vite?vue3下配置history模式路由的步驟記錄
dev 模式
利用vite 配置代理,可以解決前端瀏覽器限制跨域問(wèn)題(當(dāng)然后端要自己配置好)
export default defineConfig({ // 配置在打包時(shí),保障所有css\js能被找到 base: './', //自帶配置 plugins: [vue()], resolve: { alias: { '@': fileURLToPath(new URL('./src', import.meta.url)) } }, // 配置/api代理 server: { proxy: { '/api': { target: 'http://localhost:8080', changeOrigin: true, rewrite: (path) => path.replace(/^\/api/, '') } } }, //打包前先清空原有打包文件 build: { emptyOutDir: true, } })
配置.env
在dev 環(huán)境,默認(rèn)會(huì)讀取這個(gè)里面的內(nèi)容
# .env.development VITE_BASE_API=/api VITE_BASE_URL=/vaccinationInfo VITE_BASE_ENV=dev
配置axios
import axios from "axios"; const service = axios.create({ baseURL: import.meta.env.VITE_BASE_API as string, timeout: 3600 })
這樣在dev環(huán)境下,就可以使用代理來(lái)訪問(wèn)后端了
pro模式
打包時(shí),會(huì)自動(dòng)識(shí)別 .env.production
# .env.production VITE_BASE_API=http://localhost:8080 VITE_BASE_URL=/vaccinationInfo VITE_BASE_ENV=pro
由于生產(chǎn)模式時(shí),代理配置時(shí)不生效的,所以VITE_BASE_API直接指向服務(wù)器地址
history模式 時(shí) 還要進(jìn)行以下配置
router\index.ts
history: createWebHistory(import.meta.env.VITE_BASE_URL as string),
用一個(gè)指定的url地址
nginx 配置
當(dāng)然,打包后放到nginx也需要配置
location /vaccinationInfo { alias /usr/share/nginx/html/vaccinationInfo; index index.html index.htm; try_files $uri $uri/ /vaccinationInfo/index.html; # 解決頁(yè)面刷新404 }
然后在html中新建vaccinationInfo文件夾,把打包好的文件丟進(jìn)去就行
后端配置
寫(xiě)一個(gè)配置類(lèi)
@Configuration public class WebMvcConfig implements WebMvcConfigurer { /** * 允許跨域,以及自行配置 * * @param registry 跨域注冊(cè)器 */ @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") .allowedOriginPatterns("*") // SpringBoot2.4.0以上[allowedOriginPatterns]代替[allowedOrigins] .allowedMethods("*") .maxAge(3600) .allowedHeaders("*") .allowCredentials(true); } }
如果需要配置攔截器攔截JWT,可以采取以下操作
@Configuration public class WebMvcConfig implements WebMvcConfigurer { private JWTTokenInterceptor jwtTokenInterceptor; private InterceptorPathBean interceptorPathBean; @Autowired public void setJwtTokenInterceptor(JWTTokenInterceptor jwtTokenInterceptor) { this.jwtTokenInterceptor = jwtTokenInterceptor; } @Autowired public void setInterceptorPathBean(InterceptorPathBean interceptorPathBean) { this.interceptorPathBean = interceptorPathBean; } /** * 允許跨域,以及自行配置 * * @param registry 跨域注冊(cè)器 */ @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") .allowedOriginPatterns("*") // SpringBoot2.4.0以上[allowedOriginPatterns]代替[allowedOrigins] .allowedMethods("*") .maxAge(3600) .allowedHeaders("*") .allowCredentials(true); } /** * 添加API攔截器,對(duì)所有數(shù)據(jù)API進(jìn)行攔截 * * @param registry 攔截器注冊(cè)器 */ @Override public void addInterceptors(InterceptorRegistry registry) { // 注冊(cè)攔截規(guī)則 InterceptorRegistration interceptorRegistration = registry.addInterceptor(jwtTokenInterceptor); // 攔截配置 interceptorRegistration.addPathPatterns(interceptorPathBean.getInclude()); } }
重寫(xiě)addInterceptors 方法
配置JWT攔截器
@Component public class JWTTokenInterceptor implements HandlerInterceptor { @Resource private JWTResult jwtResult; /** * 攔截對(duì)數(shù)據(jù)API的請(qǐng)求,判斷jwt令牌是否有效,沒(méi)有則返回401 * * @param request 請(qǐng)求 * @param response 響應(yīng) * @param handler 處理器 * @return 是否繼續(xù)執(zhí)行,true繼續(xù)執(zhí)行,false不繼續(xù)執(zhí)行 * @throws Exception 異常 */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { //非簡(jiǎn)單請(qǐng)求會(huì)預(yù)先使用OPTIONS方法請(qǐng)求一次,這里直接返回true if (request.getMethod().equals("OPTIONS")) { response.setStatus(200); //在攔截器中設(shè)置允許跨域 response.setHeader("Access-Control-Allow-Origin", "*"); response.setHeader("Access-Control-Allow-Headers", "*"); response.setHeader("Access-Control-Allow-Methods", "*"); response.setHeader("Access-Control-Allow-Credentials", "true"); response.setHeader("Access-Control-Max-Age", "3600"); return true; } //業(yè)務(wù)邏輯,自行發(fā)揮 //這才是真正的請(qǐng)求,需要驗(yàn)證jwt令牌 //請(qǐng)求數(shù)據(jù)API時(shí)的目標(biāo)url String path = request.getRequestURI(); String jwt = request.getHeader("Authorization"); //對(duì)每次數(shù)據(jù)API請(qǐng)求進(jìn)行攔截,如果jwt令牌不合法,則返回401;通過(guò)則繼續(xù)放行,因此數(shù)據(jù)controller不需要再次判斷jwt令牌是否合法 boolean verify = jwtResult.verify(jwt,path); //如果校驗(yàn)不通過(guò) if (!verify) { response.setContentType("application/json;charset=utf-8"); response.getWriter().write("{\"code\":401,\"msg\":\"jwt校驗(yàn)失敗\"}"); } return verify; } }
以上是重點(diǎn)處理 OPTIONS 預(yù)先請(qǐng)求,這個(gè)在非簡(jiǎn)單請(qǐng)求時(shí)會(huì)預(yù)先發(fā)出,典型場(chǎng)景就是打包后的前端工程,在請(qǐng)求后端是就會(huì)發(fā)出這個(gè)OPTIONS請(qǐng)求。
后面那些就是業(yè)務(wù)邏輯,自行發(fā)揮即可
補(bǔ)充幾個(gè)文件
InterceptorPathBean
@Data @Component @ConfigurationProperties(prefix = "interceptor-config.path") // 配置文件的前綴 public class InterceptorPathBean { /* * 需要攔截的路徑 */ private List<String> include; }
application.yml
# 攔截器路徑攔截 interceptor-config: path: #該路徑下任何類(lèi)型請(qǐng)求均攔截 include: - /telInfo/** - /vaccinationInfo/**
以上,就可以在vue中站著用history模式了
總結(jié)
到此這篇關(guān)于vite vue3下配置history模式路由的文章就介紹到這了,更多相關(guān)vite vue3配置history模式路由內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue3配置permission.js和router、pinia實(shí)現(xiàn)路由攔截的簡(jiǎn)單步驟
- Vue3中關(guān)于路由規(guī)則的props配置方式
- vue3 vite pinia配置動(dòng)態(tài)路由、解決刷新頁(yè)面路由消失的問(wèn)題
- vue3配置router路由并實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)功能
- vue3路由配置以及路由跳轉(zhuǎn)傳參詳解
- Vue3路由配置createRouter、createWebHistory、useRouter和useRoute詳解
- vue3容器布局和導(dǎo)航路由實(shí)現(xiàn)示例
- Vue3?路由配置與導(dǎo)航實(shí)戰(zhàn)教程
相關(guān)文章
解決vue動(dòng)態(tài)路由異步加載import組件,加載不到module的問(wèn)題
這篇文章主要介紹了解決vue動(dòng)態(tài)路由異步加載import組件,加載不到module的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07Vue3?使用Element?Plus表格單選帶checkbox功能
這篇文章主要介紹了Vue3?使用Element?Plus表格單選帶checkbox,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11VeeValidate在vue項(xiàng)目里表單校驗(yàn)應(yīng)用案例
這篇文章主要介紹了VeeValidate在vue項(xiàng)目里表單校驗(yàn)應(yīng)用案例,VeeValidate是Vue.js的驗(yàn)證庫(kù),它有很多驗(yàn)證規(guī)則,并支持自定義規(guī)則,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2018-05-05vue實(shí)現(xiàn)form表單與table表格的數(shù)據(jù)關(guān)聯(lián)功能示例
這篇文章主要介紹了vue實(shí)現(xiàn)form表單與table表格的數(shù)據(jù)關(guān)聯(lián)功能,涉及vue.js表單事件響應(yīng)及頁(yè)面元素屬性動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-01-01Vs-code/WebStorm中構(gòu)建Vue項(xiàng)目的實(shí)現(xiàn)步驟
本文主要介紹了在Vs-code/WebStorm中構(gòu)建Vue項(xiàng)目,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08vue element 表頭添加斜線的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue element 表頭添加斜線的實(shí)現(xiàn)代碼,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-11-11vue與vue-i18n結(jié)合實(shí)現(xiàn)后臺(tái)數(shù)據(jù)的多語(yǔ)言切換方法
下面小編就為大家分享一篇vue與vue-i18n結(jié)合實(shí)現(xiàn)后臺(tái)數(shù)據(jù)的多語(yǔ)言切換方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03Vuex模塊化實(shí)現(xiàn)待辦事項(xiàng)的狀態(tài)管理
本文主要介紹了Vuex模塊化實(shí)現(xiàn)待辦事項(xiàng)的狀態(tài)管理的相關(guān)知識(shí),具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-03-03