在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”的原因。(谷歌“彩虹表”和“密码盐”了解更多)感谢您的建议;)