HttpServletRequest和⽤用户登录表单提交

简介:讲解 HttpServletRequest和表单提交实战

  • 使⽤用jsp编写form表单提交
  • UserServlet, doPost⾥里里⾯面调⽤用doGe
java 复制代码
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" %>
<!DOCTYPE html>
<html>
<head>
    <title>简易 JSP 示例</title>
</head>
<body>
<form action="/user/login" method="post">
    <div>⽤用户名: <input type="text" name="userName"/></div>
    <div>密码: <input type="password" name="pwd"/></div>
    <div><input type="submit" value="登录"></div>
</form>
</body>
</html>
java 复制代码
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    resp.setContentType("text/html;charset=utf-8");
        String userName = req.getParameter("userName");
        String pwd = req.getParameter("pwd");
        if (userName.equals("gaze") && pwd.equals("123")) {
            resp.getWriter().write("登录成功");
        } else {
            resp.getWriter().write("账号密码错误");
        }
    }
  • 关于乱码问题

//POST⽅方式遇到中⽂文乱码,如果客户端是以UTF-8字符编码,需要服务器器以UTF-8的编码接收数据,

req.setCharacterEncoding("UTF-8");

//对于以get⽅方式传输的中⽂文数据乱码需要另外⼀一种⽅方式,默认的还是使⽤用ISO8859-1这个字符编码来接

收数据

//办法:对接收到的原始数据的字节数组,然后通过字节数组以指定的编码构建字符串串,解决乱码问题

String name = request.getParameter("name");//接收数据

name =new String(name.getBytes("ISO8859-1"), "UTF-8")

  • 乱码问题解决的核⼼心:通过字节数组以指定的编码构建字符串串,这⾥里里指定的编码是根据客户端那边提交数据时使⽤用的字符编码来定
相关推荐
何仙鸟6 分钟前
GarmageSet下载和处理
java·开发语言
wefly201710 分钟前
免安装!m3u8live.cn在线 M3U8 播放器,小白也能快速上手
java·开发语言·python·json·php·m3u8·m3u8在线转换
yuweiade13 分钟前
springboot和springframework版本依赖关系
java·spring boot·后端
ywf121514 分钟前
springboot设置多环境配置文件
java·spring boot·后端
爱学习的程序媛22 分钟前
【Web前端】JavaScript设计模式全解析
前端·javascript·设计模式·web
小马爱打代码26 分钟前
SpringBoot + 消息生产链路追踪 + 耗时分析:从创建到发送,全链路性能可视化
java·spring boot·后端
小码哥_常31 分钟前
从SharedPreferences到DataStore:Android存储进化之路
前端
老黑40 分钟前
开源工具 AIDA:给 AI 辅助开发加一个数据采集层,让 AI 从错误中自动学习(Glama 3A 认证)
前端·react.js·ai·nodejs·cursor·vibe coding·claude code
虾..40 分钟前
多路复用 --- select系统调用
服务器·数据库·sql
杨云龙UP1 小时前
mysqldump逻辑备份文件恢复总结:全库恢复、单库恢复,一篇讲明白
linux·运维·服务器·数据库·mysql·adb