zoukankan      html  css  js  c++  java
  • 【技术贴】解决前台js传参中文乱码

    方法1:

    前台两次编码,后台一次解码。因为getParamet已经自动解了一次了。

    JavaScript:

    window.self.location="list.jsp?searchtext="+encodeURIComponent(encodeURIComponent(seartext));

    java:

    searchtext=java.net.URLDecoder.decode(searchtext,"UTF-8");

    方法2:

    另外还有一种方法是JavaScript进行一次编码,后台java处理时换种想法就好了:

    JavaScript:

    window.self.location="list.jsp?searchtext="+encodeURIComponent(seartext);

    java代码:

    String s = new String(request.getParameter("name").getBytes("ISO8859-1"), "UTF-8");

    两种方法都很实用,我以前一直是用第二种方法。现在学到了第一种方法,总结一下两种方法的用处,第一种,前台两次转码,后台一次解码适合用于utf-8编码系统和GBK系统编码项目之间的跳转。第二种全部都适合。推荐使用第二种,前台处理比较简单。后台也比较简单。但是extjs下面使用encodeURIComponent()方法进行编码后,可能会有个别汉字在java服务器端处理的时候丢失的现象(比如‘系统管理员’五个字,到后台使用第二种办法new String的那种,就会发现丢失最后一个‘员’字),换用第一种办法后,此现象消失。所以第二种办法先用,出现问题了就换第一种。

    基本原则就是前台两次转码,后台一次转码。

    前台js    -- UrlEncoding() * 2

    后台java -- Decode *1 

  • 相关阅读:
    04.VUE学习之v-text v-html
    03.VUE学习之动态绑定值
    2019年Vue学习路线图
    02.VUE学习二之数据绑定
    01.VUE学习一
    一张图解析FastAdmin中的表格列表的功能
    python 正则表达式与JSON字符串
    jQuery的select2下拉框的搜索功能(使用select2插件,方便简单)
    笔记1 python入门学习笔记
    MySQL----Navicat使用
  • 原文地址:https://www.cnblogs.com/ae6623/p/4416463.html
Copyright © 2011-2022 走看看