美文网首页
Login相关的校验和标准

Login相关的校验和标准

作者: 东方三篇 | 来源:发表于2024-07-22 15:05 被阅读0次

    本文旨在介绍 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:因为其短密钥长度而非常容易受到现代暴力攻击的破解,被认为基本不安全。

    相关文章

      网友评论

          本文标题:Login相关的校验和标准

          本文链接:https://www.haomeiwen.com/subject/rsoehjtx.html