• 使用Vue、ElementUI实现登录注册,配置axios全局设置,解决CORS跨域问题


    目录

    引言

    什么是ElementUI?

    步骤1:创建Vue组件用于用户登录和注册

     1. 基于SPA项目完成登录注册

    在SPA项目中添加elementui依赖

     在main.js中添加elementui模块

     创建用户登录注册组件

    配置路由

     修改项目端口并启动项目

     静态页面展示图

    步骤2:安装axios和qs库

    在Vue项目中安装和配置axios

    安装相关模块axios

    步骤3:用户登录

    axios之get请求

    axios之post请求

    步骤4:用户注册

    5:CORS跨域问题解决

    什么是CORS(跨源资源共享)问题

    跨域问题处理


    引言

    什么是ElementUI

    element 是基于 vue 实现的一套不依赖业务的 UI 组件库,提供了丰富的PC端组件,减少用户对常用组件的封装,降低了开发的难易程度。Element-Ui是基于vue封装的组件库,简化了常用组件的封装,提高了重用性原则,提高了重用性原则;

    步骤1:创建Vue组件用于用户登录和注册

     1. 基于SPA项目完成登录注册

    在SPA项目中添加elementui依赖

    在SPA项目根路径下使用命令npm install element-ui -S,添加Element-UI模块

     Npm安装命令 :npm install element-ui -S

    下载完成后就可以在package.json下看到导入的Element依赖: 

     

     在main.js中添加elementui模块

    在main.js中引入element-ui模块

    在项目中src目录下找到`main.js`,并在指定位置添加三行代码:

    1. import Vue from 'vue'
    2. // 新添加1
    3. import ElementUI from 'element-ui'
    4. // 新添加2,避免后期打包样式不同,要放在import App from './App';之前
    5. import 'element-ui/lib/theme-chalk/index.css'
    6. import App from './App'
    7. import router from './router'
    8. // 新添加3
    9. Vue.use(ElementUI)
    10. Vue.config.productionTip = false

     创建用户登录注册组件

    Login.vue:

    1. <template>
    2. <div class="login-wrap">
    3. <el-form class="login-container">
    4. <h1 class="title">用户登录</h1>
    5. <el-form-item label="">
    6. <el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off"></el-input>
    7. </el-form-item>
    8. <el-form-item label="">
    9. <el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off"></el-input>
    10. </el-form-item>
    11. <el-form-item>
    12. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
    13. </el-form-item>
    14. <el-row style="text-align: center;margin-top:-10px">
    15. <el-link type="primary">忘记密码</el-link>
    16. <el-link type="primary" @click="gotoRegister()">用户注册</el-link>
    17. </el-row>
    18. </el-form>
    19. </div>
    20. </template>
    21. <script>
    22. export default {
    23. name: 'Login',
    24. data () {
    25. return {
    26. username:'',
    27. password:''
    28. }
    29. },
    30. methods:{
    31. gotoRegister(){
    32. this.$router.push('/Register');
    33. }
    34. }
    35. }
    36. </script>
    37. <style scoped>
    38. .login-wrap {
    39. box-sizing: border-box;
    40. width: 100%;
    41. height: 100%;
    42. padding-top: 10%;
    43. background-image: url();
    44. /* background-color: #112346; */
    45. background-repeat: no-repeat;
    46. background-position: center right;
    47. background-size: 100%;
    48. }
    49. .login-container {
    50. border-radius: 10px;
    51. margin: 0px auto;
    52. width: 350px;
    53. padding: 30px 35px 15px 35px;
    54. background: #fff;
    55. border: 1px solid #eaeaea;
    56. text-align: left;
    57. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    58. }
    59. .title {
    60. margin: 0px auto 40px auto;
    61. text-align: center;
    62. color: #505458;
    63. }
    64. </style>

    Register.vue:

    1. <template>
    2. <div class="login-wrap">
    3. <el-form class="login-container">
    4. <h1 class="title">用户注册</h1>
    5. <el-form-item label="">
    6. <el-input type="text" v-model="realname" placeholder="姓名" autocomplete="off"></el-input>
    7. </el-form-item>
    8. <el-form-item label="">
    9. <el-input type="text" v-model="username" placeholder="注册账号" autocomplete="off"></el-input>
    10. </el-form-item>
    11. <el-form-item label="">
    12. <el-input type="password" v-model="password" placeholder="注册密码" autocomplete="off"></el-input>
    13. </el-form-item>
    14. <el-form-item>
    15. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
    16. </el-form-item>
    17. <el-row style="text-align: center;margin-top:-10px">
    18. <el-link type="primary" @click="gotoLogin()">已有账号,去登录</el-link>
    19. </el-row>
    20. </el-form>
    21. </div>
    22. </template>
    23. <script>
    24. export default {
    25. name: 'Register',
    26. data () {
    27. return {
    28. username:'',
    29. password:'',
    30. realname:''
    31. }
    32. },
    33. methods:{
    34. gotoLogin(){
    35. this.$router.push('/');
    36. }
    37. }
    38. }
    39. </script>
    40. <style scoped>
    41. .login-wrap {
    42. box-sizing: border-box;
    43. width: 100%;
    44. height: 100%;
    45. padding-top: 10%;
    46. background-image: url();
    47. /* background-color: #112346; */
    48. background-repeat: no-repeat;
    49. background-position: center right;
    50. background-size: 100%;
    51. }
    52. .login-container {
    53. border-radius: 10px;
    54. margin: 0px auto;
    55. width: 350px;
    56. padding: 30px 35px 15px 35px;
    57. background: #fff;
    58. border: 1px solid #eaeaea;
    59. text-align: left;
    60. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    61. }
    62. .title {
    63. margin: 0px auto 40px auto;
    64. text-align: center;
    65. color: #505458;
    66. }
    67. </style>
    配置路由

    router/index.js中修改vue项目默认显示路由

    1. import Vue from 'vue'
    2. import Router from 'vue-router'
    3. import HelloWorld from '@/components/HelloWorld'
    4. import Login from '@/views/Login'
    5. import Register from '@/views/Register'
    6. Vue.use(Router)
    7. export default new Router({
    8. routes: [
    9. {
    10. path: '/',
    11. name: 'Login',
    12. component: Login
    13. },
    14. {
    15. path: '/Register',
    16. name: 'Register',
    17. component: Register
    18. }
    19. ]
    20. })
     修改项目端口并启动项目

    config/index.js目录下修改vue项目运行端口,如下,

     静态页面展示图

     效果图:

     点击用户注册效果图:

     

    步骤2:安装axios和qs

    Axios 是一个流行的 JavaScript 库,用于在浏览器和 Node.js 中进行 HTTP 请求。它提供了一个简单而强大的方式来与服务器进行通信,支持各种 HTTP 请求方法,并具有以下特点:

    • Promise 风格的 API:Axios 使用 Promise 来处理异步操作,使得编写和处理请求更加简单和可读。

    • 浏览器和 Node.js 兼容:Axios 可以在浏览器和 Node.js 环境中使用,这使得它非常灵活。

    • 拦截器:你可以使用拦截器在请求和响应被发送或接收之前对它们进行转换或修改,这在处理请求和响应时非常有用。

    • 取消请求:Axios 允许你取消未完成的请求,这对于处理多个并发请求时很有用。

    • 自动转换数据:Axios 可以自动将 JSON 数据转换为 JavaScript 对象,也可以自动将请求数据转换为 JSON。

    • 错误处理:它提供了一种方便的方式来处理请求错误,并可以全局配置错误处理程序。

    • CSRF 保护:Axios 可以帮助你防止跨站请求伪造(CSRF)攻击。

    在Vue项目中安装和配置axios

    安装相关模块axios

    在spa项目根目录下使用cmd命令提示符执行:

    npm i axios -S

    npm i vue-axios -S 

    npm i qs -S

     出现如下图的配置说明下载成功

     

    导入api模块,添加axios的全局配置

         在SPA项目的src目录下添加api模块,其中api模块包含了action.js(针对后台请求接口的封装定义)和http.js(针对axios的全局配置)两个文件。

    action.js

    1. /**
    2.  * 对后台请求的地址的封装,URL格式如下:
    3.  * 模块名_实体名_操作
    4.  */
    5. export default {
    6.     'SERVER': 'http://localhost:8080/ssm_vue', //服务器
    7.     'SYSTEM_USER_DOLOGIN': '/user/userLogin', //登陆
    8.     'SYSTEM_USER_DOREG': '/user/userRegister', //注册
    9.     'getFullPath': k => { //获得请求的完整地址,用于mockjs测试时使用
    10.         return this.SERVER + this[k];
    11.     }
    12. }


    对后台请求的地址的封装,URL格式:模块名实体名操作

    http.js

    1. /**
    2.  * vue项目对axios的全局配置
    3.  */
    4. import axios from 'axios'
    5. import qs from 'qs'
    6.  
    7. //引入action模块,并添加至axios的类属性urls上
    8. import action from '@/api/action'
    9. axios.urls = action
    10.  
    11. // axios默认配置
    12. axios.defaults.timeout = 10000; // 超时时间
    13. // axios.defaults.baseURL = 'http://localhost:8080/j2ee15'; // 默认地址
    14. axios.defaults.baseURL = action.SERVER;
    15.  
    16. //整理数据
    17. // 只适用于 POST,PUT,PATCH,transformRequest` 允许在向服务器发送前,修改请求数据
    18. axios.defaults.transformRequest = function(data) {
    19.   data = qs.stringify(data);
    20.   return data;
    21. };
    22.  
    23.  
    24. // 请求拦截器
    25. axios.interceptors.request.use(function(config) {
    26.   return config;
    27. }, function(error) {
    28.   return Promise.reject(error);
    29. });
    30.  
    31. // 响应拦截器
    32. axios.interceptors.response.use(function(response) {
    33.   return response;
    34. }, function(error) {
    35.   return Promise.reject(error);
    36. });
    37.  
    38. //最后,代码通过export default语句将axios导出,以便在其他地方可以引入和使用这个axios实例。
    39. export default axios;

    修改main.js配置vue-axios

            在main.js文件中引入api模块和vue-axios模块,这样我们可以在Vue项目中方便地使用axios进行HTTP请求,并且可以利用VueAxios插件提供的功能来简化HTTP请求的处理和管理。

    1. import axios from '@/api/http'                 
    2. import VueAxios from 'vue-axios' 
    3. Vue.use(VueAxios,axios)

    步骤3:用户登录

    axios之get请求

    登入组件中进行axios的get请求,编写Login.vue的代码,如下:

    1. <template>
    2. <div class="login-wrap">
    3. <el-form class="login-container">
    4. <h1 class="title">用户登录</h1>
    5. <el-form-item label="">
    6. <el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off"></el-input>
    7. </el-form-item>
    8. <el-form-item label="">
    9. <el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off"></el-input>
    10. </el-form-item>
    11. <el-form-item>
    12. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
    13. </el-form-item>
    14. <el-row style="text-align: center;margin-top:-10px">
    15. <el-link type="primary">忘记密码</el-link>
    16. <el-link type="primary" @click="gotoRegister()">用户注册</el-link>
    17. </el-row>
    18. </el-form>
    19. </div>
    20. </template>
    21. <script>
    22. import axios from 'axios'
    23. import qs from 'qs'
    24. export default {
    25. name: 'Login',
    26. data () {
    27. return {
    28. username: '',
    29. password: ''
    30. }
    31. },
    32. methods:{
    33. gotoRegister(){
    34. this.$router.push('/Register');
    35. },
    36. doSubmit(){
    37. let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
    38. let params = {
    39. username: this.username,
    40. password: this.password
    41. };
    42. axios.get(url, {
    43. params: params
    44. }).then(r => {
    45. console.log(r);
    46. if (r.data.success) {
    47. this.$message({
    48. message: r.data.msg,
    49. type: 'success'
    50. });
    51. } else {
    52. this.$message.error(r.data.msg);
    53. }
    54. }).catch(e => {
    55. });
    56. // axios.post(url,params).then(r => {
    57. // console.log(r);
    58. // if (r.data.success) {
    59. // this.$message({
    60. // message: r.data.msg,
    61. // type: 'success'
    62. // });
    63. // } else {
    64. // this.$message.error(r.data.msg);
    65. // }
    66. // }).catch(e => {
    67. // });
    68. }
    69. }
    70. }
    71. </script>
    72. <style scoped>
    73. .login-wrap {
    74. box-sizing: border-box;
    75. width: 100%;
    76. height: 100%;
    77. padding-top: 10%;
    78. background-image: /*
    79. background-image: url();
    80. */
    81. /* background-color: #112346; */
    82. background-repeat: no-repeat;
    83. background-position: center right;
    84. background-size: 100%;
    85. }
    86. .login-container {
    87. border-radius: 10px;
    88. margin: 0px auto;
    89. width: 350px;
    90. padding: 30px 35px 15px 35px;
    91. background: #fff;
    92. border: 1px solid #eaeaea;
    93. text-align: left;
    94. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    95. }
    96. .title {
    97. margin: 0px auto 40px auto;
    98. text-align: center;
    99. color: #505458;
    100. }
    101. </style>

    然后在后端代码中,需要一个视图解析器来处理我们前端发送的请求,代码如下:

    Usercontroller.java:

    1. package com.zking.ssm.controller;
    2. import com.zking.ssm.service.IUserService;
    3. import com.zking.ssm.util.JsonResponseBody;
    4. import com.zking.ssm.util.PageBean;
    5. import com.zking.ssm.vo.UserVo;
    6. import org.springframework.beans.factory.annotation.Autowired;
    7. import org.springframework.stereotype.Controller;
    8. import org.springframework.web.bind.annotation.RequestMapping;
    9. import org.springframework.web.bind.annotation.ResponseBody;
    10. import javax.servlet.http.HttpServletRequest;
    11. import javax.servlet.http.HttpServletResponse;
    12. import java.util.HashMap;
    13. import java.util.List;
    14. import java.util.Map;
    15. import com.zking.ssm.jwt.*;
    16. @Controller
    17. @RequestMapping("/user")
    18. public class UserController {
    19. @Autowired
    20. private IUserService userService;
    21. @RequestMapping("/userLogin")
    22. @ResponseBody
    23. public JsonResponseBody<?> userLogin(UserVo userVo, HttpServletResponse response){
    24. if(userVo.getUsername().equals("admin")&&userVo.getPassword().equals("123")){
    25. //私有要求claim
    26. // Map<String,Object> json=new HashMap<String,Object>();
    27. // json.put("username", userVo.getUsername());
    28. //生成JWT,并设置到response响应头中
    29. // String jwt=JwtUtils.createJwt(json, JwtUtils.JWT_WEB_TTL);
    30. // response.setHeader(JwtUtils.JWT_HEADER_KEY, jwt);
    31. return new JsonResponseBody<>("用户登陆成功!",true,0,null);
    32. }else{
    33. return new JsonResponseBody<>("用户名或密码错误!",false,0,null);
    34. }
    35. }
    36. @RequestMapping("/queryUserPager")
    37. @ResponseBody
    38. public JsonResponseBody<List<Map<String,Object>>>
    39. queryUserPager(UserVo userVo, HttpServletRequest request){
    40. try {
    41. PageBean pageBean=new PageBean();
    42. pageBean.setRequest(request);
    43. List<Map<String, Object>> users = userService.queryUserPager(userVo, pageBean);
    44. return new JsonResponseBody<>("OK",true,pageBean.getTotal(),users);
    45. } catch (Exception e) {
    46. e.printStackTrace();
    47. return new JsonResponseBody<>("分页查询用户信息失败!",false,0,null);
    48. }
    49. }
    50. }

    axios之post请求

    将用于get请求方法的代码注释,添加Post请求代码,如下:

    Login.vue:

    1. <template>
    2. <div class="login-wrap">
    3. <el-form class="login-container">
    4. <h1 class="title">用户登录</h1>
    5. <el-form-item label="">
    6. <el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off"></el-input>
    7. </el-form-item>
    8. <el-form-item label="">
    9. <el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off"></el-input>
    10. </el-form-item>
    11. <el-form-item>
    12. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
    13. </el-form-item>
    14. <el-row style="text-align: center;margin-top:-10px">
    15. <el-link type="primary">忘记密码</el-link>
    16. <el-link type="primary" @click="gotoRegister()">用户注册</el-link>
    17. </el-row>
    18. </el-form>
    19. </div>
    20. </template>
    21. <script>
    22. import axios from 'axios'
    23. import qs from 'qs'
    24. export default {
    25. name: 'Login',
    26. data () {
    27. return {
    28. username: '',
    29. password: ''
    30. }
    31. },
    32. methods:{
    33. gotoRegister(){
    34. this.$router.push('/Register');
    35. },
    36. doSubmit(){
    37. let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
    38. let params = {
    39. username: this.username,
    40. password: this.password
    41. };
    42. // axios.get(url, {
    43. // params: params
    44. // }).then(r => {
    45. // console.log(r);
    46. // if (r.data.success) {
    47. // this.$message({
    48. // message: r.data.msg,
    49. // type: 'success'
    50. // });
    51. // } else {
    52. // this.$message.error(r.data.msg);
    53. // }
    54. // }).catch(e => {
    55. // });
    56. axios.post(url,params).then(r => {
    57. console.log(r);
    58. if (r.data.success) {
    59. this.$message({
    60. message: r.data.msg,
    61. type: 'success'
    62. });
    63. } else {
    64. this.$message.error(r.data.msg);
    65. }
    66. }).catch(e => {
    67. });
    68. }
    69. }
    70. }
    71. </script>
    72. <style scoped>
    73. .login-wrap {
    74. box-sizing: border-box;
    75. width: 100%;
    76. height: 100%;
    77. padding-top: 10%;
    78. /*
    79. background-image: url();
    80. */
    81. /* background-color: #112346; */
    82. background-repeat: no-repeat;
    83. background-position: center right;
    84. background-size: 100%;
    85. }
    86. .login-container {
    87. border-radius: 10px;
    88. margin: 0px auto;
    89. width: 350px;
    90. padding: 30px 35px 15px 35px;
    91. background: #fff;
    92. border: 1px solid #eaeaea;
    93. text-align: left;
    94. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    95. }
    96. .title {
    97. margin: 0px auto 40px auto;
    98. text-align: center;
    99. color: #505458;
    100. }
    101. </style>

    错误演示:

    正确演示:

    步骤4:用户注册

    前端用户注册页面代码:

    1. <template>
    2. <div class="login-wrap">
    3. <el-form class="login-container">
    4. <h1 class="title">用户注册</h1>
    5. <el-form-item label="">
    6. <el-input type="text" v-model="username" placeholder="注册账号" autocomplete="off"></el-input>
    7. </el-form-item>
    8. <el-form-item label="">
    9. <el-input type="password" v-model="password" placeholder="注册密码" autocomplete="off"></el-input>
    10. </el-form-item>
    11. <el-form-item>
    12. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
    13. </el-form-item>
    14. <el-row style="text-align: center;margin-top:-10px">
    15. <el-link type="primary">忘记密码</el-link>
    16. <el-link type="primary" @click="gotoLogin()">用户登录</el-link>
    17. </el-row>
    18. </el-form>
    19. </div>
    20. </template>
    21. <script>
    22. export default {
    23. name: 'Register',
    24. data () {
    25. return {
    26. username: '',
    27. password: ''
    28. }
    29. },
    30. methods:{
    31. gotoLogin(){
    32. this.$router.push('/');
    33. },
    34. doSubmit(){
    35. let url = this.axios.urls.SYSTEM_USER_DOREG;
    36. let params = {
    37. username: this.username,
    38. password: this.password
    39. };
    40. this.axios.post(url,params).then(r => {
    41. console.log(r);
    42. if (r.data.success) {
    43. this.$message({
    44. message: r.data.msg,
    45. type: 'success'
    46. });
    47. //注册完成后自动进入登入界面
    48. this.$router.push('/');
    49. } else {
    50. this.$message.error(r.data.msg);
    51. }
    52. }).catch(e => {
    53. console.log(e);
    54. });
    55. }
    56. }
    57. }
    58. </script>
    59. <style scoped>
    60. .login-wrap {
    61. box-sizing: border-box;
    62. width: 100%;
    63. height: 100%;
    64. padding-top: 10%;
    65. /*
    66. background-image: url();
    67. */
    68. /* background-color: #112346; */
    69. background-repeat: no-repeat;
    70. background-position: center right;
    71. background-size: 100%;
    72. }
    73. .login-container {
    74. border-radius: 10px;
    75. margin: 0px auto;
    76. width: 350px;
    77. padding: 30px 35px 15px 35px;
    78. background: #fff;
    79. border: 1px solid #eaeaea;
    80. text-align: left;
    81. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    82. }
    83. .title {
    84. margin: 0px auto 40px auto;
    85. text-align: center;
    86. color: #505458;
    87. }
    88. </style>

    后端 IUserService 

     int insertSelective(User record);

    后端Controller层

    1. @RequestMapping("/userRegister")
    2. @ResponseBody
    3. public JsonResponseBody<?> userRegister(UserVo userVo, HttpServletResponse response){
    4. userVo.setId("17");
    5. int i = userService.insertSelective(userVo);
    6. if(i>0){
    7. return new JsonResponseBody<>("用户注册成功!",true,0,null);
    8. }else{
    9. return new JsonResponseBody<>("用户注册失败!",false,0,null);
    10. }
    11. }

    效果图:

     

    5:CORS跨域问题解决

    什么是CORS(跨源资源共享)问题

    CORS(跨源资源共享)问题是指在Web应用程序中,由于同源策略(Same-Origin Policy)的限制,浏览器不允许通过XMLHttpRequest或Fetch等方式从一个域(或源)请求另一个域上的资源。同源策略的目的是为了保护用户的安全和隐私,防止恶意网站通过跨域请求来获取用户敏感信息或执行恶意操作。

    跨源资源共享(CORS)是一种机制,用于解决同源策略带来的限制,允许服务器在HTTP响应头中声明哪些域可以访问其资源。这允许跨域请求在浏览器中执行,前提是服务器明确允许这些请求。

    以下是CORS工作的基本原理:

    发起请求:当一个Web应用程序尝试从一个域(源)发起跨域请求到另一个域时,浏览器首先会发送一个预检请求(OPTIONS请求)来检查服务器是否允许实际请求。

    服务器响应:目标服务器收到预检请求后,会检查请求头中的Origin字段,判断是否允许该域访问资源。如果允许,服务器会在响应头中包含一些特定的CORS头,例如Access-Control-Allow-Origin,来指明允许的域。

    浏览器处理:浏览器检查服务器的响应,如果允许跨域访问,它将继续发送实际的请求。如果服务器未正确配置CORS,浏览器将阻止实际请求的执行,并在JavaScript中报错。

    域A(浏览器所在的域):https://www.example.com

    域B(资源所在的域):https://api.example.com

    浏览器向https://api.example.com发送请求,如果域B的服务器允许域A的访问,那么响应头中会包含类似于以下内容的CORS头:

    Access-Control-Allow-Origin: https://www.example.com

    这样浏览器就知道允许域A的页面访问域B的资源。

    总之,CORS问题是一种涉及跨域请求的安全机制,通过服务器配置和浏览器执行来确保安全的跨域通信。它允许Web应用程序在需要时与其他域进行数据交换,同时维护了基本的安全性。

    跨域问题处理

       需要配置tomcat允许跨域访问,tomcat跨域配置方法很多,但最简单的方式是自己写一个过滤器CorsFilter实现,添加一个响应头Access-Control-Allow-Origin即可

    1. package com.zking.ssm.util;
    2. import java.io.IOException;
    3. import javax.servlet.Filter;
    4. import javax.servlet.FilterChain;
    5. import javax.servlet.FilterConfig;
    6. import javax.servlet.ServletException;
    7. import javax.servlet.ServletRequest;
    8. import javax.servlet.ServletResponse;
    9. import javax.servlet.http.HttpServletResponse;
    10. /**
    11. * 配置tomcat允许跨域访问
    12. *
    13. * @author Administrator
    14. *
    15. */
    16. public class CorsFilter2 implements Filter {
    17. @Override
    18. public void init(FilterConfig filterConfig) throws ServletException {
    19. }
    20. @Override
    21. public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
    22. throws IOException, ServletException {
    23. HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;
    24. // Access-Control-Allow-Origin就是我们需要设置的域名
    25. // Access-Control-Allow-Headers跨域允许包含的头。
    26. // Access-Control-Allow-Methods是允许的请求方式
    27. httpResponse.setHeader("Access-Control-Allow-Origin", "*");// *,任何域名
    28. httpResponse.setHeader("Access-Control-Allow-Headers", "responseType,Origin, X-Requested-With, Content-Type, Accept");
    29. httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");
    30. //允许客户端处理一个新的响应头jwt
    31. //httpResponse.setHeader("Access-Control-Expose-Headers", "jwt,Content-Disposition");
    32. filterChain.doFilter(servletRequest, servletResponse);
    33. }
    34. @Override
    35. public void destroy() {
    36. }
    37. }

     将以上代码配置到web.xml中,对所以请求进行拦截处理,可解决跨域问题。

    1. <!--CrosFilter跨域过滤器-->
    2. <filter>
    3. <filter-name>corsFilter</filter-name>
    4. <filter-class>com.zking.ssm.util.CorsFilter2</filter-class>
    5. </filter>
    6. <filter-mapping>
    7. <filter-name>corsFilter</filter-name>
    8. <url-pattern>/*</url-pattern>
    9. </filter-mapping>

  • 相关阅读:
    正则表达式
    一文学懂Map和Set——详解
    TC8:UDP_INVALID_ADDRESSES_01-02
    docker搭建owncloud
    怎样学好java
    博客园商业化之路-开发任务众包平台:召集早期合作开发者
    Web3:数字化社会的下一步
    【计算机网络】成功解决 ARP项添加失败:请求的操作需要提升
    RV1126 快速启动
    mpvue进阶
  • 原文地址:https://blog.csdn.net/liaozhixiangjava/article/details/133254533