SPA项目开发之登录注册

发布于:2022-12-19 ⋅ 阅读:(1009) ⋅ 点赞:(0)

目录

本次目标:

一、spa项目完成登录注册布局

1. 前置工作

2. 出错解决

3. 测试项目

3.1 下载js依赖

 二、用户登陆界面排版

1.引入main.js配置​​​​​​​

2. 登录注册页跳转

3. 运行结果:

三、 Vue之数据交互登录功能

1、添加点击事件、定义方法

2、编写注册界面

3、定义路由与组件的关系 

4、导入axios的依赖 

5、登录提交方法

6、测试

7、总结

四、this指针污染

 五、CORS跨服

1、cors跨服现象

2、跨服产生的因素

3、解决方法

六、工具类的作用&get与post的区别

1. 原始axios请求的使用

2、get与post的区别


本次目标:

  1. spa项目完成登录注册布局
  2. Spa项目完成登录功能
  3. This 指针带来的变量污染

  4. ajax 跨域问题
  5. axios 的 get/post 的区别( qs )

一、spa项目完成登录注册布局

1. 前置工作

导入与本篇博客相关的spa项目

 选择Maven项目 

 

  找到需要引入的项目,等待引入成功,根据电脑性能不同引入时间也不同,再进行依赖的下载

2. 出错解决

注意如果引入后依赖出错可以尝试重新下载该依赖

解决办法:

1.找到报错依赖的本地仓库中的目录将他删除

2.重新下载

 等待重新下载成功即可 

3. 测试项目

注意查看数据库账号密码是否正确

选中项目右键debug启动,提示整合成功

整合成功后,我们要确保能对的上连接的数据库里的数据:

我们再将关于该项目的工具包导入前端:api

http.js

/**
 * vue项目对axios的全局配置
 */
import axios from 'axios'
import qs from 'qs'

//引入action模块,并添加至axios的类属性urls上
import action from '@/api/action'
axios.urls = action

// axios默认配置
axios.defaults.timeout = 10000; // 超时时间
// axios.defaults.baseURL = 'http://localhost:8080/j2ee15'; // 默认地址
axios.defaults.baseURL = action.SERVER;

//整理数据
// 只适用于 POST,PUT,PATCH,transformRequest` 允许在向服务器发送前,修改请求数据
axios.defaults.transformRequest = function(data) {
	data = qs.stringify(data);
	return data;
};


// 请求拦截器
axios.interceptors.request.use(function(config) {
	// var jwt = window.vm.$store.getters.getJwt;
	// config.headers['jwt'] = jwt;
	return config;
}, function(error) {
	return Promise.reject(error);
});

// 响应拦截器
axios.interceptors.response.use(function(response) {
	// debugger;
	// var jwt = response.headers['jwt'];
	// if(jwt){
	// 	window.vm.$store.commit('setJwt',{jwt:jwt});
	// }
	return response;
}, function(error) {
	return Promise.reject(error);
});

// // 路由请求拦截
// // http request 拦截器
// axios.interceptors.request.use(
// 	config => {
// 		//config.data = JSON.stringify(config.data);  
// 		//config.headers['Content-Type'] = 'application/json;charset=UTF-8';
// 		//config.headers['Token'] = 'abcxyz';
// 		//判断是否存在ticket,如果存在的话,则每个http header都加上ticket
// 		// if (cookie.get("token")) {
// 		// 	//用户每次操作,都将cookie设置成2小时
// 		// 	cookie.set("token", cookie.get("token"), 1 / 12)
// 		// 	cookie.set("name", cookie.get("name"), 1 / 12)
// 		// 	config.headers.token = cookie.get("token");
// 		// 	config.headers.name = cookie.get("name");
// 		// }
// 		return config;
// 	},
// 	error => {
// 		return Promise.reject(error.response);
// 	});

