encodeURIComponent编码 URLDecoder.decode解码乱码的问题

搜索页面,传递key的时候,为了防止中文乱码,使用encodeURIComponent编码:
  1. <script>
  2.      function searchSubmit(){
  3.                     reg = /[/S]+/;
  4.                     obj=$("search_word");
  5.                     if(!obj.value.match(reg)){
  6.                         alert("请输入搜索的关键词!");
  7.                         return;
  8.                     }
  9.                     location.href="/place/search?id=" + getUrlParam("id") + "&word=" + encodeURIComponent(obj.value);
  10.       }
  11. </script>
但在后台java代码直接request.getParameter("word")就已经乱码了,还没调用URLDecoder.decode。

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

前台代码:
  1. <script>
  2.                 function searchSubmit(){
  3.                     reg = /[/S]+/;
  4.                     obj=$("search_word");
  5.                     if(!obj.value.match(reg)){
  6.                         alert("请输入搜索的关键词!");
  7.                         return;
  8.                     }
  9.                     location.href="/place/search?id=" + getUrlParam("id") + "&word=" + encodeURIComponent(encodeURIComponent(obj.value));
  10.                 }
  11.             </script>



你可能感兴趣的:(java,search)