国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

基于Vue和Element UI實現(xiàn)前后端分離和交互

這篇具有很好參考價值的文章主要介紹了基于Vue和Element UI實現(xiàn)前后端分離和交互。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

目錄

前言

一、Element UI簡介

1.Element UI是什么

2.Element UI的特點

二、項目搭建

1.創(chuàng)建一個SPA項目

2.安裝 Element-UI

3.導(dǎo)入組件

4.創(chuàng)建登陸注冊界面

登錄組件---Login.vue

注冊組件---Register.vue

定義組件與路由的對應(yīng)關(guān)系

效果演示:?

三、前后端數(shù)據(jù)交互

1.安裝axios

2.導(dǎo)入api模塊,添加axios的全局配置

3.修改main.js配置vue-axios

4.數(shù)據(jù)表數(shù)據(jù)

5.編寫后端登錄注冊controller層

6.使用封裝后的axios發(fā)送請求

7.測試

四、CORS跨域

1.什么是CORS?

2.為什么會出現(xiàn)CORS問題?

3.特點

4.如何解決CORS問題?

5.跨域問題處理


前言

????????當今的Web開發(fā)趨勢中,前后端分離已經(jīng)成為一種流行的架構(gòu)模式。它將前端和后端的開發(fā)分離開來,使得前端和后端可以獨立進行開發(fā)和部署。Vue.js作為一種流行的前端框架,結(jié)合Element UI這個優(yōu)秀的UI組件庫,可以幫助我們更好地實現(xiàn)前后端分離和交互。

一、Element UI簡介

1.Element UI是什么

????????Element UI是一套基于Vue.js的開源UI組件庫。它提供了豐富的可復(fù)用的UI組件,包括按鈕、表單、彈窗、菜單等,可以幫助開發(fā)者快速構(gòu)建現(xiàn)代化的Web應(yīng)用程序界面。Element UI具有簡潔美觀的設(shè)計風(fēng)格,易于使用和定制。它還提供了豐富的文檔和示例,方便開發(fā)者學(xué)習(xí)和使用。無論是初學(xué)者還是有經(jīng)驗的開發(fā)者,都可以通過Element UI來提高開發(fā)效率,創(chuàng)建出優(yōu)秀的用戶界面。

2.Element UI的特點

1. 響應(yīng)式布局:Element UI的組件可以根據(jù)不同的屏幕尺寸自動調(diào)整布局,適應(yīng)不同的設(shè)備。

2. 高度可定制:開發(fā)者可以根據(jù)自己的需求對組件進行定制,包括樣式、功能和交互等方面。

3. 豐富的文檔和示例:Element UI提供了詳細的文檔和示例,方便開發(fā)者學(xué)習(xí)和使用。

4. 國際化支持:Element UI支持多種語言,可以輕松實現(xiàn)國際化的Web應(yīng)用程序。

二、項目搭建

1.創(chuàng)建一個SPA項目

可觀看下面這篇博文

??????Vue安裝并使用Vue-CLI構(gòu)建SPA項目并實現(xiàn)路由https://blog.csdn.net/weixin_74268571/article/details/133137962?spm=1001.2014.3001.5502

創(chuàng)建好之后運行項目

在SAP項目的根目錄輸入cmd后在cmd窗口輸入npm run dev
?基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

2.安裝 Element-UI

在安裝前需先關(guān)停我們的項目,在cmd窗口中ctrl+c,ctrl+c就可以了

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

?接下來就可以通過命令去下載Element UI

cd my-spa                                 #進入新建項目的根目錄
npm install element-ui -S                 #安裝 Element UI模塊

需進入該SPA項目根目錄安裝Element UI模塊

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

下載后就可以看到該依賴了?

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

注:

在Vue中,使用命令行工具(如npm或yarn)下載依賴時,可以使用不同的選項來指定依賴的安裝方式:

  • -g:全局安裝。使用該選項下載的依賴將被安裝在全局環(huán)境中,可以在任何項目中使用。通常用于安裝一些全局的工具或命令行工具,比如Vue CLI。

總結(jié)起來,-g用于全局安裝工具或命令行工具,-s用于保存項目運行所必需的依賴,-d用于保存開發(fā)過程中需要的依賴。

