Login相关的校验和标准

本文旨在介绍 login 相关的功能的实现和标准,以及输入信息的校验标准。

1. 标准描述

  1. 账号
  • 必填
  • 两端不能输入空格
  1. 密码
  • 必填
  • 不能输入空格
  • 长度在 8 - 30 之间
  • 必须使用 字母+数字+特殊符号 的要求。
  • 尽量不要使用 password 字样来做密码属性, 会被某些安全扫描视为漏洞,比如 奇安信 的某些 版本。
  • 密码输入框在没有具体要求的情况下要使用 show-password , 以便查看密码信息。
  • 注: 修改密码时候也要遵循该规则。
  1. 验证码
  • 在没有具体要求不使用的情况下都要使用验证码
  • 四位数字(很多项目都在使用)
  1. 加密
  • 使用RSA1024来加密(很多项目都是这么加密的)
  • 账号密码都要加密
  1. 登录成功后 token 的有效期,

2. 代码实现

  • 必填操作参考 ElementPlus 的 具体实现。

  • 以密码为例做个必填演示。

    const reg = /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[$@$!%*#?&.~、,:;+–=_^:;。,?!¥~·_—`\\|/-])[A-Za-z\d$@$!%*?&#.~、,:;+–=_^:;。,?!¥~·_—`\\|/-]{8,30}/
    
    const rules = reactive<FormRules<typeof ruleForm>>({
      pwd: [
          /**
         * 使用 validator 和 pattern 两种方式都可以
         */
        // { validator: validatePass, trigger: 'blur' }
        { required: true, message: 'please input your pwd!', trigger: 'blur' },
        {
          pattern: reg,
          message: '请输入正确的密码,长度在8-30之间,必须包含大小写字母数据和特殊符号!',
          trigger: 'blur'
        }
      ],
    })
    
    const validatePass = (rule: any, value: any, callback: any) => {
      if (value === '') {
        callback(new Error('Please input the password'))
      } else {
        const res = reg.test(value)
        if (res) {
          callback()
        } else {
          callback(new Error('请输入正确的密码,长度在8-30之间,必须包含大小写字母数据和特殊符号!'))
        }
      }
    }
                                     
    
  • 账号密码加密

    • 安装加密工具

      yarn add jsencrypt -D # 默认就是Rsa1024的加密方式, 本文继续使用这个
      
      yarn add crypto-js # 跟多的加密方式参考
      
  • 与后端沟通加密方式和等级,建议使用 Rsa1024

  • Rsa1024 的使用方法。

    // 在utils目录下创建 Rsa/index.ts 文件。
    
    import JSEncrypt from 'jsencrypt'
    
    // 因为后端提供的是pck#8的密钥对,所以这里使用 KEYUTIL.getKey来解析密钥
    let key = ''
    if (process.env.VUE_APP_API_SERVER === 'prod') {
      key = 'MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDYV9ccEjwx/1UWINY80DoQQRvwUoyM0oa6n8P/XPc7TafshKtAEugJRTlEbCmi0T+issBnFhggWFHFUx898XHVSvuzavO94zq767ivHH0qPyG70PW9C51mWgKE9k9FeSblMfRJscUg6UOLST4yXAhdBIw1+KdPx/ryRH4WfsRjWwIDAQAB'
    } else {
      key = 'MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDYV9ccEjwx/1UWINY80DoQQRvwUoyM0oa6n8P/XPc7TafshKtAEugJRTlEbCmi0T+issBnFhggWFHFUx898XHVSvuzavO94zq767ivHH0qPyG70PW9C51mWgKE9k9FeSblMfRJscUg6UOLST4yXAhdBIw1+KdPx/ryRH4WfsRjWwIDAQAB'
    }
    
    export default (str) => {
      let encrypt = new JSEncrypt()
      encrypt.setPublicKey(key)
      let encrypted = encrypt.encrypt(str)
      return encrypted
    }
    
    
  • 调用加密方法

    // 调用账号密码加密
    import Rsa from '../utils/Rsa/index.ts'
    
    const submit = () => {
        const params = {
            userName: Rsa(rlueForm.userName),
            pwd: Rsa(ruleForm.pwd),
            verify: ruleForm.verify
        }
      // 。。。
    }
    
    
  • 验证码

    • 采用常用的4位数字的验证码格式。

    • 展示效果参考
      verify code.png
    • 具体实现

      • 通过ajax请求去后端获取验证码
      • 获取到的验证是 Base64 格式的图片
      • 把图片渲染成上面的效果即可。

3. 加密强度排名

排序通常需要基于算法在当前已知攻击方法时密钥的长度和大小,适当的参数选择(如密钥长度)和实现安全性也对安全强度有重大影响。

  1. MRD码和同态加密:最新的、基于比较复杂数学问题的加密技术,未知有效攻击手段,认为安全性很高。
  2. AES-256:目前最为推荐的对称加密标准,长密钥提供高级别的安全性。
  3. ECC:基于椭圆曲线,相对于RSA,提供同等安全级别下更短的密钥,视作安全。
  4. RSA:使用足够长的密钥(2048位或以上)时被认为是安全的,但由于潜在的量子计算威胁,安全地位可能在未来受到挑战。
  5. SHA-3:最新的安全散列算法,设计的目的是替代SHA-2,为未来的安全威胁做好准备。
  6. SHA-256:SHA-2系列中广泛被使用的安全散列算法,被视作安全。
  7. 3DES:比DES安全,但由于其使用了DES算法,因此对暴力攻击的抵御力较AES弱。
  8. SHA-1:由于安全弱点,不再推荐用于安全敏感的环境。
  9. MD5:已经被证明对碰撞攻击非常脆弱,被认为是不安全的。
  10. DES:因为其短密钥长度而非常容易受到现代暴力攻击的破解,被认为基本不安全。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容