Laravel 5.6哈希

时间:2018-09-07 12:24:52

标签: laravel hash passwords sha

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

我们有一个包含SHA256和double salt的旧数据库,我们不想将其用于注册和登录。

我已经阅读了本教程以及更多其他内容: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并不是一个好主意,但我没有选择。

在此先感谢您的帮助。

0 个答案:

没有答案