// // 路由响应拦截
// // http response 拦截器
// axios.interceptors.response.use(
// 	response => {
// 		if (response.data.resultCode == "404") {
// 			console.log("response.data.resultCode是404")
// 			// 返回 错误代码-1 清除ticket信息并跳转到登录页面
// 			//      cookie.del("ticket")
// 			//      window.location.href='http://login.com'
// 			return
// 		} else {
// 			return response;
// 		}
// 	},
// 	error => {
// 		return Promise.reject(error.response) // 返回接口返回的错误信息
// 	});



export default axios;

 action.js

/**
 * 对后台请求的地址的封装,URL格式如下:
 * 模块名_实体名_操作
 */
export default {
	'SERVER': 'http://localhost:8080/T216_SSH', //服务器
	'SYSTEM_USER_DOLOGIN': '/vue/userAction_login.action', //用户登陆
	'SYSTEM_USER_DOREG': '/vue/userAction_reg.action', //用户注册
	'SYSTEM_MENU_TREE': '/vue/treeNodeAction.action', //左侧树形菜单加载
	'SYSTEM_ARTICLE_LIST': '/vue/articleAction_list.action', //文章列表
	'SYSTEM_ARTICLE_ADD': '/vue/articleAction_add.action', //文章新增
	'SYSTEM_ARTICLE_EDIT': '/vue/articleAction_edit.action', //文章修改
	'SYSTEM_ARTICLE_DEL': '/vue/articleAction_del.action', //文章删除
	'SYSTEM_USER_GETASYNCDATA': '/vue/userAction_getAsyncData.action', //vuex中的异步加载数据
	'getFullPath': k => { //获得请求的完整地址,用于mockjs测试时使用
		return this.SERVER + this[k];
	}
}

在我们前端工程中的src的api  action.js中可以看到绑定了后端的项目

测试访问一个地址(不需要传参),能否获取到数据库中的数据

 

 

3.1 下载js依赖

一共四条指令:

  • npm install element-ui -S  
  • npm install axios -S

  • npm install qs -S  

  • npm install vue-axios -S

js依赖解释: 

  1.  ​​​​​​​ElementUI:快速布局
  2. ​​​​​​​axios:前端向后台发送请求
  3. qs:解决发送post请求代码冗余的问题
  4. vue-axios:将axios依赖整合进vue中

然后打开我们的HBuilder X找到之前的那个项目,

右键打开它的根目录进入根目录里的cmd

 输入指令:npm install element-ui -S  

 查看package.json中的dependencies的变化:

下载完后: 

 ​​​​​​​

全部下载完后前端的准备工作就完成了!

 二、用户登陆界面排版

1.引入main.js配置​​​​​​​​​​​​​​

import Vue from 'vue'

import ElementUI from 'element-ui' // 新添加 1

import 'element-ui/lib/theme-chalk/index.css' // 新添加 2 ,避免后期打包样式不同,要放在import App from './App'; 之前

import App from './App'

import router from './router'

Vue.use(ElementUI)   // 新添加 3

Vue.config.productionTip = false

提问:css和js哪个先导入? 

  • 当然是css样式,因为js中需要用到css样式,如果先导入js再导入css,那么js里面的样式可能就会失效

 main.js

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
// 新添加 1
import ElementUI from 'element-ui'
// 新添加 2 ,避免后期打包样式不同,要放在import App from './App'; 之前
import 'element-ui/lib/theme-chalk/index.css'
import App from './App'
import router from './router'
Vue.use(ElementUI)   // 新添加 3

Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>'
})

2. 登录注册页跳转

登录注册页面是不可能自己写的啦!咱们去找ELement 官网的样式:官网地址:Element 官网

我们新建一个Login.vue放置我们的登录界面: 

 

 层级结构说明:

 

Login.vue

<template>
  <div class="login-wrap">
    <el-form :model="ruleForm" status-icon :rules="rules" ref="ruleForm" label-width="100px"
      class="demo-ruleForm login-container">
      <el-row>
        <el-col :span="24">
          <div style="text-align: center;" class="grid-content bg-purple">
            <h3>用户登陆</h3>
          </div>
        </el-col>
      </el-row>
      <el-form-item label="用户名" prop="uname">
        <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="密码" prop="pwd">
        <el-input type="password" v-model.number="ruleForm.pwd"></el-input>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div style="text-align: center;" class="grid-content bg-purple">
              <el-button style="width: 100%;" type="primary" @click="submitForm">提交</el-button>
            </div>
          </el-col>
        </el-row>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="12">
            <div style="text-align: center;" class="grid-content bg-purple">
              <el-link type="success" @click="">用户注册</el-link>
            </div>
          </el-col>
          <el-col :span="12">
            <div style="text-align: center;" class="grid-content bg-purple">
              <el-link type="warning" @click="">忘记密码</el-link>
            </div>
          </el-col>
        </el-row>
      </el-form-item>
    </el-form>
  </div>
</template>
 
<script>
  export default {
    name: 'Login',
    data() {
      return {
        ruleForm: {}
      }
    },
    methods: {
      submitForm() {
 
      },
      resetForm() {
 
      }
    }
  }
</script>
 
<style scoped>
  .login-wrap {
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    padding-top: 10%;
    background-image: url();
    /* background-color: #112346; */
    background-repeat: no-repeat;
    background-position: center right;
    background-size: 100%;
  }
 
  .login-container {
    border-radius: 10px;
    margin: 0px auto;
    width: 350px;
    padding: 30px 35px 15px 35px;
    background: #fff;
    border: 1px solid #eaeaea;
    text-align: left;
    box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
  }
 
  .title {
    margin: 0px auto 40px auto;
    text-align: center;
    color: #505458;
  }
</style>

Index.js 

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import Login from '@/views/Login'
 
Vue.use(Router)
 
export default new Router({
  routes: [
    {
      path: '/',
      name: 'Login',
      component: Login
    },
    {
      path: '/Login',
      name: 'Login',
      component: Login
    }
  ]
})

App.Vue

<template>
  <div id="app">
    <!-- 锚点-->
    <router-view/>
  </div>
</template>
 
<script>
export default {
  name: 'App'
}
</script>
 
<style>
html,
body {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    padding: 0px;
    margin: 0px;
}
#app {
    font-family: "Avenir", Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #2c3e50;
    widows: 100%;
    height: 100%;
}
</style>

3. 运行结果:

 这样,我们的登录界面也就完成了!

三、 Vue之数据交互登录功能

1、添加点击事件、定义方法

Login.vue中的用户注册添加点击事件

点击事件

<div style="text-align: center" class="grid-content bg-purple-dark">
              <el-link type="success" @click="toReg">用户注册</el-link>
            </div>

跳转注册方法

toReg(){
      this.$router.push({path:'/Reg'});
    }

 Login.vue

<template>
  <div class="login-wrap">
    <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
      <el-row>
        <el-col :span="24">
          <div style="text-align: center;" class="grid-content bg-purple-dark">
            <h3>用户登录</h3>
          </div>
        </el-col>
      </el-row>
      <el-form-item label="用户" prop="uname">
        <el-input type="text" v-model.number="ruleForm.uname"></el-input>
      </el-form-item>
      <el-form-item label="密码" prop="pwd">
        <el-input type="password" v-model.number="ruleForm.pwd"></el-input>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div style="text-align: center;" class="grid-content bg-purple-dark">
              <el-button style="width: 100%;" type="primary" @click="submitForm">提交</el-button>
            </div>
          </el-col>
        </el-row>
      </el-form-item>
      <el-row>
        <el-col :span="12">
          <div style="text-align: center;" class="grid-content bg-purple-dark">
            <el-link type="success" @click="toReg">用户注册</el-link>
          </div>
        </el-col>
        <el-col :span="12">
          <div style="text-align: center;" class="grid-content bg-purple-dark">
            <el-link type="warning">忘记密码</el-link>
          </div>
        </el-col>
      </el-row>
    </el-form>
  </div>
</template>

<script>
  export default {
    name: 'Login',
    data() {
      return {
        ruleForm: {}
      }
    },
    methods: {
      submitForm() {
        //this.axios 找到的是 /api/http.js 文件
        //axios.urls=axios --->this.axios.urls找到了
        //axios.js是一个JSON对象,那么就可以渠道请求的地址
        let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        // alert(url);
        // {uname:'oy',pwd:'123'}
        this.axios.post(url, this.ruleForm)
        .then(function(resp){// 代表成功
          console.log(resp);
        }).catch(function(){//代表失败

        });
      },
      resetForm() {

      },
      toReg() {
        this.$router.push({
          path: '/Reg'
        });
      }
    }
  }
</script>


<style scoped>
  .login-wrap {
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    padding-top: 10%;
    background-image: url();
    /* background-color: #112346; */
    background-repeat: no-repeat;
    background-position: center right;
    background-size: 100%;
  }

  .login-container {
    border-radius: 10px;
    margin: 0px auto;
    width: 350px;
    padding: 30px 35px 15px 35px;
    background: #fff;
    border: 1px solid #eaeaea;
    text-align: left;
    box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
  }

  .title {
    margin: 0px auto 40px auto;
    text-align: center;
    color: #505458;
  }
</style>

2、编写注册界面

Reg.vue

<template>
  <div class="login-wrap">
    <el-row>
      <el-col :span="24">
        <div style="text-align: center" class="grid-content bg-purple-dark"><h3>用户注册</h3>
      </div></el-col>
    </el-row>
 
    <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
      <el-form-item label="用户名" prop="uname">
        <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item label="密码" prop="pwd">
        <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div style="text-align: center" class="grid-content bg-purple-dark">
              <el-button style="width: 100%" type="primary" @click="submitForm">提交</el-button>
            </div>
          </el-col>
        </el-row>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="12">
            <div style="text-align: center" class="grid-content bg-purple-dark">
              <el-link type="success" @click="toLogin">用户登录</el-link>
            </div>
          </el-col>
          <el-col :span="12">
          <div style="text-align: center" class="grid-content bg-purple-dark">
            <el-link type="warning">忘记密码</el-link>
          </div>
          </el-col>
        </el-row>
      </el-form-item>
 
    </el-form>
  </div>
</template>
 
<script>
export default {
  name: 'Reg',
  data () {
    return {
      ruleForm: {}
    }
  },
  methods:{
    submitForm(){
 
    },
    resetForm(){
 
    },
    toLogin(){
      this.$router.push({path:'/Login'});
    }
  }
}
</script>
 
<style scoped>
.login-wrap {
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  padding-top: 10%;
  background-image: url();
  /* background-color: #112346; */
  background-repeat: no-repeat;
  background-position: center right;
  background-size: 100%;
}
 
.login-container {
  border-radius: 10px;
  margin: 0px auto;
  width: 350px;
  padding: 30px 35px 15px 35px;
  background: #fff;
  border: 1px solid #eaeaea;
  text-align: left;
  box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
}
 
.title {
  margin: 0px auto 40px auto;
  text-align: center;
  color: #505458;
}
</style>

3、定义路由与组件的关系 

index.js

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import Login from '@/views/Login'
import Reg from '@/views/Reg'

Vue.use(Router)

export default new Router({
	routes: [{
			path: '/',
			name: 'Login',
			component: Login
		},
		{
			path: '/Login',
			name: 'Login',
			component: Login
		},
		{
			path: '/Reg',
			name: 'Reg',
			component: Reg
		}
	]
})

4、导入axios的依赖 

axios相当于jQuery中的ajax

作用:使用获取后台数据,做局部刷新

main.js

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import ElementUI from 'element-ui' // 新添加 1
import 'element-ui/lib/theme-chalk/index.css' // 新添加 2 ,避免后期打包样式
import App from './App'
import router from './router'
import axios from '@/api/http'  //#vue项目对axios的全局配置      
import VueAxios from 'vue-axios'
 
Vue.use(ElementUI);   // 新添加 3
Vue.use(VueAxios,axios);
Vue.config.productionTip = false
 
/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>'
})

5、登录提交方法

submitForm(){
      //this.axios找到的是/api.http.js文件
      //axios.urls = action --> this.axios.urls找到了/api/action.js
      //action.js是一个JSON对象,那么就可以取到请求的值
      let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
      // alert(url);
      //{uname:'zs',pwd:'123'}
      this.axios.post(url,this.ruleForm)
      .then(function(resp){//代表成功
        console.log(resp);
      }).catch(function(){//代表失败
 
      });
    }

