关于servlet中doGet和doPost乱码再一次理解
今天系统的整理了在web项目下,出现的编码问题,下面就做一些总结:
首先对HTTP协议中对GET和POST的定义:
| GET | POST | |
|---|---|---|
| 后退按钮/刷新 | 无害 | 数据会被重新提交(浏览器应该告知用户数据会被重新提交)。 |
| 书签 | 可收藏为书签 | 不可收藏为书签 |
| 缓存 | 能被缓存 | 不能缓存 |
| 编码类型 | application/x-www-form-urlencoded | application/x-www-form-urlencoded 或 multipart/form-data。为二进制数据使用多重编码。 |
| 历史 | 参数保留在浏览器历史中。 | 参数不会保存在浏览器历史中。 |
| 对数据长度的限制 | 是的。当发送数据时,GET 方法向 URL 添加数据;URL 的长度是受限制的(URL 的最大长度是 2048 个字符)。 | 无限制。 |
| 对数据类型的限制 | 只允许 ASCII 字符。 | 没有限制。也允许二进制数据。 |
| 安全性 |
与 POST 相比,GET 的安全性较差,因为所发送的数据是 URL 的一部分。 在发送密码或其他敏感信息时绝不要使用 GET ! |
POST 比 GET 更安全,因为参数不会被保存在浏览器历史或 web 服务器日志中。 |
| 可见性 | 数据在 URL 中对所有人都是可见的。 | 数据不会显示在 URL 中。 |
再次理解servlet中有的那几个方法:
增、删、查、改
get -> select
post -> update
put -> insert
delete -> delete
但是其实get和post就能完成我们的所有操作!
其实有doGet、doPost、doPut和doDelete但是其中doPut和doDelete用的较少。而get方式直接加在url后面,post方式必须通过表单。
我们常用的就是doGet和doPost,get方式其实在http协议中并不是一个传数据的角色,更多的是用来从服务器上获得数据的,严格意义上来讲最初不是用来从客户端到服务器这个传输数据的;只是form表单的get方式提交,对url传值的扩展通过?name=xxx&password=xxx诸如此类的方式。
这里我们对get的url传值已经有了深刻的了解,也就更能理解为什么我们传大文本和文件图片等等的时候,都是使用post的方式了吧?url传值不能传递实体内容,因为url的长度在http协议中虽然没有明确的长度规定,但是在浏览器的规范中都是限制了长度的,1KB或2KB或多或少!
补充存在于:url中的内容都要通过urlencode进行加密,成符合url格式的字符串:
| ‘ ‘ | 空格 | %20 |
| ‘!’ | 感叹号 | %21 |
| ‘&’ | 花at | %26 |
| ‘/’ | 斜杠 | %2F |
| ‘:’ | 冒号) | %3A |
| ‘=’ | 等于号 | %3D |
| ‘?’ | 问号 | %3F |
get方式遇到的问题:
问题的起因很简单,在网上看了一些博文说,在tomcat作为的web容器下,通过GET方式进行表单提交,传参到servlet中会出现乱码,但是我在本地进行测试的时候发现,并没有出现GET方式乱码的情况:
因为我的IDE中配置的工作空间的编码格式是UTF8的,所以猜测我的tomcat可能是UTF8的。
首先回忆我是不是对我的tomcat进行了配置,故到tomcat中的config中查看server.xml中查看是不是有配置:
发现其中并没有多余的配置,测试了8.0和发现也没有出现乱码的情况,后面了解到tomcat从8.0开始默认的编码就是UTF8了,测试7.0的Tomcat发现,GET方式出现了乱码,通过:new String(xxx.getBytes(“ISO-8859-1“), “utf-8“);解码正常:

测试结果Tomcat从8.0开始转化为默认编码为utf-8的格式了,但是8.0以下的tomcat默认的编码还是ISO-8859-1;
Tomcat8.0及以上默认编码为utf-8;
Tomcat7.0及以下默认编码为ISO-8859-1;
项目开发下,我们可以通过在tomcat的server.xml中的URIEncoding="UTF-8";

这样设置tomcat的编码格式为utf-8来配合我们IDE中的utf-8,来保证在开发过程中不出现乱码问题;
在实际的上线的时候
1.如果可以修改web容器的编码为utf-8最好(urlEncoding="utf-8");
2.不行的话我们可以选择:过滤器+动态代理的方式,用动态代理的方式来重写HttpServlet中的getParameter方法【逻辑:如果为GET方式的request请求,就做一个newString(xxx.getBytes(“ISO-8859-1”), “utf-8”)】来解决ISO-8859-1编码下的tomcat的get方式中文乱码的问题;【在过滤器中的操作】 -- 后面会专门讲
3.当然最好的就是,不要使用get方式进行中文的传参!
POST方式遇到的问题:

