下面是一段.textblog中的密码加密代码,现在数据库中已经大量存在这些加密后的密码了,公司要求用JAVA再做一个入口,如果用户从JAVA口进入,也要判断用户名与密码是不是一致,但问题是那个是C#的专用加密算法,用JAVA如何实现呢?请教大家了!
代码如下:  strText = strText.ToLower();
            Byte[] clearBytes = new UnicodeEncoding().GetBytes(strText);
            Byte[] hashedBytes = ((HashAlgorithm)CryptoConfig.CreateFromName("MD5")).ComputeHash(clearBytes);
            return BitConverter.ToString(hashedBytes);

解决方案 »

  1.   


    import java.security.MessageDigest;/**   
     * @author closewbq
     * @version 1.0
     * 对密码进行加密和验证  
     */
    public class MD5Util { /**
     * 16进制下的映射数组
     */
    private final static String[] hexDigits = { "0", "1", "2", "3", "4", "5",
    "6", "7", "8", "9", "a", "b", "c", "d", "e", "f" }; /**
     * 将密码进行加密处理
     * @param password
     * @return 加密后的字符串
     */
    public static String getPassByMD5(String password) {
    return stringByMD5(password);
    } /**  
     * 验证登录密码是否正确  
     * @param password    加密后的密码  
     * @param loginPassword    登录的密码  
     * @return    验证结果,TRUE:正确 FALSE:错误  
     */
    public static boolean validatePassword(String password, String loginPassword) {
    if (password.equals(stringByMD5(loginPassword))) {
    return true;
    } else {
    return false;
    }
    } /**
     * 对字符串进行加密处理
     * @param strString
     * @return 加密后的字符串
     */
    private static String stringByMD5(String strString) {
    if (strString != null) {
    try {
    //创建MD5算法的信息摘要   
    MessageDigest md = MessageDigest.getInstance("MD5");
    byte[] results = md.digest(strString.getBytes());

    //将得到的字节数组变成字符串返回   
    String resultString = byteArrayToHexString(results);
    return resultString.toUpperCase();
    } catch (Exception ex) {
    ex.printStackTrace();
    }
    }
    return null;
    } /**   
     * 转换字节数组为十六进制字符串  
     * @param     字节数组  
     * @return    十六进制字符串  
     */
    private static String byteArrayToHexString(byte[] results) {
    StringBuffer resultSb = new StringBuffer();
    for (int i = 0; i < results.length; i++) {
    resultSb.append(byteToHexString(results[i]));
    }
    return resultSb.toString();
    }
        
    /**
     * 将一个字节转化成十六进制形式的字符串
     * @param b
     * @return 十六进制形式的字符
     */
    private static String byteToHexString(byte b) {
    int n = b;
    if (n < 0)
    n = 256 + n;
    int d1 = n / 16;
    int d2 = n % 16;
    return hexDigits[d1] + hexDigits[d2];
    }

    }
    .net进行加密我们一般也不这么写呀,
     System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str,"MD5");
      

  2.   

    感谢各位的关注,但这个问题是个很精典的问题,比如:http://lendy.9846.com/blog/2009/01/07/php-dottext-password/请各位帮忙!
      

  3.   


    三楼正解,在.net中md5加密一句话就OK,楼主的方法就是重复造轮子
      

  4.   

    好了,不说什么了,
    1234
    用C#算法加密完:0F-03-75-84-C9-9E-7F-D4-F4-F8-C5-95-50-F8-F5-07
    md5是:81dc9bdb52d04dc20036dbd8313ed055哪位用JAVA把1234加完MD5是上面c# 那样,我二百分献上,不够再开一帖子
      

  5.   

    是和81dc9bdb52d04dc20036dbd8313ed055这个一样?还是和0F-03-75-84-C9-9E-7F-D4-F4-F8-C5-95-50-F8-F5-07一样?
      

  6.   

    0F-03-75-84-C9-9E-7F-D4-F4-F8-C5-95-50-F8-F5-07一样
      

  7.   

    话说这个java的实现复杂了, 不过比较通用!
    MessgeDigest是专门用来加密的类!public String toMD5(String input){
        MessageDigest digest = MessageDigest.getInstance("MD5");
        byte[] res = digest.digest(input.getBytes());
        return toHex(res);
    }
    private String toHex(byte[] input){
        StringBuffer buffer = new StringBuffer();
        for (int i = 0; i < input.length; i++) {
          int low = input[i] & 0x0f;
          int high = (input[i] >>> 4) & 0x0f;
          buffer.append(Character.forDigit(high, 16));
          buffer.append(Character.forDigit(low, 16));
        }
        return buffer.toString();
      }
      

  8.   

    像这样的多程序入口,还是用webservice吧!!!
    C#写个webservice,java程序来调用就好了。