암호화 및 디코딩


ㅋㅋ >
A 값 해독 설정
Laravel의 암호화 도구를 사용하기 전에 먼저

값을 올바르게 설정하지 않으면 Laravel에서 암호화한 모든 값이 안전하지 않게 됩니다.

  • Usage
  • 값 암호화
  • 도우미 함수 encrypt를 사용하여 값을 암호화할 수 있습니다. 모든 암호화된 값은 OpenSSL의 AES-256-CBC를 사용하여 암호화됩니다. 또한 모든 암호화된 값은 메시지 인증 코드(MAC)를 사용하여 서명되어 암호화된 문자열이 변조되었는지 감지합니다.
<?php
   namespace App\Http\Controllers;
   use App\User;use Illuminate\Http\Request;
   use App\Http\Controllers\Controller;class UserController extends Controller{  
     /**
     * 存储用户的保密信息
     *
     * @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();  
        }
     }

직렬화 암호화 없음

암호화 과정에서 암호화된 값 serialize가 직렬화되어 전달되어 암호화된 개체와 배열이 허용됩니다. 따라서 암호화된 값을 수신하는 PHP가 아닌 클라이언트는 데이터를 역직렬화해야 합니다. 직렬화하지 않고 값을 암호화하고 복호화하려면 Crypt Facade의 encryptStringdecryptString 메서드를 사용할 수 있습니다. serialize 序列化后传递,允许加密对象和数组。因此,接收加密值的非 PHP 客户端需要对数据进行 unserialize 反序列化。如果想要在不序列化的情况下加密解密值,你可以使用 Crypt Facade 的 encryptStringdecryptString 方法:

use Illuminate\Support\Facades\Crypt;
$encrypted = Crypt::encryptString('Hello world.');
$decrypted = Crypt::decryptString($encrypted);

解密一个值

你可以使用辅助函数 decrypt 来进行解密。如果该值不能被正确解密,例如 MAC 无效时,会抛出异常 IlluminateContractsEncryptionDecryptException

use Illuminate\Contracts\Encryption\DecryptException;try { 
   $decrypted = decrypt($encryptedValue);
  } 
catch (DecryptException $e) {
    //
}

값 해독도우미 기능 decrypt을 사용하여 해독할 수 있습니다. 예를 들어 MAC가 유효하지 않은 경우와 같이 값을 올바르게 해독할 수 없는 경우 IlluminateContractsEncryptionDecryptException 예외가 발생합니다.
rrreee
이 문서는 🎜LearnKu.com🎜 웹사이트에 처음 게시되었습니다. 🎜🎜