`
a1520708
  • 浏览: 27015 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

js get 中文乱码 encodeURIComponent解决

    博客分类:
  • js
 
阅读更多
    当以get方式提交时,你设置过滤器来处理中文乱码的方式会失效; get方式的理解可以简单的理解为url上带的参数,和 form表单中指定get方式的时候,默认为get; 这个时候需要对中文进行编码,这样传输过程工就不会乱码,到后台在解码即可;下面是js中对url的编码 和 java的 解码
    搜索页面,传递key的时候,为了防止中文乱码,使用encodeURIComponent编码:
     
 function searchSubmit(){
                      reg = /[\S]+/;
                      obj=$("search_word");
                     if(!obj.value.match(reg)){
                          alert("请输入搜索的关键词!");
                         return;
                      }
                      location.href="/place/search?id=" + getUrlParam("id") + "&word=" + encodeURIComponent(obj.value);
        }

但在后台java代码直接request.getParameter("word")就已经乱码了,还没调用URLDecoder.decode。 找资料发现调用request.getParameter的时候java会自动对word进行一次解码,所以就乱码。既然java会自动对word 进行一次解码,那我们在前台进行2次编码,然后后台 URLDecoder.decode(request.getParameter("word"),"utf-8")就可以解决乱码的问题。 前台代码:

     function searchSubmit(){
          reg = /[\S]+/;
           obj=$("search_word");
          if(!obj.value.match(reg)){
             alert("请输入搜索的关键词!");
               return;
           }
 location.href="/place/search?id=" + getUrlParam("id") + "&word=" + encodeURIComponent(encodeURIComponent(obj.value));
                  }

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics