当前位置: 首页 > news >正文

宿迁做网站 宿迁网站建设/中国互联网公司排名

宿迁做网站 宿迁网站建设,中国互联网公司排名,wordpress前台上传,北京网站建设公司哪家最好目录 一、登录逻辑简单梳理 1、前言 2、原始登录逻辑 二、登录功能实现 1、修改请求地址 request.js: 2、登录请求实现 说明: 代码实现LoginController: 3、关于跨域问题 为什么会出现跨域问题: 如何解决跨域问题&…

目录

一、登录逻辑简单梳理

1、前言

2、原始登录逻辑

二、登录功能实现

1、修改请求地址

request.js:

2、登录请求实现

说明:

代码实现LoginController:

3、关于跨域问题

为什么会出现跨域问题:

如何解决跨域问题:

4、测试

5、为什么两个login?


一、登录逻辑简单梳理

1、前言

由于自己的年少情况,遇到了很多阻碍,甚至中途泄气,虽然通过自己研究了解到很多知识吧,但项目的进度真实严重滞后了,还好最终找到了通路,总结出的教训:学习最好按照老师教的一步一步来,不要好高骛远、自以为是,要尽量使用老师使用的框架版本,加油!

 

2、原始登录逻辑

原始登录是由这个前端框架自己模拟的,官方提供的流程说明是:

  1. UI 组件交互操作;
  2. 调用统一管理的 api service 请求函数;
  3. 使用封装的 request.js 发送请求;
  4. 获取服务端返回;
  5. 更新 data;

其中第4步,在此项目中是使用mock模拟的数据,所以说,我们要做的是改变请求地址,之前从mock拿数据,现在从我们的后端项目拿数据;

 

二、登录功能实现

1、修改请求地址

vue-element-admin这个框架将请求统一封装在了 request.js 里面,我们只需要修改baseURL即可;

request.js:

import axios from 'axios'
import { MessageBox, Message } from 'element-ui'
import store from '@/store'
import { getToken } from '@/utils/auth'// create an axios instance
const service = axios.create({// baseURL: process.env.VUE_APP_BASE_API, // url = base url + request url// withCredentials: true, // send cookies when cross-domain requests// 我们只需要这个修改baseURL即可修改全局的请求地址baseURL: 'http://localhost:8001',timeout: 5000 // request timeout
})// request interceptor
service.interceptors.request.use(config => {// do something before request is sentif (store.getters.token) {// let each request carry token// ['X-Token'] is a custom headers key// please modify it according to the actual situationconfig.headers['X-Token'] = getToken()}return config},error => {// do something with request errorconsole.log(error) // for debugreturn Promise.reject(error)}
)// response interceptor
service.interceptors.response.use(/*** If you want to get http information such as headers or status* Please return  response => response*//*** Determine the request status by custom code* Here is just an example* You can also judge the status by HTTP Status Code*/response => {const res = response.data// if the custom code is not 20000, it is judged as an error.if (res.code !== 20000) {Message({message: res.message || 'Error',type: 'error',duration: 5 * 1000})// 50008: Illegal token; 50012: Other clients logged in; 50014: Token expired;if (res.code === 50008 || res.code === 50012 || res.code === 50014) {// to re-loginMessageBox.confirm('You have been logged out, you can cancel to stay on this page, or log in again', 'Confirm logout', {confirmButtonText: 'Re-Login',cancelButtonText: 'Cancel',type: 'warning'}).then(() => {store.dispatch('user/resetToken').then(() => {location.reload()})})}return Promise.reject(new Error(res.message || 'Error'))} else {return res}},error => {console.log('err' + error) // for debugMessage({message: error.message,type: 'error',duration: 5 * 1000})return Promise.reject(error)}
)export default service

 

2、登录请求实现

说明:

当我们点击登录按钮的时候会向后台发送两个请求,一个是/edu-admin/user/login,另一个是/edu-admin/user/info,所以我们需要在后台实现这两个接口;

 

代码实现LoginController:

package com.zibo.edu.controller;import com.zibo.common.utils.R;
import org.springframework.web.bind.annotation.*;@CrossOrigin //跨域
@RestController
@RequestMapping("/edu-admin/user")
public class LoginController {@PostMapping("/login")public R login(){return R.ok().data("token","admin");}@GetMapping("/info")public R info(){return R.ok().data("roles","[admin]").data("name","admin").data("avatar","https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif");}@PostMapping("/logout")public R logout(){return R.ok().success(true);}
}

 

3、关于跨域问题

为什么会出现跨域问题:

通过一个地址去访问另一个地址,这个过程中三个地方有任何一个地方不一样就会出现跨域问题,三个地方:访问协议,ip地址,端口号;

 

如何解决跨域问题:

在后台相关controller上面添加@CrossOrigin注解即可;

 

4、测试

请求地址修改成功了,跨域问题也解决了

 

5、为什么两个login?

OPTIONS请求:只是为了测试服务器是否可以连通,不会真正进行请求,更不会返回数据;

 

 

 

 

 

 

 

 

 

 

 

 

http://www.jmfq.cn/news/4926439.html

相关文章:

  • 网络公司发生网站建设费分录/湖南关键词优化快速
  • 织梦m网站伪静态/北京网站建设公司案例
  • 中国住建网查询证书/郑州seo
  • 电商网站开发设计方案/整站seo服务
  • wordpress建站 ftp/品牌词优化
  • 湖北省最新疫情情况/优化网站页面
  • 网站开发过程记录/nba最新消息
  • 如何免费建网站/关键词排名优化顾问
  • 社区网站制作/今天最新新闻摘抄
  • 网站设计酷站/百度关键词怎么做
  • asp.net网站开发上/万网域名注册
  • 同一网站相同form id/seo主要做什么
  • 网站建设gzzhixun/国内可访问的海外网站和应用
  • 郑州做网站推广运营商/网络营销推广方式包括
  • 做网站的公司怎么找客户/友情链接软件
  • 苏州现在能正常出入吗/重庆网站优化软件
  • 四川销售应用app/站长工具 seo查询
  • 深圳做网站的公司排名/火狐搜索引擎
  • 做网站的职位叫什么问题/百度云网页版登录入口
  • b2b行业门户网站/怎样才能在百度上发布信息
  • 我买了一个域名怎么做网站/杭州百度推广代理商
  • 聊城招聘网站建设/济南网站优化公司哪家好
  • 营销自动化案例/网站优化怎么做
  • 如何做招聘网站对比分析/网站seo置顶 乐云践新专家
  • 卓辉科技 网站建设/黑马培训是正规学校吗
  • 建设独立网站的公司/软文自助发布平台系统
  • 本科毕设做网站多少钱/企业seo顾问公司
  • 建设自己的企业网站需要什么资料/福州百度推广开户
  • 昆明做网站的/谷歌seo最好的公司
  • 做html5网站/企业培训员工培训平台