前端怎么做一个验证码和JWT,使用mockjs模拟后端

流程图

创建一个发起请求

创建一个方法

复制代码
    getCaptchaImg() {
      this.$axios.get('/captcha').then(res => {
        console.log(res);
        this.loginForm.token = res.data.data.token
        this.captchaImg = res.data.data.captchaImg
        console.log(this.captchaImg)
      })
    },

    captchaImg: "",

创建一个参数

先使页面刷星调用这个方法

复制代码
  created() {
    this.getCaptchaImg();

  },

要导入的图片,我这里加宽和高是因为,我的显示不出来,也不知道什么原因,望大佬指教

复制代码
          <el-input v-model="loginForm.code">
            <el-image slot="append" v-if="captchaImg" :src="captchaImg" style="width: 70px;height: 30px"
                      class="captchaImg"></el-image>
          </el-input>

使用mockjs

在main.js中加入

创建一个mock.js的文件

就可以模拟后端接口

复制代码
const Mock = require('mockjs')

const Random = Mock.Random
返回的结果
let Result = {
    code: 200,
    msg: '操作成功',
    data: null
};
这里和前端对应
Mock.mock('/captcha', 'get', () => {
    Result.data = {
        token: Random.string(32),
        这些方法可以在mockjs的官网上面去查询
        captchaImg: Random.dataImage('100x40', 'p7n5w'),
    }
    return Result;
});
Mock.mock('/login', 'post', () => {
    //无法往header中传入数据
    return Result;
});

结果

有点丑,见谅

现在我们要让所有页面都能有JWT

我们就要在store/index.js中进行一个传值

复制代码
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
设置一个变量token
    token: '',
  },
  getters: {
  },
  mutations: {
设置一个方法,将token存入localStorage
      SET_TOKEN: (state, token) => {
          state.token = token
          localStorage.setItem("token", token)
      },

  },
  actions: {
  },
  modules: {
  }
})

写一个发请求的方法

复制代码
    submitForm(loginForm) {
      this.$refs[loginForm].validate((valid) => {
        if (valid) {
          this.$axios.post('/login', this.loginForm).then(res => {
            const jwt = res.headers['authorization']
            // 把jwt放到请求头中
            this.$store.commit('SET_TOKEN', jwt)
            //页面的跳转
            this.$router.push('/index')

          });
        } else {
          console.log('error submit!!');
          return false;
        }
      });
    },

mockjs中写接口

复制代码
Mock.mock('/login', 'post', () => {
    //无法往header中传入数据
    return Result;
});
相关推荐
海石2 小时前
📱随时随地大小编:TraeSolo 移动端初体验
前端·ai编程·trae
爱滑雪的码农3 小时前
详细说说React大型项目结构以及日常开发核心语法
前端·javascript·react.js
七牛开发者4 小时前
HTML is the new Markdown:来自 Claude Code 团队的实践
前端·人工智能·语言模型·html
@大迁世界4 小时前
43.HTML 事件处理和 React 事件处理有什么区别?
前端·javascript·react.js·html·ecmascript
CloneCello4 小时前
AI时代程序员认知调整指南
前端
ZC跨境爬虫5 小时前
跟着 MDN 学 HTML day_38:(DocumentFragment 文档片段接口详解)
前端·javascript·ui·html·音视频
@大迁世界6 小时前
41.ShadCN 是什么?它如何和 Tailwind CSS 集成,从而更容易构建可访问且可自定义的 React 组件?
前端·javascript·css·react.js·前端框架
千叶风行6 小时前
Text-to-SQL 技术设计与注意事项
前端·人工智能·后端
软件开发技术深度爱好者7 小时前
HTML5+JavaScript读取DOCX 文档完整内容
前端·html5
幽络源小助理7 小时前
苹果CMS V10 MXPro V4.5模版下载, 自适应视频主题源码, 幽络源源码
前端·开源·源码·php源码