正常情况下,当用户使用我们的这个服务时,需要注册,设置用户名及密码,由于密码属于比较隐私的,所以在大部分情况下,都需要对用户的密码进行加密。

其实,加密也比较简单,为什么单独分出来写一篇,因为下面我们需要讲项目集成JWT,篇幅较长,所以把这个功能单独拎出来。

1 编写加密工具函数

项目规范化,我们在项目src目录下新建utils文件夹,这里面放工具函数,新建cryptogram.ts 文件,内容如下:

import * as crypto from 'crypto';/** * Make salt */export function makeSalt(): string {  return crypto.randomBytes(3).toString('base64');}/** * Encrypt password * @param password 密码 * @param salt 密码验证 */export function encryptPassword(password: string, salt: string): string {  if (!password || !salt) {    return '';  }  const tempSalt = Buffer.from(salt, 'base64');  return (    // 10000 代表迭代次数 16代表长度    crypto.pbkdf2Sync(password, tempSalt, 10000, 16, 'sha1').toString('base64')  );}

文件内容比较简单,两个方法,一个是随机字符串,一个是加密

2 使用

在user.service.ts文件导入

// 引入加密函数import { makeSalt, encryptPassword } from '../utils/cryptogram'; 

使用,用在更新及添加方法中,

// 增加/更新async save(parameter: any): Promise<boolean | string> {  Logger.log(`请求参数:${JSON.stringify(parameter)}`);  // 判断新增/更新  const user = await this.UserRepository.findOne({    where: {      name: parameter.name,    },  });  if (!parameter.id && user != undefined) {    return '用户名重复';  }  const salt = makeSalt();  const hashPwd = encryptPassword(parameter.password, salt);  parameter.password = hashPwd;  parameter.passwdSalt = salt;  try {    let a = await this.UserRepository.save(parameter);    return true;  } catch (error) {    Logger.log(`请求失败:${JSON.stringify(error)}`);    return false;  }}

逻辑很简单,就是不管是添加还是修改,只要是用户传了密码,就把密码加密存进数据库

3 查看效果

©著作权归作者所有:来自51CTO博客作者mb5fd86dae5fbf6的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. win10 安装 MySQL8.0版本
  2. QianBase数据存储和传输加密
  3. 配置文件中的数据库连接串加密了,你以为我就挖不出来吗?
  4. CISSP学习:第7章PKI和密码应用
  5. CISSP学习:第6章密码学和对称密钥算法
  6. 基于Docker部署Ldap环境
  7. CentOS 7 单用户模式修改密码
  8. GitHub等三大平台遭勒索,***给出十天期限:不交赎金即公开用户代码
  9. 一套简单通用的Java后台管理系统,拿来即用,非常方便(附项目地址)

随机推荐

  1. Spring Cloud Bus:消息总线
  2. Spring Cloud Security:Oauth2使用入门
  3. Spring Cloud Sleuth:分布式请求链路跟踪
  4. 上优酷土豆,再也不用看广告啦!
  5. 豆瓣开源的那些神库
  6. Spring Cloud Security:Oauth2结合JWT使用
  7. Spring Cloud Security:Oauth2实现单点登
  8. String还有长度限制?是多少?
  9. 仅需四步,整合SpringSecurity+JWT实现登录
  10. Spring Cloud Alibaba:Nacos 作为注册中心