有次开发要求将用户的姓名先后端分别进行MD5加密进行对比,在本地windows环境开发测试过程当中对比无误,但在服务器端加密事后与原有加密的密文不一致,首先想到多是接收参数时出现了编码和解码不一致致使乱码(Windows的默认编码是使用GBK,本次服务的编码是UTF-8),可是这个很快就排除了,觉得前端和后端的编码格式都是UTF-8编码,在添加了日志打印之后也证明了并非参数传递过程当中出现乱码,因此问题指向了MD5加密 最后找到缘由是这次MD5加密的过程当中字符串转字节时没有指定UTF-8编码,致使使用了服务器的GBK默认编码,在修改编码和解密后问题解决,可是本地开发也是windnows没有指定编码会使用项目代码的默认编码,可是服务器windows就会默认使用系统的GBK编码,这仍是一个待解决的问题。前端