加密javascript中的字符串和java中的解密

时间:2012-07-31 09:49:55

标签: java javascript cryptography public-key-encryption

我想知道是否有人知道任何库在javascript中进行加密并在java中进行解密。我已经尝试了很多API,但是不要在java中获得相同的值。
我想要公钥 - 私钥加密,因此尝试使用RSA。 我很少使用的是:

  1. http://www-cs-students.stanford.edu/~tjw/jsbn/
  2. http://ats.oka.nu/titaniumcore/js/crypto/readme.txt
  3. http://www.ohdave.com/rsa/
  4. 我检查的东西很少,javascript将字符串分成小块然后加密它们,这使得密码文本在java和javascript中不同。我编辑javascript代码以使用字符串作为一个整体,但没有工作。

    我也尝试将html页面的charset设置为utf-8,但它也没有用。 我在加密单个字符串方面取得了成功,例如' K'要正确加密和解​​密,这让我觉得在javascript中加密字符串有问题,把它分成小块(我检查过,但是整个加密都失败了)。

    我的java实现是:

    BigInteger d = new BigInteger("1f3fac65c4ae222e3a3074dd4c38fbb72c0705c4bbac0385b867c12c25a44e01", 16);
    BigInteger e = new BigInteger("65537");
    BigInteger N = new BigInteger("b42e91fbca364cf2a125aec67ffbdab624fd401100c40ea05189ba34d1028b0d", 16);
    String messageToEncrypt = "kishor";
    byte [] messageByte = messageToEncrypt.getBytes();
    BigInteger message = new BigInteger(messageByte);
    //Encrypting and Decrypting messages
    //Encrypt a message using N and e:
    BigInteger ciphertext = message.modPow(e, N);
    //Decrypt the message using N and d:
    BigInteger plaintext = ciphertext.modPow(d, N);
    byte[] plainTextByte = plaintext.toByteArray();
    String decryptMessage = new String(plainTextByte);
    /*System.out.println("p : " + p);
    System.out.println("q : " + q);*/
    System.out.println("N : " + N.toString(16));
    System.out.println("e : " + e.toString(16));
    System.out.println("d : " + d.toString(16));
    /*System.out.println("PhiN : " + PhiN);*/
    System.out.println("ciphertext : " + ciphertext.toString(16));
    System.out.println("decryptMessage : " + decryptMessage);
    }
    

    请告诉我是否有可能,因为我搜索了很多问题(在stackoverflow本身),但无法找到解决方案。

3 个答案:

答案 0 :(得分:0)

尝试使用Gibberish AES(JS Lib) https://github.com/mdp/gibberish-aes/

答案 1 :(得分:0)

RSA最适合密钥交换。根据我的经验,那些将其用于其他任何事情的人都不知道他们在做什么,如果他们坚持下去,最终会建立一个毫无价值的加密系统。

我已经成功地在Java和Stanford Javascript Crypto Library.之间进行了互操作。还有许多其他用于对称加密算法的优秀JavaScript库。

答案 2 :(得分:0)

嘿伙计们我找到了解决方案。在javascript中,第一个字符被跳过加密导致问题。修复了循环。感谢您的所有回复。