6、测试

我们先直接提交试试

 填写一个错误的

 登录成功

7、总结

方法语法:

this.axios.post(请求地址,参数)
 
.then(function(resp) {})
 
.catch(function(error) {})

四、this指针污染

我们发现我们把ElementUI中的消息提示语句,写到axios.post提交的方法内是没有效果的,原因就是因为这个post提交方法的内部已经不是vue实例,而是http.js,这就是this的指针污染。

解决方法

Login.Vue

<template>
  <div class="login-wrap">
    <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
      <el-row>
        <el-col :span="24">
          <div style="text-align: center;" class="grid-content bg-purple-dark">
            <h3>用户登录</h3>
          </div>
        </el-col>
      </el-row>
      <el-form-item label="用户" prop="uname">
        <el-input type="text" v-model.number="ruleForm.uname"></el-input>
      </el-form-item>
      <el-form-item label="密码" prop="pwd">
        <el-input type="password" v-model.number="ruleForm.pwd"></el-input>
      </el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div style="text-align: center;" class="grid-content bg-purple-dark">
              <el-button style="width: 100%;" type="primary" @click="submitForm">提交</el-button>
            </div>
          </el-col>
        </el-row>
      </el-form-item>
      <el-row>
        <el-col :span="12">
          <div style="text-align: center;" class="grid-content bg-purple-dark">
            <el-link type="success" @click="toReg">用户注册</el-link>
          </div>
        </el-col>
        <el-col :span="12">
          <div style="text-align: center;" class="grid-content bg-purple-dark">
            <el-link type="warning">忘记密码</el-link>
          </div>
        </el-col>
      </el-row>
    </el-form>
  </div>
</template>
 
<script>
  export default {
    name: 'Login',
    data() {
      return {
        ruleForm: {}
      }
    },
    methods: {
      submitForm() {
        //this.axios 找到的是 /api/http.js 文件
        //axios.urls=axios --->this.axios.urls找到了
        //axios.js是一个JSON对象,那么就可以渠道请求的地址
        let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        // alert(url);
        // {uname:'oy',pwd:'123'}
 
        //this指的是vue实例
        this.axios.post(url, this.ruleForm)
          .then(resp => { // 代表成功 this污染的问题可以通过箭头函数来实现 jdk8的 lambda表达式
            console.log(resp);
            if (resp.data.code == 1) {
              //this指的是http.js
              this.$message({
                message: resp.data.msg,
                type: 'success'
              });
            }else if (resp.data.code == 0) {
              //this指的是http.js
             this.$message.error(resp.data.msg);
            }
 
          }).catch(function() { //代表失败
 
          });
      },
      resetForm() {
 
      },
      toReg() {
        this.$router.push({
          path: '/Reg'
        });
      }
    }
  }
</script>
 
 
<style scoped>
  .login-wrap {
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    padding-top: 10%;
    background-image: url();
    /* background-color: #112346; */
    background-repeat: no-repeat;
    background-position: center right;
    background-size: 100%;
  }
 
  .login-container {
    border-radius: 10px;
    margin: 0px auto;
    width: 350px;
    padding: 30px 35px 15px 35px;
    background: #fff;
    border: 1px solid #eaeaea;
    text-align: left;
    box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
  }
 
  .title {
    margin: 0px auto 40px auto;
    text-align: center;
    color: #505458;
  }
</style>

 五、CORS跨服

1、cors跨服现象

​​​​​​​

2、跨服产生的因素

访问网址的组成:协议+ip+端口号+项目

跨域产生原因:只要请求地址中的元素有任意一处发生改变,就会产生跨域的问题。

3、解决方法

后台项目web.xml中添加一个过滤器

<!-- 解决cors跨域问题过滤器 -->
<filter>
<filter-name>corsFilter</filter-name>
    <filter-class>com.zking.vue.util.CorsFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>corsFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

 配置tomcat允许跨域访问

