Heim > Backend-Entwicklung > PHP-Tutorial > [ Laravel 5.2 文档 ] 服务 -- 加密

[ Laravel 5.2 文档 ] 服务 -- 加密

WBOY
Freigeben: 2016-06-23 13:17:13
Original
998 Leute haben es durchsucht

1、配置

在使用Laravel的加密器之前,应该在配置文件 config/app.php中设置 key选项为32位随机字符串。如果这个值没有被设置,所有Laravel加密过的值都是不安全的。

2、基本使用

2.1 加密

你可以使用 Crypt门面对数据进行加密,所有加密值都使用OpenSSL和 AES-256-CBC密码进行加密。此外,所有加密值都通过一个消息认证码(MAC)来检测对加密字符串的任何修改。

例如,我们可以使用 encrypt方法加密 secret属性并将其存储到Eloquent模型:

<?phpnamespace App\Http\Controllers;use Crypt;use App\User;use Illuminate\Http\Request;use App\Http\Controllers\Controller;class UserController extends Controller{    /**     * Store a secret message for the user.     *     * @param  Request  $request     * @param  int  $id     * @return Response     */    public function storeSecret(Request $request, $id)    {        $user = User::findOrFail($id);        $user->fill([            'secret' => Crypt::encrypt($request->secret)        ])->save();    }}
Nach dem Login kopieren

2.2 解密

当然,你可以使用 Crypt门面上的 decrypt方法进行解密。如果该值不能被解密,例如MAC无效,将会抛出一个 Illuminate\Contracts\Encryption\DecryptException异常:

use Illuminate\Contracts\Encryption\DecryptException;try {    $decrypted = Crypt::decrypt($encryptedValue);} catch (DecryptException $e) {    //}
Nach dem Login kopieren
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage