navicate密码解密

  public static void main(String []args) {
            //navicat11解密
            Navicat11Cipher de = new Navicat11Cipher();
            System.out.println(de.decryptString("15057D7BA390"));
            //navicat12解密
            Navicat12Cipher de12 = new Navicat12Cipher();
            System.out.println(de12.decryptString("835045BB2B22A3306A7743D8F64FF3CB"));
        }
        static class Navicat11Cipher {
            public static final String DefaultUserKey = "3DC5CA39";
            private static byte[] _IV;

            private static SecretKeySpec _Key;
            private static Cipher _Encryptor;
            private static Cipher _Decryptor;

            private static void initKey(String UserKey) {
                try {
                    MessageDigest sha1 = MessageDigest.getInstance("SHA1");
                    byte[] userkey_data = UserKey.getBytes(StandardCharsets.UTF_8);
                    sha1.update(userkey_data, 0, userkey_data.length);
                    _Key = new SecretKeySpec(sha1.digest(), "Blowfish");
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }

            private static void initChiperEncrypt() {
                try {
                    // Must use NoPadding
                    _Encryptor = Cipher.getInstance("Blowfish/ECB/NoPadding");
                    _Encryptor.init(Cipher.ENCRYPT_MODE, _Key);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }

            private static void initChiperDecrypt() {
                try {
                    // Must use NoPadding
                    _Decryptor = Cipher.getInstance("Blowfish/ECB/NoPadding");
                    _Decryptor.init(Cipher.DECRYPT_MODE, _Key);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }

            private static void initIV() {
                try {
                    byte[] initVec = DatatypeConverter.parseHexBinary("FFFFFFFFFFFFFFFF");
                    _IV = _Encryptor.doFinal(initVec);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }

            private void xorBytes(byte[] a, byte[] b) {
                for (int i = 0; i < a.length; i++) {
                    int aVal = a[i] & 0xff; // convert byte to integer
                    int bVal = b[i] & 0xff;
                    a[i] = (byte) (aVal ^ bVal); // xor aVal and bVal and typecast to byte
                }
            }

            private void xorBytes(byte[] a, byte[] b, int l) {
                for (int i = 0; i < l; i++) {
                    int aVal = a[i] & 0xff; // convert byte to integer
                    int bVal = b[i] & 0xff;
                    a[i] = (byte) (aVal ^ bVal); // xor aVal and bVal and typecast to byte
                }
            }

            static {
                initKey(DefaultUserKey);
                initChiperEncrypt();
                initChiperDecrypt();
                initIV();
            }

            private byte[] Encrypt(byte[] inData) {
                try {
                    byte[] CV = Arrays.copyOf(_IV, _IV.length);
                    byte[] ret = new byte[inData.length];

                    int blocks_len = inData.length / 8;
                    int left_len = inData.length % 8;

                    for (int i = 0; i < blocks_len; i++) {
                        byte[] temp = Arrays.copyOfRange(inData, i * 8, (i * 8) + 8);

                        xorBytes(temp, CV);
                        temp = _Encryptor.doFinal(temp);
                        xorBytes(CV, temp);

                        System.arraycopy(temp, 0, ret, i * 8, 8);
                    }

                    if (left_len != 0) {
                        CV = _Encryptor.doFinal(CV);
                        byte[] temp = Arrays.copyOfRange(inData, blocks_len * 8, (blocks_len * 8) + left_len);
                        xorBytes(temp, CV, left_len);
                        System.arraycopy(temp, 0, ret, blocks_len * 8, temp.length);
                    }

                    return ret;
                } catch (Exception e) {
                    e.printStackTrace();
                    return null;
                }
            }

            public String encryptString(String inputString) {
                try {
                    byte[] inData = inputString.getBytes(StandardCharsets.UTF_8);
                    byte[] outData = Encrypt(inData);
                    return DatatypeConverter.printHexBinary(outData);
                } catch (Exception e) {
                    e.printStackTrace();
                    return "";
                }
            }

            private byte[] Decrypt(byte[] inData) {
                try {
                    byte[] CV = Arrays.copyOf(_IV, _IV.length);
                    byte[] ret = new byte[inData.length];

                    int blocks_len = inData.length / 8;
                    int left_len = inData.length % 8;

                    for (int i = 0; i < blocks_len; i++) {
                        byte[] temp = Arrays.copyOfRange(inData, i * 8, (i * 8) + 8);

                        temp = _Decryptor.doFinal(temp);
                        xorBytes(temp, CV);
                        System.arraycopy(temp, 0, ret, i * 8, 8);
                        for (int j = 0; j < CV.length; j++) {
                            CV[j] = (byte) (CV[j] ^ inData[i * 8 + j]);
                        }
                    }

                    if (left_len != 0) {
                        CV = _Encryptor.doFinal(CV);
                        byte[] temp = Arrays.copyOfRange(inData, blocks_len * 8, (blocks_len * 8) + left_len);

                        xorBytes(temp, CV, left_len);
                        for (int j = 0; j < temp.length; j++) {
                            ret[blocks_len * 8 + j] = temp[j];
                        }
                    }

                    return ret;
                } catch (Exception e) {
                    e.printStackTrace();
                    return null;
                }
            }

            public String decryptString(String hexString) {
                try {
                    byte[] inData = DatatypeConverter.parseHexBinary(hexString);
                    byte[] outData = Decrypt(inData);
                    return new String(outData, StandardCharsets.UTF_8);
                } catch (Exception e) {
                    e.printStackTrace();
                    return "";
                }
            }
        }
        static class Navicat12Cipher {
            private static SecretKeySpec _AesKey;
            private static IvParameterSpec _AesIV;

            static {
                _AesKey = new SecretKeySpec("libcckeylibcckey".getBytes(StandardCharsets.UTF_8), "AES");
                _AesIV = new IvParameterSpec("libcciv libcciv ".getBytes(StandardCharsets.UTF_8));
            }

            public String encryptString(String plaintext) {
                try {
                    Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
                    cipher.init(Cipher.ENCRYPT_MODE, _AesKey, _AesIV);
                    byte[] ret = cipher.doFinal(plaintext.getBytes(StandardCharsets.UTF_8));
                    return DatatypeConverter.printHexBinary(ret);
                } catch (Exception e) {
                    e.printStackTrace();
                    return "";
                }
            }

            public String decryptString(String ciphertext) {
                try {
                    Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
                    cipher.init(Cipher.DECRYPT_MODE, _AesKey, _AesIV);
                    byte[] ret = cipher.doFinal(DatatypeConverter.parseHexBinary(ciphertext));
                    return new String(ret, StandardCharsets.UTF_8);
                } catch (Exception e) {
                    e.printStackTrace();
                    return "";
                }
            }
        }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值