자바 암호 MD5 암호 화

16522 단어 Java
암호 MD5 암호 화, 문자열 바 꾸 기 32 비트 대문자
  • 방법:
         public  static String MD5(String pwd) {
          // 用于加密的字符
          char md5String[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
                  'A', 'B', 'C', 'D', 'E', 'F' };
          try {
              // 使用平台的默认字符集将此 String 编码为 byte序列,并将结果存储到一个新的 byte数组中
              byte[] btInput = pwd.getBytes();
    
              // 信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。
              MessageDigest mdInst = MessageDigest.getInstance("MD5");
    
              // MessageDigest对象通过使用 update方法处理数据, 使用指定的byte数组更新摘要
              mdInst.update(btInput);
    
              // 摘要更新之后,通过调用digest()执行哈希计算,获得密文
              byte[] md = mdInst.digest();
    
              // 把密文转换成十六进制的字符串形式
              int j = md.length;
              char str[] = new char[j * 2];
              int k = 0;
              for (int i = 0; i < j; i++) { // i = 0
                  byte byte0 = md[i]; // 95
                  str[k++] = md5String[byte0 >>> 4 & 0xf]; // 5
                  str[k++] = md5String[byte0 & 0xf]; // F
              }
              // 返回经过加密后的字符串
              return new String(str);
          } catch (Exception e) {
              return null;
          }
      }
    
  • 방법 호출:
      public static void main(String[] arg){
        System.out.print(MD5("ls123"));
      }
    
  • 암호 화 결과: 0F60DD0BCB58E50E8190327DC60E826A
  • 전체 코드:
     public class KEMD5Utils {
    
      /**
       * 32位大写
       * @param pwd 密码
       * @return String
       * @author 王子様
       * date:   2019/5/24 17:34
       */
      public  static String MD5(String pwd) {
          // 用于加密的字符
          char md5String[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
                  'A', 'B', 'C', 'D', 'E', 'F' };
          try {
              // 使用平台的默认字符集将此 String 编码为 byte序列,并将结果存储到一个新的 byte数组中
              byte[] btInput = pwd.getBytes();
    
              // 信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。
              MessageDigest mdInst = MessageDigest.getInstance("MD5");
    
              // MessageDigest对象通过使用 update方法处理数据, 使用指定的byte数组更新摘要
              mdInst.update(btInput);
    
              // 摘要更新之后,通过调用digest()执行哈希计算,获得密文
              byte[] md = mdInst.digest();
    
              // 把密文转换成十六进制的字符串形式
              int j = md.length;
              char str[] = new char[j * 2];
              int k = 0;
              for (int i = 0; i < j; i++) { // i = 0
                  byte byte0 = md[i]; // 95
                  str[k++] = md5String[byte0 >>> 4 & 0xf]; // 5
                  str[k++] = md5String[byte0 & 0xf]; // F
              }
              // 返回经过加密后的字符串
              return new String(str);
          } catch (Exception e) {
              return null;
          }
      }
      
          public static void main(String[] arg){
            System.out.print(MD5("ls123"));
          }
      }
    
    
  • 좋은 웹페이지 즐겨찾기