首頁 後端開發 PHP問題 php aes cbc解密亂碼怎麼解決

php aes cbc解密亂碼怎麼解決

Apr 11, 2023 am 10:30 AM

在PHP中,使用AES CBC模式加密和解密是很常見的。然而,在使用AES CBC模式解密時,可能會遇到亂碼的問題。這個問題很常見,但是卻很容易解決。在本篇文章中,我將會介紹如何透過PHP來正常解密AES CBC加密資料並避免亂碼問題。

一、問題描述

在PHP中,我們可以使用openssl_encrypt和openssl_decrypt函數來分別進行加密和解密運算。例如,下面的程式碼使用AES CBC模式對資料進行加密:

$key = '1234567890123456';
$data = 'hello world';
$iv = '1234567890123456';

$encrypted = openssl_encrypt($data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
登入後複製

其中,$key為金鑰,$data為要加密的數據,$iv為初始向量。加密之後,$encrypted變數將會得到加密後的資料。現在,我們需要對其進行解密:

$key = '1234567890123456';
$encrypted = 'soLPpFUpwJdVEaYpuu6zRg==';
$iv = '1234567890123456';

$decrypted = openssl_decrypt($encrypted, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
echo $decrypted;
登入後複製

然而,運行上面的程式碼後,你可能會得到以下輸出:

纭洏鍥?J    鍗虫槑涓?
登入後複製

這是一段亂碼,而不是原始資料"hello world "。這是由於解密函數對輸入參數的長度有嚴格限制,因此如果對其進行解密的資料長度不正確,便會出現亂碼的問題。

二、解決方案

為了解決這個問題,我們需要了解AES CBC模式的一些基礎知識。

在AES CBC模式中,加密和解密都需要一個初始向量(Initialization Vector,IV)。這個初始向量需要在加密和解密時使用相同的值,否則會導致解密時資料錯誤。

初始向量的長度必須等於加密演算法所要求的區塊大小。例如,當使用128位元的AES CBC模式時,初始向量的長度必須為16位元組(128位元 / 8位元)。如果不符合這個要求,解密時就會出現亂碼或其他問題。

因此,我們需要檢查輸入參數的長度是否符合要求。當長度不合法時,需要進行填充(Padding)操作。填充可以在解密前進行,以確保輸入資料的長度與加密時使用的長度相同。

針對以上的問題和解決方案,我們可以修改原來的程式碼,以適應AES CBC模式的要求,如下所示:

$key = '1234567890123456';
$encrypted = 'soLPpFUpwJdVEaYpuu6zRg==';
$iv = '1234567890123456';

// 检查初始向量长度是否正确
if (strlen($iv) != 16) {
    echo 'Error: IV length is not valid!';
    exit;
}

// 检查输入参数长度是否正确
$decrypted = openssl_decrypt($encrypted, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
if ($decrypted === false) {
    // 进行填充操作
    $padded_data = $encrypted . str_repeat(chr(16), 16 - (strlen($encrypted) % 16));
    $decrypted = openssl_decrypt($padded_data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
}

echo $decrypted;
登入後複製

以上程式碼中,首先檢查初始向量長度是否正確。如果不正確,則輸出錯誤並退出程式。接著,對解密前的輸入資料長度進行檢查。如果長度不正確,則進行填充操作,以確保資料長度符合要求。

這樣,在解密時就可以避免亂碼問題了。

三、總結

使用AES CBC模式進行加密和解密時,如果輸入參數的長度不正確,可能會導致解密失敗並出現亂碼。為了避免這個問題,我們需要檢查輸入參數的長度,並進行必要的填充操作。

以上就是我對PHP AES CBC模式解密亂碼問題的解。希望對你有幫助。

以上是php aes cbc解密亂碼怎麼解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1665
14
CakePHP 教程
1423
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24