关于get请求中文乱码的原因分析

浏览器是怎么知道该按照哪种方式编码的?
浏览器向服务器请求数据的时候,服务器通过响应头中的content-type 来告诉浏览器,发送的内容的编码格式。比如,我们在html 页面里面加上如下的模拟响应头:<meta http-equiv="Content-Type" content="text/html;charset=gbk" /> 。浏览器收到这个响应头之后,就会按照gbk 的方式来打开页面。之后,在这个页面上,浏览器向服务器提交数据的时候,都会按照gbk 来编码。
 
URL 编码和字符集( gbk 或者 utf-8 )的关系



 
Get 请求乱码分析
Get 请求参数是附加在url 后面的,如果有中文的话,会对中文进行urlencode 。如果html 页面本身是gbk 编码,则浏览器进行urlencode 时会采用gbk 的字符集,字符串" 张三" 就会被编码成%D5%C5%C8%FD
tomcat9 中默认的 URIEncoding UTF, 因此 tomcat url 进行 urldecode (主要是为了取出 get 提交的参数)时,就会解码错误而乱码。以下是 tomcat 官方文档对 URIEncoding 的解释。
This specifies the character encoding used to decode the URI bytes, after %xx decoding the URL. If not specified, UTF-8 will be used unless the  org.apache.catalina.STRICT_SERVLET_COMPLIANCE   system property  is set to  true  in which case ISO-8859-1 will be used.
 
 
 
Get 请求乱码解决
在前端js里面,对需要使用get提交的中文字符串使用encodeURI()进行编码,该函数会一直使用utf-8的字符集进行url编码,不管页面采用的是什么编码,该函数都会使用utf-8字符集进行url编码。
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值