传输中文乱码js解决方法

encodeURI要编码两次

var a="我的";
  //编译两次
//window.location.href = "http://127.0.0.1:8080/kabao-api/xtetest/c.do?title="+encodeURI(encodeURI(a)); window.location.href=encodeURI(encodeURI("http://127.0.0.1:8080/kabao-api/xtetest/c.do?title="+a));

后台接收编译两次之后的代码操作

String title = request.getParameter("title");
System.out.println(title); //%E6%88%91%E7%9A%84 String encode
= URLDecoder.decode(title, "UTF-8"); System.out.println(encode); //我的



 

编译一次

var a="我的";
//编译一次 //window.location.href = "http://127.0.0.1:8080/kabao-api/xtetest/c.do?title="+encodeURI(a);
window.location.href=encodeURI("http://127.0.0.1:8080/kabao-api/xtetest/c.do?title="+a);

后台接收编译一次之后的代码操作

String title = request.getParameter("title");
System.out.println(new String(title.getBytes("ISO-8859-1"), "UTF-8"));



一般情况下,tomcat容器中request.getParameter(paramName);容器会自动按照容器默认的编码进行解码,默认是iso-8859-1,因为encodeURI使用的是UTF-8编码规则来编的,如果将tomcat的配置文件server.xml中的

<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="utf-8" />

URIEncoding修改成utf-8那样在后台就不用解码了,因为容器会自动按照utf-8进行解码。

如果不能修改容器的编码就在接收的参数的时候先使用iso-8859-1接收然后在使用utf-8获取比如:title.getBytes("ISO-8859-1"), "UTF-8")

前台提交的时候进行二次编码,在第一次进行编码的时候进行utf-8进行了编码因为utf-8是最灵活的utf编码形式,即兼容iso -8859-1又可以用来表示所有语言的字符,而且ISO-8859-1编码范围使用了单字节内的所有空间,把其他任何编码的字节流当作ISO-8859-1编码看待都没有问题。所以第一次编码就变成的单字节字符,第二次是为了与解码相对相应  即: 中文字符 ---->utf-8 -->utf-8(iso-8859-1) |||iso-8859-1容器解码-->utf-8用于解码-->中文字符  这样就相对应了,就不会产生编译乱码

 

也可以使用filter或者设置pageEncoding、contentType来设置定义编码

<%@ page language="java" contentType="text/html;charset=UTF-8" pageEncoding="UTF-8"%>

 

 java 编码解码

java.net.URLEncoder.encode(String s,"编码");

java.net.URLDecoder.decode(String s,"编码");

js编码解码

encodeURI(String3.value);编码

decodeURI(String1.value);解码


escape(String);编码

unescape(string);解码


 encodeURIComponent(URIstring);编码

decodeURIComponent(URIstring);解码

提示:请注意 encodeURIComponent() 函数 与 encodeURI() 函数的区别之处,前者假定它的参数是 URI 的一部分(比如协议、主机名、路径或查询字符串)。因此 encodeURIComponent() 函数将转义用于分隔 URI 各个部分的标点符号。

 详细编码介绍

转载于:https://www.cnblogs.com/dashuai01/p/4864660.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值