在Java中解密SecureSHA1哈希的密码?
我已使用在Java中解密SecureSHA1哈希的密码?,java,encryption,hash,Java,Encryption,Hash,我已使用SecureSHA1加密了我的密码(Password1234$),并获得以下信息 输出:SHA1密码1234$的散列是12a00057ae853a05601d5fafb7bc8141c37eaabe。 我想为它编写一个解密方法,这样如果我传递加密字符串12a00057ae853a05601d5fafb7bc8141c37eaabe.我需要获取我的密码Password1234$ 下面是我用来加密密码的代码 SecureSHA1.java import java.io.Unsupported
SecureSHA1
加密了我的密码(Password1234$),并获得以下信息
输出:SHA1密码1234$的散列是12a00057ae853a05601d5fafb7bc8141c37eaabe。
我想为它编写一个解密方法,这样如果我传递加密字符串12a00057ae853a05601d5fafb7bc8141c37eaabe.
我需要获取我的密码Password1234$
下面是我用来加密密码的代码
SecureSHA1.java
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class SecureSHA1 {
private static String convertToHex(byte[] data) {
StringBuffer buf = new StringBuffer();
for (int i = 0; i < data.length; i++) {
int halfbyte = (data[i] >>> 4) & 0x0F;
int two_halfs = 0;
do {
if ((0 <= halfbyte) && (halfbyte <= 9))
buf.append((char) ('0' + halfbyte));
else
buf.append((char) ('a' + (halfbyte - 10)));
halfbyte = data[i] & 0x0F;
} while(two_halfs++ < 1);
}
return buf.toString();
}
public static String getSHA1(String text)
throws NoSuchAlgorithmException, UnsupportedEncodingException {
MessageDigest md;
md = MessageDigest.getInstance("SHA-1");
byte[] sha1hash = new byte[40];
md.update(text.getBytes("iso-8859-1"), 0, text.length());
sha1hash = md.digest();
return convertToHex(sha1hash);
}
public static void main(String args[]){
try {
String s = "Password1234$";
String sha1S = getSHA1(s);
System.out.print("SHA1 hash for "+ s+ " is "+ sha1S);
} catch (Exception e) {
System.out.println(e);
}
}
}
import java.io.UnsupportedEncodingException;
导入java.security.MessageDigest;
导入java.security.NoSuchAlgorithmException;
公共类安全1{
私有静态字符串convertToHex(字节[]数据){
StringBuffer buf=新的StringBuffer();
对于(int i=0;i>>4)&0x0F;
int two_halfs=0;
做{
如果((0加密和散列之间有很大区别。加密的设计目的是使用密钥对某些内容进行编码和解码
散列是专门为单向计算而设计的。除非使用蛮力,否则无法从输出中获取输入
SHA1是一种哈希算法。答案是您无法反转SHA1哈希
有关更多详细信息,请参阅本文:
单向散列函数不是加密,SHA1是单向散列。@ElliottFrisch因此,我无法在使用SHA1散列后找回密码。请参阅(参考MD5,但概念相同)我们是否实现了暴力算法。暴力方法是简单地尝试对任何可能的输入值进行散列,直到创建相同的散列。如果输入很短,如密码,则预先计算的散列列表会有所帮助。这称为彩虹表。这也是为什么不只是对密码进行散列,而是使用“salt”的原因。(谷歌“彩虹表”和“密码盐”了解更多)感谢您的建议;)