有次开发要求将用户的姓名前后端分别进行MD5加密进行对比,在本地windows环境开发测试过程中对比无误,但在服务器端加密过后与原有加密的密文不一致,首先想到可能是接收参数时出现了编码和解码不一致导致乱码(Windows的默认编码是使用GBK,本次服务的编码是UTF-8),但是这个很快就排除了,以为前端和后端的编码格式都是UTF-8编码,在添加了日志打印以后也证实了并不是参数传递过程中出现乱码,所以问题指向了MD5加密 最后找到原因是此次MD5加密的过程中字符串转字节时没有指定UTF-8编码,导致使用了服务器的GBK默认编码,在修改编码和解密后问题解决,但是本地开发也是windnows没有指定编码会使用项目代码的默认编码,但是服务器windows就会默认使用系统的GBK编码,这还是一个待解决的问题。
来源:oschina
链接:https://my.oschina.net/u/3087202/blog/1922936