欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php如何使用3des加解密及hmacsha256加密

 更新時間:2022年09月21日 11:45:54   作者:.周周  
因為工作中要用到加密,接口中要求也是用密文傳輸數(shù)據(jù),用到3des加密,就研究了一下,下面這篇文章主要給大家介紹了關(guān)于php如何使用3des加解密及hmacsha256加密的相關(guān)資料,需要的朋友可以參考下

一、3des加解密

從PHP 7.2起它將被從核心代碼中移除并且移到PECL中。PHP手冊在7.1遷移頁面給出了替代方案,就是用OpenSSL取代MCrypt。

現(xiàn)整理PHP7.2中AES加密解密方法mcrypt_module_open()替換方案,以下為原加解密方法:

function encrypt($str) { 
         $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, ''); 
         mcrypt_generic_init($td, $this->key, $this->hexToStr($this->hex_iv)); 
         $block = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);  
        $pad = $block - (strlen($str) % $block);  
        $str .= str_repeat(chr($pad), $pad);  
        $encrypted = mcrypt_generic($td, $str); 
         mcrypt_generic_deinit($td); 
         mcrypt_module_close($td);  
        return base64_encode($encrypted);  
    } 
 
    function decrypt($code) {  
        $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');  
        mcrypt_generic_init($td, $this->key, $this->hexToStr($this->hex_iv));  
        $str = mdecrypt_generic($td, base64_decode($code));  
        $block = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC); 
         mcrypt_generic_deinit($td); 
        mcrypt_module_close($td); 
        return $this->strippadding($str); 
    }

替換后,新方法:

//加密
public function encrypt($data)
{
 
    if ($data== null || empty($data)) {
        return $data;
    }
    $secret_key = "your key";
    $iv = "your iv";
    $result= base64_encode(openssl_encrypt( $data, "aes-256-cbc", $secret_key, OPENSSL_RAW_DATA, $iv));
 
    return $result;
    
}
 
//解密
public function decode($data)
{
    if ($data== null || empty($data)) {
        return $data;
    }
    $secret_key = "your key";
    $iv = "your iv";
    $result= openssl_decrypt(base64_decode($data), "aes-256-cbc", $secret_key, OPENSSL_RAW_DATA, $iv);
 
    return $result;
   
}

加密方法:

openssl_encrypt($data, $method, $password, $options, $iv)

解密方法:

openssl_decrypt($data, $method, $password, $options, $iv)

參數(shù)說明:

$data 加密明文

$method 加密方法

1、DES-ECB
2、DES-CBC
3、DES-CTR
4、DES-OFB
5、DES-CFB

$passwd 加密密鑰[密碼]

$options 數(shù)據(jù)格式選項(可選)【選項有:】

1、0
2、OPENSSL_RAW_DATA=1
3、OPENSSL_ZERO_PADDING=2
4、OPENSSL_NO_PADDING=3

$iv 密初始化向量(可選)

DES 是對稱性加密里面常見一種,是一種使用密鑰加密的塊算法。

二、hmacsha256加密

使用hash_hmac()

string hash_hmac ( string $algo , string $data , string $key [, bool $raw_output = false ] )

參數(shù)

algo

要使用的哈希算法名稱,例如:"md5","sha256","haval160,4" 等。 如何獲取受支持的算法清單,請參見 hash_algos() 。

data

要進行哈希運算的消息。

key

使用 HMAC 生成信息摘要時所使用的密鑰。

raw_output

設(shè)置為 TRUE 輸出原始二進制數(shù)據(jù), 設(shè)置為 FALSE 輸出小寫 16 進制字符串。

返回值

如果 raw_output 設(shè)置為 TRUE , 則返回原始二進制數(shù)據(jù)表示的信息摘要, 否則返回 16 進制小寫字符串格式表示的信息摘要。 如果 algo 參數(shù)指定的不是受支持的算法,返回 FALSE 。

總結(jié)

到此這篇關(guān)于php如何使用3des加解密及hmacsha256加密的文章就介紹到這了,更多相關(guān)php用3des加解密內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論