詳解PHP laravel中的加密與解密函數(shù)
Laravel為我們提供了完整的加密方法及加密模式。
我之前一般在加密的時(shí)候使用的是我自己寫的加密函數(shù),但是這個(gè)玩意,有的位置還是不太使用,當(dāng)然,破解的話,基本上也是不可能的。具體請(qǐng)移步《php加密函數(shù)與解密函數(shù)》
這里具體看下laravel為我們提供的加密及解密方法。
一:簡(jiǎn)介
Laravel 的加密器使用 OpenSSL 來提供 AES-256 和 AES-128 加密。強(qiáng)烈建議使用 Laravel 自帶的加密設(shè)置,不要嘗試推出自己“土生土長(zhǎng)”的加密算法。所有 Laravel 加密過的值都使用消息授權(quán)碼(MAC)進(jìn)行簽名以便底層值一經(jīng)加密就不能修改。
二:配置
在使用 Laravel 的加密器之前,必須在配置文件 config/app.php 中設(shè)置 key 選項(xiàng)為 32 位隨機(jī)字符串??梢允褂?nbsp;php artisan key:generate 命令來生成這個(gè)key,該 Artisan 命令會(huì)使用 PHP 的安全隨機(jī)字節(jié)生成器來構(gòu)建 key 的值。如果這個(gè)值沒有被設(shè)置,所有 Laravel 加密過的值都是不安全的。
三:使用加密/解密
1:加密
你可以使用輔助函數(shù) encrypt 對(duì)數(shù)據(jù)進(jìn)行加密,所有加密值都使用 OpenSSL 和 AES-256-CBC 密碼(cipher)進(jìn)行加密。此外,所有加密值都通過一個(gè)消息認(rèn)證碼(MAC)來進(jìn)行簽名以防止對(duì)加密字符串的任何修改。
<?php namespace AppHttpControllers; use AppUser; use IlluminateHttpRequest; use AppHttpControllersController; class UserController extends Controller { /** * 存儲(chǔ)用戶安全信息. * * @param Request $request * @param int $id * @return Response */ public function storeSecret(Request $request, $id) { $user = User::findOrFail($id); $user->fill([ 'secret' => encrypt($request->secret) ])->save(); } }
2:不使用序列化進(jìn)行加密
加密值在加密期間都會(huì)經(jīng)過序列化函數(shù) serialize 進(jìn)行處理,從而允許對(duì)對(duì)象和數(shù)組的加密。因此,非 PHP 客戶端接收的加密數(shù)據(jù)需要進(jìn)行 unserialize 反序列化。如果你想要在加密和解密數(shù)據(jù)時(shí)不進(jìn)行序列化操作,可以使用 Crypt 門面提供的 encryptString 和 decryptString 方法:
use IlluminateSupportFacadesCrypt; $encrypted = Crypt::encryptString('Hello world.'); $decrypted = Crypt::decryptString($encrypted);
3:解密
你可以使用輔助函數(shù) decrypt 對(duì)加密數(shù)據(jù)進(jìn)行解密。如果該值不能被解密,例如 MAC 無效,將會(huì)拋出一個(gè)IlluminateContractsEncryptionDecryptException異常:
use IlluminateContractsEncryptionDecryptException; try { $decrypted = decrypt($encryptedValue); } catch (DecryptException $e) { // }
以上大概就是laravel為我們提供的加密/解密函數(shù)
到此這篇關(guān)于詳解PHP laravel中的加密與解密函數(shù)的文章就介紹到這了,更多相關(guān)PHP laravel加密 解密內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家
相關(guān)文章
PHP使用memcache緩存技術(shù)提高響應(yīng)速度的方法
這篇文章主要介紹了PHP使用memcache緩存技術(shù)提高響應(yīng)速度的方法,以實(shí)例形式分析了memcache緩存技術(shù)的使用技巧,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12使用GDB調(diào)試PHP代碼,解決PHP代碼死循環(huán)問題
這篇文章主要介紹了使用GDB調(diào)試PHP代碼,解決PHP代碼死循環(huán)問題,需要的朋友可以參考下2015-03-03PHP操作redis實(shí)現(xiàn)的分頁列表,新增,刪除功能封裝類與用法示例
這篇文章主要介紹了PHP操作redis實(shí)現(xiàn)的分頁列表,新增,刪除功能封裝類與用法,結(jié)合實(shí)例形式分析了php針對(duì)redis數(shù)據(jù)庫基本的連接、查詢、添加、分頁等操作封裝與使用技巧,需要的朋友可以參考下2018-08-08php之使用docker運(yùn)行workerman案例講解
這篇文章主要介紹了php之使用docker運(yùn)行workerman案例講解,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08