使用POST进行获取参数的时候也要注意!
必须在doPost方法的一开始就使用:request.setCharacterEncoding("utf-8");
或者在过滤器中一开始就写上request.setCharacterEncoding("utf-8");来保证POST方式后面获取到的parameter正常,
【这里有个问题要记录一下,如果不写这一句直接在doPost中getParameter,就会造成获取的中文参数异常:这句代码约束post中的内容编码为utf-8,必须写在doPost或者filter中第一个request.getParameter之前才行,如果没有设置utf-8,在调用第一个getParameter之后request中的所有键值对就都被解析成了ISO-8859-1的编码的字符了,再去设置characterEncoding为utf-8就已经无效了,就只能通过getParameter之后new String(xxx.getBytes("ISO-8859-1"),"utf-8")的方式来还原字符串了】
但是get方式是取决于Tomcat的默认的urlencoding的编码。
关于URL中的中文的问题:
在IE下的url中不能显示中文,但是在firefox和chrome中的url中可以显示中文,因为我都设置为了unicode,所以在unicode编码的浏览器环境下,原本encoder.encode(“utf-8”);的数据,都被浏览器替换解密了出来。
在开发中,为了保证开发的稳定性,我们在能够设置utf-8的地方都设置utf-8;
在运行环境复杂,为了保证系统的稳定下,尽量使用doPost传值,不使用get方式传值,或者url传值中不使用中文!
关于servlet中doGet和doPost乱码再一次理解的更多相关文章
- servlet中doGet()和doPost()的用法
转自:https://blog.csdn.net/qq_38963960/article/details/79468182 1.servlet中doGet()和doPost()的用法 一般来说我们是用 ...
- servlet中doGet()和doPost()的区别
1.生成方式 get方法有四种: ①直接在URL地址栏中输入URL ②网页中的超链接 ③form中method为get ④form中method为空时,默认是get提交 post只知道有一种:form ...
- Servlet中response、request乱码问题解决
Java Web(二) Servlet中response.request乱码问题解决 三月不减肥,五月徒伤悲,这就是我现在的状态,哈哈~ 健身.博客坚持. --WH 一.request请求参数出现 ...
- Java Web之Servlet中response、request乱码问题解决
Java Web之Servlet中response.request乱码问题解决 一.request请求参数出现的乱码问题 get请求: get请求的参数是在url后面提交过来的,也就是在请求行中, ...
- Servlet的doGet与doPost方法的区别与使用
Servlet的doGet与doPost方法的区别与使用 2016年07月07日 13:05:13 阅读数:10222 一,区别 在使用表单提交数据到服务器的时候有两张方式可共选择,一个是post一个 ...
- 去除myeclipse中doget和dopost方法中的注释
当我们使用myeclipse新建servlet时发现doget和dopost方法中有一些无用的注释,每次新建一个servlet时都要手动删除特别麻烦. 下面就教大家如何去除这些注释! 以myeclip ...
- 【Servlet】doGet()与doPost()的区别
doGet与doPost的区别 .Servlet接口只定义了一个服务方法--service .当发出客户端请求时,调用service方法并传递一个请求和响应对象 .使用时经常在doPost()中调用d ...
- 自定义servlet重写doGet或doPost方法是如何实现多态的
我们知道,如果我们自定义一个servlet继承HttpServlet,并且重写HttpServlet中的doGet或doPost方法,那么从浏览器发送过来的request请求将调用HttpServle ...
- 自定义servlet重写doGet或者doPost方法时,405 method not allowed
自定义servlet public class TestServlet extends HttpServlet { @Override protected void doGet(HttpServlet ...
随机推荐
- Python高阶之多线程锁机制
'''1.多进程的优势:为了同步完成多项任务,通过提高资源使用效率来提高系统的效率.2.查看线程数:threading.enumerate()函数便可以看到当前线程的数量.3.查看当前线程的名字:th ...
- robotframework - selenium Api介绍
一.介绍下selenium常用的api *** Settings ***Library SeleniumLibraryResource baidu业务.txtResource UI分层.txt *** ...
- Winform框架中窗体基类的用户身份信息的缓存和提取
在Winform开发中,有时候为了方便,需要把窗体的一些常规性的数据和操作函数进行封装,通过自定义基类窗体的方式,可以实现这些封装管理,让我们的框架统一化.简单化的处理一些常规性的操作,如这里介绍的用 ...
- ubuntu16.04细节设置
1.查看无线网卡名称 $ iwconfig ------------------ lo no wireless extensions. eth1 no wireless extensions. eth ...
- etcd学习(4)-centos7中部署etcd
etcd的搭建 前言 单机 集群 创建etcd配置文件 更新etcd系统默认配置 启动 配置ETCD为启动服务 测试下 参考 etcd的搭建 前言 这里记录下如何搭建etcd 单机 在etcd的rel ...
- (opencv09)cv2.getStructuringElement()构造卷积核
(opencv09)cv2.getStructuringElement()构造卷积核 rectkernel = cv2.getStructuringElement(shape, ksize, anch ...
- Linux下如何查看定位当前正在运行软件的配置文件
netstat命令 用于显示与IP.TCP.UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况 netstat -lntup 说明: l:listening n:num t:tc ...
- LeetCode通关:求次数有妙招,位运算三连
分门别类刷算法,坚持,进步! 刷题路线参考: https://github.com/chefyuan/algorithm-base 大家好,我是刷题困难户老三,这一节我们来刷几道很有意思的求次数问题, ...
- Java代码中,如何监控Mysql的binlog?
最近在工作中,遇到了这样一个业务场景,我们需要关注一个业务系统数据库中某几张表的数据,当数据发生新增或修改时,将它同步到另一个业务系统数据库中的表中. 一提到数据库的同步,估计大家第一时间想到的就是基 ...
- QT 如何在调试时能进入源码方式(MacOS)
最近在学习QT, 遇到一些crash, 也没看过QT源码啊, 就想类似Java一样, 在出错时进入源码跟踪一下, 但是QT和Java太不一样了, 死活进不去. 研究了几天, 发现本来是很简单的事情, ...