首页 > 解决方案 > Laravel 5.6 哈希

问题描述

我知道这个问题已经问过了,但我尝试过但没有成功。

我们有一个带有 SHA256 和双盐的旧数据库,我们不想将其用于注册和登录。

我已遵循本教程以及更多内容:https ://conceptsandimplementation.wordpress.com/2017/03/07/replace-laravels-default-password-hash-bcrypt-with-base64-encode/

这是我的代码:

namespace App\Libs\CustomHash;

use Illuminate\Contracts\Hashing\Hasher as HasherContract;

class CustomHasher implements HasherContract {

    public function info($hashedValue) {

    }

    /**
     * Hash the given value.
     *
     * @param  string  $value
     * @return array   $options
     * @return string
     */
    public function make($value, array $options = array()) {
        $PasswordHashed = 'a5df5z' . $value . 'a45ee1a';
        $PasswordHashed = hash('sha256', $value);
        return $PasswordHashed;
    }

    /**
     * Check the given plain value against a hash.
     *
     * @param  string  $value
     * @param  string  $hashedValue
     * @param  array   $options
     * @return bool
     */
    public function check($value, $hashedValue, array $options = array()) {
        return $this->make($value) === $hashedValue;
    }

    /**
     * Check if the given hash has been hashed using the given options.
     *
     * @param  string  $hashedValue
     * @param  array   $options
     * @return bool
     */
    public function needsRehash($hashedValue, array $options = array()) {
        return false;
    }

}

和 :

namespace App\Providers;

use Illuminate\Hashing\HashServiceProvider;
use App\Libs\CustomHash\CustomHasher as CustomHasher;

class CustomHashServiceProvider extends HashServiceProvider
{
    public function register()
    {
        $this->app->singleton('hash', function () {
            return new CustomHasher;
        });
    }
}

这是我的供应商列表

//Illuminate\Hashing\HashServiceProvider::class,
App\Providers\CustomHashServiceProvider::class,

我知道这不是使用 SHA 的好方法,但我别无选择。

提前感谢您的帮助。

标签: laravelhashpasswordssha

解决方案


推荐阅读