哈希在环回中为同一密码生成不同的哈希?

时间:2019-11-14 06:25:21

标签: typescript hash loopback loopback4

我将回送哈希器用作

import { PasswordHasher } from './hash.password.bcryptjs';

这具有生成哈希的功能

credentials.password = await this.passwordHasher.hashPassword(credentials.password);

我将输入pass@1010用作生成哈希的密码,但是每次生成的哈希都不同。但是同一字符串的哈希应该相同。

课程代码

import { genSalt, hash } from 'bcryptjs';
import { compare } from 'bcryptjs';
import { inject } from '@loopback/core';
import { PasswordHasherBindings } from '../keys';

/**
 * Service HashPassword using module 'bcryptjs'.
 * It takes in a plain password, generates a salt with given
 * round and returns the hashed password as a string
 */
export type HashPassword = (
  password: string,
  rounds: number,
) => Promise<string>;
// bind function to `services.bcryptjs.HashPassword`
export async function hashPassword(
  password: string,
  rounds: number,
): Promise<string> {
  const salt = await genSalt(rounds);
  return await hash(password, salt);
}

export interface PasswordHasher<T = string> {
  hashPassword(password: T): Promise<T>;
  comparePassword(providedPass: T, storedPass: T): Promise<boolean>;
}

export class BcryptHasher implements PasswordHasher<string> {
  constructor(
    @inject(PasswordHasherBindings.ROUNDS)
    private readonly rounds: number,
  ) { }

  async hashPassword(password: string): Promise<string> {
    const salt = await genSalt(10);
    return await hash(password, salt);
  }

  async comparePassword(
    providedPass: string,
    storedPass: string,
  ): Promise<boolean> {
    const passwordIsMatched = await compare(providedPass, storedPass);
    return passwordIsMatched;
  }
}

1 个答案:

答案 0 :(得分:0)

问题是您在每个哈希中使用了新的盐。如果要获得稳定的哈希,则需要生成一次盐,然后在下一轮中重新使用它。