gpt4 book ai didi

java - Android RSA加密和Python解密

转载 作者:行者123 更新时间:2023-12-01 04:23:58 28 4
gpt4 key购买 nike

我正在尝试制作一个 Android 应用程序,它将用户登录到基于 Django 的服务器。我试图通过加密用户名和密码来提高安全性,但由于某种原因,它无法在服务器端正确解密。

我怀疑这与 Java 加密和 PyCrypto 加密略有不同并导致兼容性问题有关,但我太新手,无法真正知道出了什么问题。

这是应用程序上的加密代码(遵循 this 教程):

public String encrypt_rsa(String original) throws IOException, NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException, InvalidKeyException, IllegalBlockSizeException, BadPaddingException
{
Resources res = getResources();
InputStream is = res.openRawResource(R.raw.public_key);
byte[] encodedKey = new byte[is.available()];
is.read(encodedKey);
X509EncodedKeySpec publicKeySpec = new X509EncodedKeySpec(encodedKey);
KeyFactory kf = KeyFactory.getInstance("RSA");
PublicKey pkPublic = kf.generatePublic(publicKeySpec);

Cipher pkCipher = Cipher.getInstance("RSA/ECB/PKCS1PADDING");
pkCipher.init(Cipher.ENCRYPT_MODE, pkPublic);
byte[] encryptedInByte = pkCipher.doFinal(original.getBytes());
String encryptedInString = new String(Base64Coder.encode(encryptedInByte));
is.close();

return encryptedInString;
}

这是我的 Python 代码

from Cryto.PublicKey import RSA

def decrypt(encoded_text):

f = open("/path_to_file/private_key.pem", 'r')
priv_key = RSA.importKey(f)

encrypted_text = base64.b64decode(encoded_text)

plain_text = priv_key.decrypt(encrypted_text)

return plain_text

任何帮助将不胜感激!

最佳答案

Java 代码使用 PKCS#1 v1.5 RSA 加密,这是一种严重损坏且不安全的协议(protocol)。

话虽如此,解密是在 Python 中使用适当的模块完成的:

from Crypto.Cipher import PKCS1_v1_5

priv_key = RSA.importKey(f)
cipher = PKCS1_v1_5.new(priv_key)
plain_text = cipher.decrypt(encrypted_text)

更多信息请参见the module documentation .

关于java - Android RSA加密和Python解密,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18657184/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com