java http spring mvc 302重定向 url 中文乱码

java http spring mvc 302重定向 url 中文乱码,第1张

中文转成unicode编码,然后放到配置文件中,通过取unicode编码来访问中文,就不会存在乱码的问题了,具体方法就是直接在配置文件里该中文=unicode编码就行了,然后取到这个配置文件,读取对应的值,然后放到url中。

如果两端服务器页面使用的编码不一致,就会导致乱码

如你所说,对方服务器发来的是GBK编码的内容,如果你本地PHP用的编码不是GBK就会是乱码

2种解决方案:

将页面编码更改为GBK(可以通过header('Content-Type:text/html charset=gbk');)

将GBK编码转为当期页面编码(假设当前页面是utf-8),可以使用iconv('gbk','utf-8',$content);其中$content是你经过urldecode、base64解码后的字符串

编码问题

一般有中文参数的时候编码应该是GBK或GB2312

通常默认UTF-8

还有传中文参数的时候请用:

ServerUrlEncode(url);加密

在接受中文参数的时候请用

ServerUrlDecode(url);解密

去你的网站里在传参时和接参时分别用我上面提供的方法进行处理

去webconfig中修改成

<globalization

requestEncoding="GB2312"

responseEncoding="GB2312"

/>

指定编码

发送方 ServerUrlEncode("中文", EncodingGetEncoding("GB2312"));

接收方 ServerUrlDecode(Request["key"], EncodingGetEncoding("GB2312"));

你这个问题真心不好办,建议你把页面编码改为GBK编码把。像楼上说的这些方法看似行得通,原理就是把utf-8转为gbk然后再转回utf-8,但那样是不能解决问题的,试图通过String newStr = new String(strgetBytes("gbk","utf-8"));办不到的,结果是中文字符为奇数会出现最后一个字乱码。我以前也曾碰到这个情况,最后还是把页面统一编码解决。

IE缺省对URL后面的参数是不编码发送的,但是Tomat缺省是按ISO8859-1来进行URL编码的,因此才会出错。

方法一:

对URL链接进行二次编码:

<a

onclick="javascript:windowopen(encodeURI(encodeURI('/DispatchActiondoefFormEname=FKRY0001&code_type=中文参数')))">测试</a>

或者单独对参数进行二次编码:

var

code_type

=

"中文参数";

code_type

=

encodeURI(code_type);

code_type

=

encodeURI(code_type);

windowopen("/DispatchActiondoefFormEname=FKRY0001&code_type="+code_type);

Service:

String

code_type

=

requestgetParameter("code_type");

//这句话一定要写,因为如果不写的话编码就是%E5%A6%88%

code_type

=

javanetURLDecoderdecode(code_type,"UTF-8");

有人提出为什么要在客户端对字符串重复编码两次呢?

如果因为项目需要,不能指定容器使用何种编码规则来解码提交的参数,比如:需要接收来自不同页面,不地编码的参数内容时。

(又或者是开发人员被这有点复杂的东西搞得晕头转向,不懂得如何正确的去做好这接收参数的工作)

这个时候,在客户端对参数进行二次编码,可以有效的避开“提交多字节字符”的这个棘手问题。

因为第一次编码,你的参数内容便不带有多字节字符了,成了纯粹的

Ascii

字符串。(这里把编第一次的结果叫成

[STR_ENC1]

好了。[STR_ENC1]

是不带有多字节字符的)

再编一次后,提交,接收时容器自动解一次(容器自动解的这一次,不管是按

GBK

还是

UTF-8

还是

ISO-8859-1

都好,都能够正确的得到

[STR_ENC1])

然后,再在程序中实现一次

decodeURIComponent

(Java中通常使用

javanetURLDecoderdecode(,

"UTF-8"))就可以得到想提交的参数的原值。

简单来说,就是Tomcat服务器会自动帮你做一次URLDecode,再加上你自己在Service代码里面写的URLDecode,一共就是两个Decode了。既然要两次Decode,当然就需要两次Encode了。或许你会问,干脆只Encode一次,然后在java代码里不Decode,呵呵,这个也是不行的,这其实也就是为什么要进行两次Encode的原因吧。

方法二:(经测试不支持IE8)

>

以上就是关于java http spring mvc 302重定向 url 中文乱码全部的内容,包括:java http spring mvc 302重定向 url 中文乱码、中文url编码、base64编码,PHP解码中文部分乱码、url 乱码等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/10160455.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-05
下一篇2023-05-05

发表评论

登录后才能评论

评论列表(0条)

    保存