- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我一直在尝试使用相同的 key 和 iv 在 PHP 和 Ruby 中加密字符串,但我总是得到不同的结果。
下面是PHP代码
$data = "This string needs to be encrypted";
$key = "1234567887654321abcdefghabcdefgh";
$iv = "1234567887654321abcdefghabcdefgh";
echo $encrypted_data = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $key, $data, MCRYPT_MODE_CBC, $iv);
下面是 Ruby 代码
data = "This string needs to be encrypted"
key = "1234567887654321abcdefghabcdefgh"
iv = "1234567887654321abcdefghabcdefgh"
aes = OpenSSL::Cipher::Cipher.new("AES-256-CBC")
aes.encrypt
aes.key = key
aes.iv = iv
encrypted_data = aes.update(data) + aes.final
有人可以帮我在 PHP 和 Ruby 中获得相同的加密数据吗?我用 PHP 加密了一些数据,然后用 Ruby 解密但没有取回数据。所以我认为问题在于 PHP 和 Ruby 加密和解密机制的工作方式不同。如果我错了,请纠正我。谢谢
最佳答案
不要对 IV 进行硬编码,这是不安全的。 IV 必须是随机的,但可以是公开的,所以只需使用
mcrypt_create_iv 并将其添加到密文的前面,然后在之前提取它解密
你可能有三个问题
填充。 AES 只采用固定的 128 位 block ,因此您必须将文本填充为该大小的倍数。 PHP 还不错,我相信 SSL 使用 pkcs7 填充。请注意,即使使用不同的填充方案,对于大多数方案来说,密文的开头应该相同,只是结尾可能是垃圾。
字符串编码。 AES 是用位输入定义的,在 c 中通常这是一个字节数组。 Ruby 和 PHP 使用字符串。我愿意打赌你的字符串编码是不同的。
关于PHP (mcrypt_encrypt) Ruby (AES-256-CBC) 加密不同结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10181193/
根据 php 7.0 mcrypt_decrypt 已弃用。 我有以下代码。 $intSize= mcrypt_get_iv_size( MCRYPT_RIJNDAEL_256, MCRYPT_MOD
我正尝试在 CBC 模式下使用 256 位 key 使用 Rijndael 密码对 PHP 中的某些数据进行加密,但由于某种原因,我收到以下错误消息: mcrypt_encrypt() 模块初始化失败
我使用了 MCRYPT_ENCRYPT 和这个方法: class Encrypter { private static $Key = "dublin"; public static f
这是一个加密和解密数据的PHP演示脚本: \n"; $card_nbr_encrypted=encrypt_data($card_nbr); echo "card_nbr_encrypted: $ca
有人知道 mcrypt_generic 和 mcrypt_encrypt 在 PHP 加密方面的区别吗? 最佳答案 mcrypt_encrypt() 结合了几种方法的功能,而 mcrypt_gener
首先,Coldfusion Encrypt: #ciphertext# 然后,PHP mcrypt: $message = "1447841550"; $key = 'Mk9m98IfEblmP
这是一个加密和解密数据的PHP演示脚本: \n"; $card_nbr_encrypted=encrypt_data($card_nbr); echo "card_nbr_encrypted: $ca
我被迫从 PHP 5.6 迁移到 7.0+,除了 mcrypt_encrypt() 之外一切都很好,它已经被弃用,如 php.net 中所述。 这是我的代码 $json = array( 'A
我正在使用以下函数来加密字符串 ($str),并使用 key ($key) 来创建唯一 key 。 示例代码: 该函数返回由特殊字符(包括 '+' )组成的值。我将此值作为唯一 ID 存储在数据库中
我的 Web 应用程序从客户端获取 URL 对象,使用 mcrypt_encrypt 对其进行加密,并将结果作为 LONGTEXT 类型存储在 MySQL 数据库中。整个过程如下所示: /*
我一直在寻找答案,但在这里找不到。如果已经有人问过这个问题,请原谅。 我有一个加密和解密字符串的简单代码,字符串看起来一样,但是当使用 == 比较它们时,它们看起来并不相同,所以哈希值也不同.. 这是
我有一个旧算法来编码我想与 PHP 7 一起使用的密码 public function encriptarPass($cadena) { $extra = (strlen($cadena)%
我几乎失去了头发、思想和其他一切!我一直在尝试将此 PHP 函数转换为 C#: function encrypt_decrypt($action, $string) { $output = fa
我想知道是否有一个 javascript 库可以为 php 中的 mcrypt_encrypt 提供功能。 我正在编写一个函数来使用 javascript 访问我的 api。我总是对我的参数进行加密和
PHP 版本: mcrypt_encrypt(MCRYPT_RIJNDAEL_256, "11111111111111111111111111111111", "1111111111111111111
我需要在 android 中使用 key 对特定文本进行加密。在 PHP 中,加密代码如下所示 $this->securekey = hash('sha256',$textkey,TRUE); $th
function fnEncrypt($key,$string){ return base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $key
我需要加密一些 SOAP header 字段,目前我在 PHP 5.6 版本的项目中使用以下代码。 function getBaseEncoded($data, $key) { $size
我正在将项目中加密数据和使用 mcrypt 的所有功能迁移到 openssl。 进行测试时我发现,使用相同的 key 加密相同的数据会得到不同的结果。 解密时,我使用这两个函数都得到了正确的结果;问题
我正在将项目中加密数据和使用 mcrypt 的所有功能迁移到 openssl。 进行测试时我发现,使用相同的 key 加密相同的数据会得到不同的结果。 解密时,我使用这两个函数都得到了正确的结果;问题
我是一名优秀的程序员,十分优秀!