Advertisement

如何使用java进行sha1加密

阅读量:

安全哈希算法(Secure Hash Algorithm)主要应用于数字签名标准(Digital Signature Standard DSS)中所定义的数字签名算法(Digital Signature Algorithm DSA)。在SHA1算法中,我们必须将原始消息(包括字符串、文件等)转化为对应的位字节序列。由于SHA1算法仅接受位作为输入数据源,在实际应用中需对原始消息进行必要的填充和长度扩展处理。具体而言,在处理过程中需要先将原始消息转化为对应的位字节序列,并在其后添加适当的填充信息以满足算法的要求。关于具体的实现细节,请参阅此处

复制代码
 public static String getSha1(String str) {  
    
     	          
    
     	         char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',  
    
     	                 'a', 'b', 'c', 'd', 'e', 'f' };  
    
     	         try {  
    
 						 MessageDigest mdTemp = MessageDigest.getInstance("SHA1");  
    
 						 mdTemp.update(str.getBytes("UTF-8"));  
    
 						 byte[] md = mdTemp.digest();  
    
 						 int j = md.length;  
    
 						 char buf[] = new char[j * 2];  
    
     	                 int k = 0;  
    
                      for (int i = 0; i < j; i++) {  
    
                      byte byte0 = md[i];  
    
     	                 buf[k++] = hexDigits[byte0 >>> 4 & 0xf];  
    
     	                 buf[k++] = hexDigits[byte0 & 0xf];  
    
              }  
    
     	             return new String(buf);  
    
     	         } catch (Exception e) {  
    
              return null;  
    
         }  
    
      }

该算法通常应用于数字信息实施签名认证和安全认证过程,在微信接入认证以及腾讯云对象存储OSS平台的操作前阶段实施签名验证。

全部评论 (0)

还没有任何评论哟~