又见中文乱码

原创 2016年06月02日 09:51:39

乱码问题总是记不住,每次越到了解决就不管了,现在在写一遍增加既要

场景是:jsp上传值到后端发现“啊”变为“å•Š”

思路:在jsp的url里将中文用encodeURI加密在加密,然后再java接收时解密

实现:

jsp上:

原来的样子:var url="<%=basePath%>interface/opt_encrypt?type="+type+"&encryptStr="+value;

修改后的样子:var url="<%=basePath%>interface/opt_encrypt?type="+type+"&encryptStr="+encodeURI(encodeURI(value));


引入包

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ page import="java.net.*" %>



<script>

/*加密
v:value
t:type*/
function encryptHandle(v,t){
var value= $("#"+v).val();
var type="";
if(t==5)type="md5";
if(t==640)type="64_encode";
if(t==641)type="64_decode";
var url="<%=basePath%>interface/opt_encrypt?type="+type+"&encryptStr="+encodeURI(encodeURI(value));
$.ajax({type: "GET",
 url: url,
 success: function(result){
 $("#"+v).val(result.ciphertext);
 }
}); 
}

</script>


java接收处理:

/**
* 接口、加密解决
* encryption
* decryption加密解密
* @param request
* @param encryptStr
* @return map
*/
@RequestMapping(value="opt_encrypt",method=RequestMethod.GET,produces="application/json;charset=UTF-8")
@ResponseBody
public Map encryptHandle(HttpServletRequest request,
@RequestParam("type") String type,
@RequestParam("encryptStr") String encryptStr){
String encStr="";
String str="";
try {
encStr=URLDecoder.decode(encryptStr,"utf-8");//对中文参数进行解码
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}

if(type.equals("md5"))
str=MD5Util.MD5(encStr);
else if(type.equals("64_encode"))
str=Base64Codec.getBase64(encStr);
else if(type.equals("64_decode"))
str=Base64Codec.getFromBase64(encStr);


        //开始返回
        Map map = new HashMap();
        map.put("success", Boolean.TRUE);
        map.put("ciphertext",str);
        return map;
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

百度地图生成器,图标消失,中文乱码和自定义名字undefind

中文乱码是因为生成的网页代码中,charset设置成gbk了,手动把 /*修改为*/ 自定义名字undefind是因为生成的代码有个错误,手动把69行左右的代码var label = new BMap...

修复ReportNG中文乱码问题

  • 2017-09-27 15:56
  • 1.32MB
  • 下载

MySQL字符集 GBK、GB2312、UTF8区别 解决 MYSQL中文乱码问题

MySQL中涉及的几个字符集 character-set-server/default-character-set:服务器字符集,默认情况下所采用的。 character-set-databa...

【MySQL for Mac】navicat for mysql中文乱码问题——MySQL在Mac的字符集设置

1. 首先打开『终端』 —> 输入 /usr/local/mysql/bin/mysql -u root -p->密码->回车—>连接到数据库 然后输入 show variables li...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)