zoukankan      html  css  js  c++  java
  • vue+CryptoJS+cookie实现保存账号密码

    安装依赖

    npm i crypto-js --save

    HTML

    <el-input v-model="username" placeholder="用户名"></el-input>
    <el-input v-model="password" placeholder="密码"></el-input>
    <el-checkbox v-model="checked">记住密码</el-checkbox>

    JS

    mounted() {
        this.getCookie();
    },
    //表单提交方法
    submit( ){
        if (that.checked == true) {
            //传入账号,密码,保存天数
            that.setCookie(values.username, values.password, 7);
        } else {
            //清空Cookie
            that.clearCookie();
        }
    }
    //设置cookie方法
                setCookie(username, password, days) {
                    var text = CryptoJS.AES.encrypt(password, 'secret key 123'); //使用CryptoJS方法加密
                    var exdate = new Date(); //获取时间
                    exdate.setTime(exdate.getTime() + 24 * 60 * 60 * 1000 * days); //保存的天数
                    //字符串拼接存入cookie
                    document.cookie = "username" + "==" + username + ";path=/;expires=" + exdate.toGMTString();
                    document.cookie = "password" + "==" + text + ";path=/;expires=" + exdate.toGMTString();
                },
    //读取cookie
                getCookie() {
                    if (document.cookie.length > 0) {
                        var arr = document.cookie.split('; '); //这里显示的格式需要切割一下自己可输出看下
                        for (var i = 0; i < arr.length; i++) {
                            var arr2 = arr[i].split('=='); //再次切割
                            //这里会切割出以username为第0项的数组、以password为第0项的数组,判断查找相对应的值
                            if (arr2[0] == 'adminusername') {
                                this.form.setFieldsValue({
                                    username: arr2[1],
                                });
                            } else if (arr2[0] == 'adminpassword') {
                                //拿到拿到加密后的密码arr2[1]并解密
                                var bytes = CryptoJS.AES.decrypt(arr2[1].toString(), 'secret key 123');
                                var plaintext = bytes.toString(CryptoJS.enc.Utf8); //拿到解密后的密码(登录时输入的密码)
                                this.form.setFieldsValue({
                                    password: plaintext,
                                });
                            }
                        }
                    }
                },
    //清除cookie
                clearCookie() {
                    this.setCookie("", "", -1); //账号密码置空,天数置0
                }
    有问题可直接留言,望各位与我都可以成为技术大牛。
  • 相关阅读:
    英雄会 高校俱乐部 题解(均分01)
    win7下装ubuntu
    UVA10142/PC110108Australian Voting
    解决打不开jar包
    pc110301QWERTYU
    寒假的ACM训练三(PC110107/UVa10196)
    寒假ACM训练(二)
    寒假的ACM训练(一)
    『ORACLE』授予hr用户查看执行计划权限(11g)
    『ORACLE』SPM(下)-baseline实验(11g)
  • 原文地址:https://www.cnblogs.com/xhxdd/p/13999182.html
Copyright © 2011-2022 走看看