1. Servlet接收用户请求参数
在Servlet中接收用户发来的请求参数
1. 为什么要在Servlet中接收?
之前是需要自己从请求数据包中去解析数据,现在使用WebServer,WebServer已经解析过请求数据包,将请求参数读取出来了,开发者仅需要在Servlet中通过API来获取就可以了
2. 如何获取?
-
通过request对象去获取
-
request提供了一个API
String value=request.getParameter("username"); 注: 1. input type="text/password" textarea,如果用户没有输入任何内容,该API返回的是 空字符串 "" 2. input type="radio/checkbox" select-option,如果用户什么都没选,该API返回的是 null
-
为什么这么设计?
2. 实际开发功能
1. 新建一个maven项目,名称为servlet02,打包方式选war
2. 在webapp文件夹下添加一个 addUser.html
3. 解决请求乱码
-
乱码产生的原因:编码规则和解码规则不一致
-
浏览器对参数进行编码时使用的编码规则,受当前html页面的,浏览器使用UTF-8对参数进行编码
-
服务器(Tomcat)默认使用ISO8859-1对请求参数进行解码
-
-
解决方案:
-
POST请求:
- 通知Tomcat使用UTF-8对收到的参数进行解码
- API: request.setCharacterEncoding(“UTF-8”)
注:该API仅对请求实体中的数据生效,对url中的数据无效的 - 注意:该API必须在调用 request.getParameter()之前调用
-
GET请求:
- 修改Tomcat的配置文件
- 修改server.xml,第65行
- 通知Tomcat使用UTF-8对请求行中的数据进行解码
- 该项操作仅需要在Tomcat7版本中使用,Tomcat8已经修复该问题
- 修改Tomcat的配置文件
-
4. Http协议的请求方式
Http协议规定了8种请求方式,最常用的是2种,get和post
1) 为什么要规定多种请求方式?
根据用户请求服务器的目的不同,划分成不同的方式,采用对应的方式可以更高效
2)get请求
代表用户从服务器获取数据(下载),是最为常用的请求方式
1. 以下几种情况,默认使用get请求:
1. 在浏览器地址栏输入一个url时
2. 表单(form)的默认提交方式
3. 是超链接(<a>标签)的默认请求方式
2. get请求的特点:
1. 请求参数会被拼接到url后面,显示在浏览器的地址栏上
1. 安全性比较低
2. 浏览器对地址栏中的内容的长度有限制,一般在2kb
3)post请求
代表用户向服务器提交(上传)数据
1. POST请求的特点:
1. 请求参数不会拼接在url后面,而是放在请求实体中
1. 安全性相对高一些
1. 注意,http协议不会对请求实体中的数据进行解密
2. 浏览器对请求实体中数据的长度没有限制,理论上多长都可以
4) get和post如何选择?
1. 用户从服务器获取数据时,使用GET
2. 用户向服务器提交数据时,使用POST
3. 所有涉及密码的表单,都必须使用POST
4. GET请求可以提交数据,但是长度有限制,约2KB
5. Servlet输出中文的乱码问题
在Servlet中输出中文,用户在浏览器收到的是乱码
1. 乱码产生原因
- 服务器(Tomcat)默认使用ISO8859-1对响应内容进行编码
- 浏览器(谷歌浏览器)默认使用 平台码 对响应内容进行解码
- 平台码受操作系统影响
2. 解决方案
-
通知Tomcat使用UTF-8对响应内容进行编码
response.setCharacterEncoding("UTF-8")
-
通知浏览器使用UTF-8对响应内容进行解码
response.setContentType("text/html;charset=utf-8"); 注:该API有2个功能 1. 通知浏览器使用UTF-8对响应内容进行解码 2. Tomcat读取到这部分内容后,会自动使用UTF-8对响应内容进行编码 3. 因此,解决Servlet的响应乱码问题,仅需要这一行代码 4. 该API必须写在调用 response.getWriter().write()之前
6. 在项目中添加JDBC的代码
-
在项目中新建一个util包,复制之前的DBUitls.java文件到util包下
-
在项目的pom.xml中添加对数据库连接jar包和数据库连接池jar包的依赖
<dependencies> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.6</version> </dependency> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.4</version> </dependency> </dependencies>
-
将jdbc.properties拷贝到src/java/resources文件夹下
-
修改jdbc.properties文件的内容
-
开AddUserServlet中添加将数据存入数据库的代码
-
测试项目
- 添加英文名用户,查看数据库中是否有数据
- 添加中文名用户,查看数据库中是否有乱码问题
- 添加重复的用户名,查看是否提示添加失败