2016-09-18 7 views
4

現在、Laravel 5.2から5.3に更新しようとしています。しかし、アップグレードガイドhttps://laravel.com/docs/5.3/upgrade#upgrade-5.3.0に記載されているように、暗号化をMCryptからOpenSSLに変換する際に問題があります。この目的のために、私は上記の文書で提案されているようにコマンドを書いた。しかし、エラーがあります:Laravel 5.2から5.3への暗号鍵の移行

[2016-09-18 11:07:46] local.ERROR: exception 'Illuminate\Contracts\Encryption\DecryptException' with message 'The payload is invalid.' in /home/vagrant/Code/bob/vendor/laravel/legacy-encrypter/src/BaseEncrypter.php:44 

コマンド:

<?php 
namespace App\Console\Commands; 

use App\User; 
use Illuminate\Console\Command; 
use Laravel\LegacyEncrypter\McryptEncrypter; 

class McryptToOpenSSL extends Command 
{ 
/** 
* The name and signature of the console command. 
* 
* @var string 
*/ 
protected $signature = 'key:migrate'; 

/** 
* The console command description. 
* 
* @var string 
*/ 
protected $description = 'Migrates key from deprecated Mcrypt to OpenSSL.'; 

/** 
* Create a new command instance. 
* 
* @return void 
*/ 
public function __construct() 
{ 
    parent::__construct(); 
} 

/** 
* Execute the console command. 
* 
* @return mixed 
*/ 
public function handle() 
{ 
    $legacy = new McryptEncrypter(env('APP_KEY_LEGACY')); 
    $users = User::all(); 
    foreach ($users as $user) { 
     $user->password = encrypt(
      $legacy->decrypt($user->password) 
     ); 

     $user->save(); 
    } 
} 
} 

.env(キーは少しセキュリティ上の理由から変更されている)

APP_ENV=local 
APP_DEBUG=true 
APP_KEY=base64:3VU8u79ZU0dObazwvd2lHHOAVRJjy5kvzXKeKtcHVYk= 
APP_KEY_LEGACY=zejqrdy7WjA58xGoSuj634RYXB97vLyp 

答えて

0

は、手動でユーザーのパスワードの暗号化をオーバーライドしていますか? デフォルトでは、何も変更しない場合は、そのパスワードの移行を行う必要はありません。 パスワードがencrypt()を使用して暗号化していない場合は、password_hash()、 を使用しています。そのため、ペイロードが有効ではありません。

関連する問題