package com.zking.vue.util;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * 配置tomcat允许跨域访问
 * 
 * @author Administrator
 *
 */
public class CorsFilter implements Filter {

	@Override
	public void init(FilterConfig filterConfig) throws ServletException {
	}

	// @Override
	// public void doFilter(ServletRequest servletRequest, ServletResponse
	// servletResponse, FilterChain filterChain)
	// throws IOException, ServletException {
	// HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;
	//
	// // Access-Control-Allow-Origin就是我们需要设置的域名
	// // Access-Control-Allow-Headers跨域允许包含的头。
	// // Access-Control-Allow-Methods是允许的请求方式
	// httpResponse.addHeader("Access-Control-Allow-Origin", "*");// *,任何域名
	// httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT,
	// DELETE");
	// // httpResponse.setHeader("Access-Control-Allow-Headers", "Origin,
	// // X-Requested-With, Content-Type, Accept");
	//
	// // 允许请求头Token
	// httpResponse.setHeader("Access-Control-Allow-Headers",
	// "Origin,X-Requested-With, Content-Type, Accept, Token");
	// HttpServletRequest req = (HttpServletRequest) servletRequest;
	// System.out.println("Token=" + req.getHeader("Token"));
	// if("OPTIONS".equals(req.getMethod())) {
	// return;
	// }
	//
	//
	// filterChain.doFilter(servletRequest, servletResponse);
	// }

	@Override
	public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
			throws IOException, ServletException {
		HttpServletResponse resp = (HttpServletResponse) servletResponse;
		HttpServletRequest req = (HttpServletRequest) servletRequest;

		// Access-Control-Allow-Origin就是我们需要设置的域名
		// Access-Control-Allow-Headers跨域允许包含的头。
		// Access-Control-Allow-Methods是允许的请求方式
		resp.setHeader("Access-Control-Allow-Origin", "*");// *,任何域名
		resp.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");
		// resp.setHeader("Access-Control-Allow-Headers", "Origin,X-Requested-With,
		// Content-Type, Accept");
		// 允许客户端,发一个新的请求头jwt
		resp.setHeader("Access-Control-Allow-Headers", "Origin,X-Requested-With, Content-Type, Accept, jwt");

		// 允许客户端,处理一个新的响应头jwt
		resp.setHeader("Access-Control-Expose-Headers", "jwt");
		// String sss = resp.getHeader("Access-Control-Expose-Headers");
		// System.out.println("sss=" + sss);

		// 允许请求头Token
		// httpResponse.setHeader("Access-Control-Allow-Headers","Origin,X-Requested-With,
		// Content-Type, Accept, Token");
		// System.out.println("Token=" + req.getHeader("Token"));

		if ("OPTIONS".equals(req.getMethod())) {// axios的ajax会发两次请求,第一次提交方式为:option,直接返回即可
			return;
		}
		filterChain.doFilter(servletRequest, servletResponse);
	}

	@Override
	public void destroy() {

	}
}

六、工具类的作用&get与post的区别

1. 原始axios请求的使用

更换在main.js文件中导入的依赖,注释原本导入的vue项目对axios的全局配置

导入依赖一定要重启项目

而且请求路径也要写死

      let url = "http://localhost:8080/T216_SSH/vue/treeNodeAction";

 测试一下登录

可以看到登录验证传过去是一个对象

然后我们将那个http.js的“qs”​​​​​​​Login.vue

单独使用一下,在这个页面中导入qs依赖

然后咱们再运行一下:

2、get与post的区别

get请求

let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
this.axios.post(url, this.ruleForm).then(function(response) {
console.log(response);
}).catch(function(error) {
console.log(error);
});

post请求

let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
this.axios.get(url, { //注意数据是保存到json对象的params属性
params: this.ruleForm
}).then(function(response) {
console.log(response);
}).catch(function(error) {
console.log(error);
});

今天分享的知识就到这里啦!我们下次再见吧!拜拜!

本文含有隐藏内容,请 开通VIP 后查看

网站公告

今日签到

点亮在社区的每一天
去签到