3.導(dǎo)入組件

在main.js中導(dǎo)入Element UI對應(yīng)組件并將Element UI掛載在Vue中

// 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'


// 新添加3
Vue.use(ElementUI)
Vue.config.productionTip = false

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

4.創(chuàng)建登陸注冊界面

  • 登錄組件---Login.vue

<template>
	<div class="login-wrap">
		<el-form class="login-container">
			<h1 class="title">用戶登錄</h1>
			<el-form-item label="">
				<el-input type="text" v-model="username" placeholder="登錄賬號" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item label="">
				<el-input type="password" v-model="password" placeholder="登錄密碼" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item>
				<el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
			</el-form-item>
			<el-row style="text-align: center;margin-top:-10px">
				<el-link type="primary">忘記密碼</el-link>
				<el-link type="primary" @click="gotoRegister()">用戶注冊</el-link>
			</el-row>
		</el-form>
	</div>
</template>
<script>
export default {
  name: 'Login',
  data () {
    return {
      username : '',
      password:''
    }
  },
  methods:{
    gotoRegister(){
      //跳轉(zhuǎn)
      this.$router.push('/Register');
    }
  }
}
</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>
  • 注冊組件---Register.vue

<template>
	<div class="login-wrap">
		<el-form class="login-container">
			<h1 class="title">用戶注冊</h1>
			<el-form-item label="">
				<el-input type="text" v-model="username" placeholder="賬號" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item label="">
				<el-input type="password" v-model="password" placeholder="密碼" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item>
				<el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
			</el-form-item>
			<el-row style="text-align: center;margin-top:-10px">
				<el-link type="primary">忘記密碼</el-link>
				<el-link type="primary" @click="gotoLogin()">用戶登錄</el-link>
			</el-row>
		</el-form>
	</div>
</template>
<script>
export default {
  name: 'Register',
  data () {
    return {
      username : '',
      password:''
    }
  },
  methods:{
    gotoLogin(){
      //跳轉(zhuǎn)
      this.$router.push('/');
    }
  }
}
</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>
  • 定義組件與路由的對應(yīng)關(guān)系

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

Vue.use(Router)

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

效果演示:?

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

三、前后端數(shù)據(jù)交互

使用SSM項目構(gòu)建Java后臺,模擬提供一個用戶登錄的action地址,Vue通過請求指定的用戶登錄接口。

1.安裝axios

axios是vue2提倡使用的輕量版的ajax。它是基于promise的HTTP庫。它會從瀏覽器中創(chuàng)建 XMLHttpRequests,與Vue配合使用非常好。

vue.js有著名的全家桶系列:vue-router,vuex, vue-resource,再加上構(gòu)建工具vue-cli,就是一個完整的vue項目的核心構(gòu)成。 其中vue-resource是Vue.js的一款插件,它可以通過XMLHttpRequest或JSONP發(fā)起請求并處理響應(yīng),但在vue更新到2.0之后,作者就宣告不再對vue-resource更新,而是推薦的axios

安裝指令

npm i axios -S

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

"qs"通常指的是"query string",即查詢字符串。查詢字符串是URL中的一部分,用于傳遞參數(shù)給服務(wù)器。在Vue中,我們可以使用"qs"庫來處理和解析查詢字符串和傳參問題

"qs"庫是一個用于序列化和解析URL查詢字符串的JavaScript庫。它提供了一組方法,可以將JavaScript對象轉(zhuǎn)換為查詢字符串,或?qū)⒉樵冏址馕鰹镴avaScript對象。通過使用"qs"庫,我們可以方便地處理URL中的查詢參數(shù),例如在發(fā)送HTTP請求時將參數(shù)序列化為查詢字符串,或在接收到查詢字符串時將其解析為JavaScript對象進行處理。通過使 用"qs"庫,我們可以更方便地處理Vue應(yīng)用程序中的查詢字符串,提高開發(fā)效率。

安裝指令

npm i qs -S

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

Vue Axios是一個基于Promise的HTTP客戶端,用于在Vue.js應(yīng)用程序中發(fā)送HTTP請求。它是基于Axios庫的封裝,提供了一種簡潔、靈活和強大的方式來處理HTTP請求和響應(yīng)。

