java - servlet传汉字到jsp乱码
巴扎黑
巴扎黑 2017-04-17 11:47:45
0
7
620

response.sendRedirect("content/template/zpsc.jsp?path="+realPath+"&responseText="+responseText+"");
realPath里有汉字
'''response.setContentType("text/html; charset=utf-8");
request.setCharacterEncoding("utf-8"); ''不管用

巴扎黑
巴扎黑

全員に返信(7)
Peter_Zhu

你前端接收数据的是javascript还是jsp 如果是javascript的话在后台你可以用escape()对文字进行加密,然后用javascript中的unescape()进行解密。 因为javascript中自带这两个方法进行加密解密比较方便。这两个加密和解密的方法网上已经有高手用java的方式实现了,可以下一个工具类然后就这样的方式在后台进行加密,在前台用javascript自带方法进行解密。这样一定是没有乱码的。如果是用jsp接收数据建议不要采用这种方式。可以用一些内置对象传值。

いいねを押す +0
左手右手慢动作

Response.sendRedirect("content/template/zpsc.jsp?path="+URLEncoder.encode(realPath, "UTF-8")+"&responseText="+URLEncoder.encode(responseText,"UTF-8")+"");

做个好人吧

いいねを押す +0
PHPzhong

这样是肯定不行的,你这个是通过url传值,会出现转码问题

比较简单和正统的方式是通过request、session、application等内置对象传值

いいねを押す +0
左手右手慢动作

通过url传汉字的话,先要将汉字转成unicode

いいねを押す +0
伊谢尔伦

通过request、session、application等内置对象传值

いいねを押す +0
阿神

前台js: encodeURI(encodeURI(tag))

后台java代码: String tag = URLDecoder.decode(tag, "utf-8");

いいねを押す +0
洪涛

要不写个 字符过滤器 试试看?

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!