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 

  • 相关阅读:
    Pytorch——张量 Tensors
    Pytorch——cuda的使用
    神经网络训练模型的两种写法
    Pytorch——torch.nn.init 中实现的初始化函数
    线性回归的简洁实现
    Pytorch——net.parameters()参数获取
    Tensor和NumPy相互转换
    Codeforces Round #600 (Div. 2) A、B
    2020-2021 ACM-ICPC, Asia Seoul Regional Contest G. Mobile Robot
    大组合数模板
  • 原文地址:https://www.cnblogs.com/ae6623/p/4416463.html
Copyright © 2011-2022 走看看