使用Vue Axios,你可以輕松地發(fā)送GET、POST、PUT、DELETE等不同類型的請求,并處理服務(wù)器返回的數(shù)據(jù)。它還支持攔截器,可以在請求發(fā)送前或響應(yīng)返回后對請求進行攔截和處理。此外,Vue Axios還提供了取消請求、設(shè)置請求頭、處理錯誤等功能,使得與后端API進行交互變得更加方便和可靠。 通過Vue Axios,還可以在Vue.js應(yīng)用程序中輕松地集成和管理HTTP請求,從而更好地處理數(shù)據(jù)交互和與后端API進行通信。

安裝指令

npm i vue-axios -S

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

2.導(dǎo)入api模塊,添加axios的全局配置

將api模塊導(dǎo)入到SPA項目的src目錄下,其中api模塊包含了action.js(針對后臺請求接口的封裝定義)和http.js(針對axios的全局配置)兩個文件。

action.js

/**
 * 對后臺請求的地址的封裝,URL格式如下:
 * 模塊名_實體名_操作
 */
export default {
	'SERVER': 'http://localhost:8080/ssm/', //服務(wù)器url
	'SYSTEM_USER_DOLOGIN': 'user/userLogin', //登陸
	'SYSTEM_USER_DOREG': 'user/userRegister', //注冊
	'getFullPath': k => { //獲得請求的完整地址,用于mockjs測試時使用
		return this.SERVER + this[k];
	}
}

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;

//整理數(shù)據(jù)
// 只適用于 POST,PUT,PATCH,transformRequest` 允許在向服務(wù)器發(fā)送前,修改請求數(shù)據(jù)
axios.defaults.transformRequest = function(data) {
	data = qs.stringify(data);
	return data;
};


// 請求攔截器
axios.interceptors.request.use(function(config) {
	return config;
}, function(error) {
	return Promise.reject(error);
});

// 響應(yīng)攔截器
axios.interceptors.response.use(function(response) {
	return response;
}, function(error) {
	return Promise.reject(error);
});

export default axios;

3.修改main.js配置vue-axios

在main.js文件中引入api模塊和vue-axios模塊

import axios from '@/api/http'                 
import VueAxios from 'vue-axios' 

Vue.use(VueAxios,axios)

4.數(shù)據(jù)表數(shù)據(jù)

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

5.編寫后端登錄注冊controller層

package com.ctb.ssm.controller;

import com.ctb.ssm.service.IUserService;
import com.ctb.ssm.util.JsonResponseBody;
import com.ctb.ssm.util.PageBean;
import com.ctb.ssm.vo.UserVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.List;
import java.util.Map;
import com.ctb.ssm.jwt.*;

@Controller
@RequestMapping("/user")
public class UserController {

    @Autowired
    private IUserService userService;

    /**
     * 登錄
     * @param userVo
     * @param response
     * @return
     */
    @RequestMapping("/userLogin")
    @ResponseBody
    public JsonResponseBody<?> userLogin(UserVo userVo, HttpServletResponse response){
        if(userVo.getUsername().equals("admin")&&userVo.getPassword().equals("123")){
            //私有要求claim
//            Map<String,Object> json=new HashMap<String,Object>();
//            json.put("username", userVo.getUsername());
            //生成JWT,并設(shè)置到response響應(yīng)頭中
//            String jwt=JwtUtils.createJwt(json, JwtUtils.JWT_WEB_TTL);
//            response.setHeader(JwtUtils.JWT_HEADER_KEY, jwt);
            return new JsonResponseBody<>("用戶登陸成功!",true,0,null);
        }else{
            return new JsonResponseBody<>("用戶名或密碼錯誤!",false,0,null);
        }
    }


    /**
     * 注冊
     * @param userVo
     * @param response
     * @return
     */
    @RequestMapping("/userRegister")
    @ResponseBody
    public JsonResponseBody<?> userRegister(UserVo userVo, HttpServletResponse response){
        userVo.setId("9");
        int i = userService.insertSelective(userVo);
        if(i>0){
            return new JsonResponseBody<>("用戶注冊成功!",true,0,null);
        }else{
            return new JsonResponseBody<>("用戶注冊失??!",false,0,null);
        }
    }
}

6.使用封裝后的axios發(fā)送請求

Login.vue登錄提交中發(fā)get請求

<template>
	<div class="login-wrap">
		<el-form class="login-container">
			<h1 class="title">用戶登錄</h1>
			<el-form-item label="">
				<el-input type="text" v-model="username" placeholder="登錄賬號" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item label="">
				<el-input type="password" v-model="password" placeholder="登錄密碼" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item>
				<el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
			</el-form-item>
			<el-row style="text-align: center;margin-top:-10px">
				<el-link type="primary">忘記密碼</el-link>
				<el-link type="primary" @click="gotoRegister()">用戶注冊</el-link>
			</el-row>
		</el-form>
	</div>
</template>

<script>
  import axios from 'axios'
  import qs from 'qs'
export default {
  name: 'Login',
  data () {
    return {
      username: '',
      password: ''
    }
  },
  methods:{
    gotoRegister(){
      this.$router.push('/Register');
    },
    doSubmit(){
      let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
      let params = {
        username: this.username,
        password: this.password
      };
      //get請求
      axios.get(url, {
        params: params
      }).then(r => {
        console.log(r);
        if (r.data.success) {
          this.$message({
            message: r.data.msg,
            type: 'success'
          });
        } else {
          this.$message.error(r.data.msg);
        }
      }).catch(e => {
      });
      //post請求
      // axios.post(url,params).then(r => {
      //   console.log(r);
      //   if (r.data.success) {
      //     this.$message({
      //       message: r.data.msg,
      //       type: 'success'
      //     });
      //   } else {
      //     this.$message.error(r.data.msg);
      //   }
      // }).catch(e => {
      // });
    }
  }
}
</script>


