繁体   English   中英

如何在Java中解密来自PHP的加密响应?

[英]How to decrypt in Java an encrypted response from PHP?

目标:我打算用PHP加密JSON响应,并且一旦android应用接收到该响应,它将对其解密。

我能够在PHP中找到Encryption和Decryption函数:

<?php
   function simple_encrypt($text)
    {
    $salt = "anything";
        return trim(base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $salt, $text, MCRYPT_MODE_ECB, mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB), MCRYPT_RAND))));
    }

    function simple_decrypt($text)
    {
        $salt = "anything";
        return trim(mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $salt, base64_decode($text), MCRYPT_MODE_ECB, mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB), MCRYPT_RAND)));
    }
?>

(我实际上并不需要simple_decrypt函数,我只是对其进行测试。实际上,我需要的只是服务器端的加密和客户端的解密(我的android应用))

因此,我需要一个类似于simple_decrypt的函数,但是它是用Java编写的,因此我可以解密响应。

我不知道该怎么做,因为我是加密/解密的新手。 我希望这里的一些专家可以指导我找到合适的解决方案。

这是我发现的一些PHP / Java代码 -这是对您的PHP代码的改进,因为它使用了密码反馈模式(CFB),它比ECB(电子密码本)更安全。 要在Java中使用256位AES,您需要安装Java密码术扩展(位于此页面底部)。 请注意,PHP和Java代码都将需要使用相同的初始化向量-这对于每个密文都应该是唯一的,但是可以以明文形式传输。

如果您使用的是SSL,则没有必要-仅当数据从PHP到数据库/文件/其他持久性存储,再到Java时,才需要这样做。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM