关于MD5加密同一个字符串调用方式不同,返回密文不同。见鬼啦!!!!!? 400 报错
这是MAIN方法请求调用加密方法返回的密文是:c4e479cfc417f1dfc4853be31523d1bf
public static void main(String[] args) { String name = "深圳市"; String password = "963963"; String md5Value = MyUtils.getMD5(name+"#"+password); System.out.println(md5Value); }
public ActionForward test1(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception { String name = "深圳市"; String password = "963963"; String md5Value = MyUtils.getMD5(name+"#"+password); System.out.println(md5Value); return null; }
public static String getMD5(String x) { String s = null; char hexDigits[] = { // 用来将字节转换成 16 进制表示的字符 '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'}; try { java.security.MessageDigest md = java.security.MessageDigest.getInstance( "MD5" ); md.update( x.getBytes() ); byte tmp[] = md.digest(); // MD5 的计算结果是一个 128 位的长整数, // 用字节表示就是 16 个字节 char str[] = new char[16 * 2]; // 每个字节用 16 进制表示的话,使用两个字符, // 所以表示成 16 进制需要 32 个字符 int k = 0; // 表示转换结果中对应的字符位置 for (int i = 0; i < 16; i++) { // 从第一个字节开始,对 MD5 的每一个字节 // 转换成 16 进制字符的转换 byte byte0 = tmp[i]; // 取第 i 个字节 str[k++] = hexDigits[byte0 >>> 4 & 0xf]; // 取字节中高 4 位的数字转换, // >>> 为逻辑右移,将符号位一起右移 str[k++] = hexDigits[byte0 & 0xf]; // 取字节中低 4 位的数字转换 } s = new String(str); // 换后的结果转换为字符串 }catch( Exception e ) { e.printStackTrace(); } return s; }
中文的字符一直都有问题,如果是单纯的数字字符没有问题。求救呀!
去和网上的方法比较,如果你的结果不对,说明你的程序有错,不要问为什么。######
其实你两个结果都是对的,只不过一个是把字符串UTF8编码后的结果,
######
其实你两个结果都是对的,只不过一个是把字符串UTF8编码后的结果,
兄弟,你这个问题怎么解决的呀,我今天也见鬼了。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。