<style scoped>
	.login-wrap {
		box-sizing: border-box;
		width: 100%;
		height: 100%;
		padding-top: 10%;
    background-image: url('../assets/cfpl.png');
		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>

Register.vue注冊提交中發(fā)post請求

<template>
	<div class="login-wrap">
		<el-form class="login-container">
			<h1 class="title">用戶注冊</h1>
			<el-form-item label="">
				<el-input type="text" v-model="username" placeholder="注冊賬號" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item label="">
				<el-input type="password" v-model="password" placeholder="注冊密碼" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item>
				<el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
			</el-form-item>
			<el-row style="text-align: center;margin-top:-10px">
				<el-link type="primary">忘記密碼</el-link>
				<el-link type="primary" @click="gotoLogin()">用戶登錄</el-link>
			</el-row>
		</el-form>
	</div>
</template>

<script>
export default {
  name: 'Register',
  data () {
   return {
     username: '',
     password: ''
   }
  },
  methods:{
    gotoLogin(){
      this.$router.push('/');
    },
    doSubmit(){
      let url = this.axios.urls.SYSTEM_USER_DOREG;
      let params = {
        username: this.username,
        password: this.password
      };

      this.axios.post(url,params).then(r => {
        console.log(r);
        if (r.data.success) {
          this.$message({
            message: r.data.msg,
            type: 'success'
          });
          //注冊完成后自動進入登入界面
          this.$router.push('/');
        } else {
          this.$message.error(r.data.msg);
        }
      }).catch(e => {
          console.log(e);
      });
    }
  }
}
</script>

<style scoped>
	.login-wrap {
		box-sizing: border-box;
		width: 100%;
		height: 100%;
		padding-top: 10%;
    background-image: url('../assets/cfpl.png');
		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>

7.測試

在前后端分離后我們需同時運行前后端項目,那么我們的前后端項目所用端口號為避免發(fā)生沖突,應(yīng)修改為不同的,如后端Tomcat運行端口號為8080,那我們的SPA項目端口號應(yīng)為其它。

我們應(yīng)該如何修改SPA項目的端口號呢?

在config/index.js中進行修改

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

注意:

端口號的范圍是從0到65535。

0到1023的端口號被稱為"知名端口",用于一些常見的網(wǎng)絡(luò)服務(wù);

1024到49151的端口號被稱為"注冊端口",用于一些已經(jīng)注冊的應(yīng)用程序;

49152到65535的端口號被稱為"動態(tài)或私有端口",用于臨時分配給客戶端應(yīng)用程序。

登錄效果演示

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

注冊效果演示?

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

數(shù)據(jù)庫數(shù)據(jù)展示

基于Vue和Element UI實現(xiàn)前后端分離和交互,Vue+Element UI,vue.js,ui,前端,elementui,mybatis,前端框架,交互

四、CORS跨域

1.什么是CORS?

CORS是一種瀏覽器安全機制,用于限制跨域資源的訪問。當瀏覽器發(fā)起跨域請求時,會先向目標服務(wù)器發(fā)送一個預(yù)檢請求(OPTIONS請求),以確定是否允許跨域訪問。如果服務(wù)器返回的響應(yīng)中包含了合適的CORS頭部信息,瀏覽器才會繼續(xù)發(fā)送真正的跨域請求。

2.為什么會出現(xiàn)CORS問題?

  • 前端代碼通過AJAX或Fetch API向不同域的服務(wù)器發(fā)送請求。
  • 前端代碼中使用了不同域的資源,比如字體、圖片、腳本等。

3.特點

  1. 安全性高:CORS 是一種安全的跨域訪問解決方案,通過限制允許跨域訪問的源和方法,可以有效地防止惡意攻擊。

  2. 靈活性強:CORS 支持不同類型的請求,包括 GET、POST、PUT、DELETE 等,同時也支持不同類型的數(shù)據(jù)傳輸格式,比如 JSON、XML 等。

  3. 無需修改客戶端代碼:CORS 是一種服務(wù)器端的解決方案,因此無需修改客戶端代碼即可實現(xiàn)跨域訪問。

  4. 無需額外授權(quán):與 JSONP 不同,CORS 不需要額外授權(quán),只需在服務(wù)器端設(shè)置響應(yīng)頭即可。

4.如何解決CORS問題?

  • 服務(wù)器端設(shè)置CORS頭部信息:在服務(wù)器端的響應(yīng)中添加合適的CORS頭部信息,允許指定的域進行跨域訪問??梢酝ㄟ^設(shè)置Access-Control-Allow-Origin、Access-Control-Allow-Methods、Access-Control-Allow-Headers等頭部字段來控制跨域訪問的權(quán)限。
Access-Control-Allow-Origin: * // 允許所有域名訪問
Access-Control-Allow-Methods: GET, POST, PUT, DELETE // 允許的請求方法
Access-Control-Allow-Headers: Content-Type // 允許的請求頭
  • 使用代理服務(wù)器:通過在同域下設(shè)置一個代理服務(wù)器,將跨域請求轉(zhuǎn)發(fā)到目標服務(wù)器,然后將響應(yīng)返回給前端。這樣前端代碼就可以繞過CORS限制,實現(xiàn)跨域訪問。
  • JSONP:JSONP(JSON with Padding)是一種利用script標簽跨域獲取數(shù)據(jù)的方法。它的原理是利用script標簽可以跨域加載資源的特性,通過動態(tài)創(chuàng)建script標簽,向服務(wù)器請求JSON數(shù)據(jù),從而實現(xiàn)跨域獲取數(shù)據(jù)。需要注意的是,JSONP只支持GET請求。

5.跨域問題處理

????????需要配置tomcat允許跨域訪問,需編寫一個過濾器,添加一個響應(yīng)頭Access-Control-Allow-Origin即可

package com.ctb.ssm.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.HttpServletResponse;

/**
 * 配置tomcat允許跨域訪問
 * 
 * @author Administrator
 *
 */
public class CorsFilter2 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就是我們需要設(shè)置的域名
		// Access-Control-Allow-Headers跨域允許包含的頭。
		// Access-Control-Allow-Methods是允許的請求方式
		httpResponse.setHeader("Access-Control-Allow-Origin", "*");// *,任何域名
		httpResponse.setHeader("Access-Control-Allow-Headers", "responseType,Origin, X-Requested-With, Content-Type, Accept");
		httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");

		//允許客戶端處理一個新的響應(yīng)頭jwt
		//httpResponse.setHeader("Access-Control-Expose-Headers", "jwt,Content-Disposition");
		filterChain.doFilter(servletRequest, servletResponse);
	}

	@Override
	public void destroy() {

	}
}

將Tomcat跨域處理配置到web.xml中,對所有請求進行攔截處理

<!--CrosFilter跨域過濾器-->
  <filter>
    <filter-name>corsFilter</filter-name>
    <filter-class>com.ctb.ssm.util.CorsFilter2</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>corsFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>

它設(shè)置了適當?shù)?CORS 響應(yīng)頭,以允許跨域請求,包括允許的來源域、請求頭和請求方法,有效的控制跨域訪問的權(quán)限,解決跨域問題。文章來源地址http://www.zghlxwxcb.cn/news/detail-719686.html

到了這里,關(guān)于基于Vue和Element UI實現(xiàn)前后端分離和交互的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • Java之Spring Boot+Vue+Element UI前后端分離項目

    Java之Spring Boot+Vue+Element UI前后端分離項目

    typeId : this.typeId, }).then((res) = { this.$router.push(“/”); this.$message.success(“文章發(fā)布成功!”); }).catch(() = { this.$message.error(“文章發(fā)布失??!”); }); }, handleAvatarSuccess(res, file) { this.imageUrl = URL.createObjectURL(file.raw); this.thumbnail = “http://localhost:9090/img/” + res; }, selectType(typename,id) { t

    2024年04月27日
    瀏覽(44)
  • FLASK+VUE--前后端分離(三)- VUE+Element-UI搭建登陸頁面且能夠正常登陸

    FLASK+VUE--前后端分離(三)- VUE+Element-UI搭建登陸頁面且能夠正常登陸

    FLASK+VUE–前后端分離(一)- Flask基礎(chǔ)講解之路由、視圖函數(shù)及代碼實現(xiàn) FLASK+VUE–前后端分離(二)- VUE基礎(chǔ)安裝及項目的簡易介紹 FLASK+VUE–前后端分離(三)- VUE+Element-UI搭建登陸頁面且能夠正常登陸 FLASK+VUE–前后端分離(四)- VUE+Element-UI簡單搭建主頁布局 FLASK+VUE–前后端

    2023年04月15日
    瀏覽(33)
  • 川西旅游網(wǎng)系統(tǒng)-前后端分離(前臺vue 后臺element UI,后端servlet)

    川西旅游網(wǎng)系統(tǒng)-前后端分離(前臺vue 后臺element UI,后端servlet)

    前臺:tour_forword: 川西旅游網(wǎng)前端----前臺 (gitee.com) 后臺:tour_back: 川西旅游網(wǎng)-------后臺 (gitee.com) 后端 :tour: 川西旅游網(wǎng)------后端 (gitee.com)

    2024年02月07日
    瀏覽(25)
  • 基于Java+SpringBoot+Vue.js前后端分離電腦購物商城系統(tǒng)設(shè)計和實現(xiàn) 可行性分析

    ?博主介紹 :黃菊華老師《Vue.js入門與商城開發(fā)實戰(zhàn)》《微信小程序商城開發(fā)》圖書作者,CSDN博客專家,在線教育專家,CSDN鉆石講師;專注大學(xué)生畢業(yè)設(shè)計教育和輔導(dǎo)。 所有項目都配有從入門到精通的基礎(chǔ)知識視頻課程,學(xué)習(xí)后應(yīng)對畢業(yè)設(shè)計答辯。 項目配有對應(yīng)開發(fā)文檔、

    2024年02月20日
    瀏覽(14)
  • 基于Java+SpringBoot+Vue.js前后端分離箱包購物商城系統(tǒng)設(shè)計和實現(xiàn) 可行性分析

    ?博主介紹 :黃菊華老師《Vue.js入門與商城開發(fā)實戰(zhàn)》《微信小程序商城開發(fā)》圖書作者,CSDN博客專家,在線教育專家,CSDN鉆石講師;專注大學(xué)生畢業(yè)設(shè)計教育和輔導(dǎo)。 所有項目都配有從入門到精通的基礎(chǔ)知識視頻課程,學(xué)習(xí)后應(yīng)對畢業(yè)設(shè)計答辯。 項目配有對應(yīng)開發(fā)文檔、

    2024年02月22日
    瀏覽(18)
  • 基于Java+SpringBoot+Vue.js前后端分離鞋子購物商城系統(tǒng)設(shè)計和實現(xiàn) 可行性分析

    ?博主介紹 :黃菊華老師《Vue.js入門與商城開發(fā)實戰(zhàn)》《微信小程序商城開發(fā)》圖書作者,CSDN博客專家,在線教育專家,CSDN鉆石講師;專注大學(xué)生畢業(yè)設(shè)計教育和輔導(dǎo)。 所有項目都配有從入門到精通的基礎(chǔ)知識視頻課程,學(xué)習(xí)后應(yīng)對畢業(yè)設(shè)計答辯。 項目配有對應(yīng)開發(fā)文檔、

    2024年02月20日
    瀏覽(21)
  • 基于Java+SpringBoot+Vue.js前后端分離綠植購物商城系統(tǒng)設(shè)計和實現(xiàn) 可行性分析

    ?博主介紹 :黃菊華老師《Vue.js入門與商城開發(fā)實戰(zhàn)》《微信小程序商城開發(fā)》圖書作者,CSDN博客專家,在線教育專家,CSDN鉆石講師;專注大學(xué)生畢業(yè)設(shè)計教育和輔導(dǎo)。 所有項目都配有從入門到精通的基礎(chǔ)知識視頻課程,學(xué)習(xí)后應(yīng)對畢業(yè)設(shè)計答辯。 項目配有對應(yīng)開發(fā)文檔、

    2024年02月19日
    瀏覽(28)
  • 基于Java+SpringBoot+Vue.js前后端分離寵物購物商城系統(tǒng)設(shè)計和實現(xiàn) 可行性分析

    ?博主介紹 :黃菊華老師《Vue.js入門與商城開發(fā)實戰(zhàn)》《微信小程序商城開發(fā)》圖書作者,CSDN博客專家,在線教育專家,CSDN鉆石講師;專注大學(xué)生畢業(yè)設(shè)計教育和輔導(dǎo)。 所有項目都配有從入門到精通的基礎(chǔ)知識視頻課程,學(xué)習(xí)后應(yīng)對畢業(yè)設(shè)計答辯。 項目配有對應(yīng)開發(fā)文檔、

    2024年02月19日
    瀏覽(20)
  • 基于Java+SpringBoot+Vue.js前后端分離零食購物商城系統(tǒng)設(shè)計和實現(xiàn) 可行性分析

    ?博主介紹 :黃菊華老師《Vue.js入門與商城開發(fā)實戰(zhàn)》《微信小程序商城開發(fā)》圖書作者,CSDN博客專家,在線教育專家,CSDN鉆石講師;專注大學(xué)生畢業(yè)設(shè)計教育和輔導(dǎo)。 所有項目都配有從入門到精通的基礎(chǔ)知識視頻課程,學(xué)習(xí)后應(yīng)對畢業(yè)設(shè)計答辯。 項目配有對應(yīng)開發(fā)文檔、

    2024年02月20日
    瀏覽(23)
  • 【項目案例】前后端分離項目 【W(wǎng)eb圖書管理系統(tǒng) 】SpringBoot + Vue + Element UI + Mysql

    【項目案例】前后端分離項目 【W(wǎng)eb圖書管理系統(tǒng) 】SpringBoot + Vue + Element UI + Mysql

    ?? 博主介紹 : 博主從事應(yīng)用安全和大數(shù)據(jù)領(lǐng)域,有8年研發(fā)經(jīng)驗,5年面試官經(jīng)驗,Java技術(shù)專家,WEB架構(gòu)師,阿里云專家博主,華為云云享專家,51CTO 專家博主 Java知識圖譜點擊鏈接: 體系化學(xué)習(xí)Java(Java面試專題) ???? 感興趣的同學(xué)可以收藏關(guān)注下 , 不然下次找不到喲

    2024年02月07日
    瀏覽(41)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包