PHP OpenSSL函數庫之openssl_decrypt()

一、簡介

PHP OpenSSL函數庫提供了多種加密、解密方式,在其中,openssl_decrypt()是一種常用的解密方法。該函數可以使用指定的演算法將密文解密為明文,例如AES(Advanced Encryption Standard)加密演算法。本文將分為以下幾個部分詳細介紹openssl_decrypt()函數,包括使用方法、參數說明以及示例代碼等。

二、openssl_decrypt()函數的使用方法

openssl_decrypt()用於解密通過openssl_encrypt()函數加密生成的密文。該函數的定義如下:

string openssl_decrypt (string $data, string $method, string $key [, int $options = 0 [, string $iv = "" [, string $tag = "" [, string $aad = "" ]]]])

參數說明:

  • $data:要解密的數據。
  • $method:用於加密的演算法,例如:AES-128-CBC、AES-192-CBC、AES-256-CBC、AES-128-CTR等。
  • $key:加密密鑰,規則與加密時的一樣(其長度與演算法有關,例如:AES-128-CBC演算法需要16個位元組的密鑰)。
  • $options:加密選項,暫不支持。
  • $iv:初始向量,需要使用與加密一樣的值才能正確解密。如果未傳入,則默認使用長度為blocksize的0字元串。如果該演算法不需要iv,則可以省略。
  • $tag:在使用AEAD(Authenticated Encryption with Associated Data)加密模式時,解密時需要輸入的tag。如果該演算法不需要tag,則可以省略。
  • $aad:在使用AEAD加密模式時需要傳入的附加數據。如果該演算法不需要aad,則可以省略。

該函數會返回解密出的明文,如果出錯,則返回FALSE。

三、示例代碼

1、使用AES-128-CBC演算法進行解密

以下示例代碼演示了使用AES-128-CBC演算法對加密後的數據進行解密,其中的密鑰、初始向量等參數需要根據實際情況進行設置。decryptData()函數中的$key和$iv可以在實際應用中進行隨機生成,增加安全性。

<?php
function decryptData($encrypted, $key, $iv) {
    $decrypted = openssl_decrypt($encrypted, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
    return $decrypted;
}

$encrypted = base64_decode('tXyzdtrtIh9wbPX9MjPwUQ=='); //加密後的數據
$key = '1234567812345678'; //加密密鑰(16位)
$iv = '1234567812345678'; //初始向量

$decrypted = decryptData($encrypted, $key, $iv);

echo $decrypted;
?>

2、使用AES-256-CBC演算法進行解密

以下示例代碼演示了使用AES-256-CBC演算法對加密後的數據進行解密,其中的密鑰、初始向量等參數需要根據實際情況進行設置。decryptData()函數中的$key和$iv可以在實際應用中進行隨機生成,增加安全性。

<?php
function decryptData($encrypted, $key, $iv) {
    $decrypted = openssl_decrypt($encrypted, 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv);
    return $decrypted;
}

$encrypted = base64_decode('lzok0YNfRH8OGntnXmG+Sg=='); //加密後的數據
$key = '12345678123456781234567812345678'; //加密密鑰(32位)
$iv = '1234567812345678'; //初始向量

$decrypted = decryptData($encrypted, $key, $iv);

echo $decrypted;
?>

3、使用AES-128-CTR演算法進行解密

以下示例代碼演示了使用AES-128-CTR演算法對加密後的數據進行解密,其中的密鑰、初始向量等參數需要根據實際情況進行設置。decryptData()函數中的$key和$iv可以在實際應用中進行隨機生成,增加安全性。

<?php
function decryptData($encrypted, $key, $iv) {
    $decrypted = openssl_decrypt($encrypted, 'AES-128-CTR', $key, OPENSSL_RAW_DATA, $iv);
    return $decrypted;
}

$encrypted = base64_decode('xE1TTxgf8iEqOg=='); //加密後的數據
$key = '1234567812345678'; //加密密鑰(16位)
$iv = '1234567812345678'; //初始向量

$decrypted = decryptData($encrypted, $key, $iv);

echo $decrypted;
?>

四、結語

以上就是本篇文章介紹的全部內容,我們從多個方面詳細介紹了openssl_decrypt()函數的使用。在使用該函數時,請根據實際需要選擇合適的加密演算法、密鑰和初始向量,並嚴格控制密鑰和初始向量的保密性。希望該文章對讀者在使用openssl_decrypt()函數時有所幫助。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/198400.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-04 10:25
下一篇 2024-12-04 10:25

相關推薦

  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • PHP怎麼接幣

    想要在自己的網站或應用中接受比特幣等加密貨幣的支付,就需要對該加密貨幣擁有一定的了解,並使用對應的API進行開發。本文將從多個方面詳細闡述如何使用PHP接受加密貨幣的支付。 一、環…

    編程 2025-04-29
  • 使用PHP foreach遍歷有相同屬性的值

    本篇文章將介紹如何使用PHP foreach遍歷具有相同屬性的值,並給出相應的代碼示例。 一、基礎概念 在講解如何使用PHP foreach遍歷有相同屬性的值之前,我們需要先了解幾…

    編程 2025-04-28
  • PHP獲取301跳轉後的地址

    本文將為大家介紹如何使用PHP獲取301跳轉後的地址。301重定向是什麼呢?當我們訪問一個網頁A,但是它已經被遷移到了另一個地址B,此時若伺服器端做了301重定向,那麼你的瀏覽器在…

    編程 2025-04-27
  • PHP登錄頁面代碼實現

    本文將從多個方面詳細闡述如何使用PHP編寫一個簡單的登錄頁面。 1. PHP登錄頁面基本架構 在PHP登錄頁面中,需要包含HTML表單,用戶在表單中輸入賬號密碼等信息,提交表單後服…

    編程 2025-04-27
  • PHP與Python的比較

    本文將會對PHP與Python進行比較和對比分析,包括語法特性、優缺點等方面。幫助讀者更好地理解和使用這兩種語言。 一、語法特性 PHP語法特性: <?php // 簡單的P…

    編程 2025-04-27
  • PHP版本管理工具phpenv詳解

    在PHP項目開發過程中,我們可能需要用到不同版本的PHP環境來試驗不同的功能或避免不同版本的兼容性問題。或者我們需要在同一台伺服器上同時運行多個不同版本的PHP語言。但是每次手動安…

    編程 2025-04-24
  • PHP數組去重詳解

    一、array_unique函數 array_unique是php中常用的數組去重函數,它基於值來判斷元素是否重複,具體使用方法如下: $array = array(‘a’, ‘b…

    編程 2025-04-24
  • PHP導出Excel文件

    一、PHP導出Excel文件列寬調整 當我們使用PHP導出Excel文件時,有時需要調整單元格的列寬。可以使用PHPExcel類庫中的setWidth方法來設置單元格的列寬。下面是…

    編程 2025-04-24
  • php擴展庫初探

    一、什麼是php擴展庫? PHP擴展庫(PHP extension)是一些用C語言編寫的動態鏈接庫,用於擴展PHP的功能。PHP擴展庫使得PHP可以與各種資料庫系統相連、SMTP、…

    編程 2025-04-23

發表回復

登錄後才能評論