關(guān)于SpringBoot中Ajax跨域以及Cookie無(wú)法獲取丟失問(wèn)題
在寫自己項(xiàng)目的登錄注冊(cè)頁(yè)面時(shí), 因?yàn)槲业淖?cè)和更改密碼功能采用了郵箱驗(yàn)證, 在發(fā)送驗(yàn)證碼的時(shí)候后端會(huì)向響應(yīng)數(shù)據(jù)中添加一個(gè)cookie
Cookie cookie = new Cookie(toEmail.split("@")[0],verCode);
cookie.setMaxAge(30*60);
response.addCookie(cookie);然后在點(diǎn)擊注冊(cè)或更改密碼時(shí), 后端會(huì)從請(qǐng)求中獲取Cookie獲得郵箱與驗(yàn)證碼信息
Cookie[] cookies = request.getCookies();
在本地進(jìn)行測(cè)試時(shí), Cookie能正確添加進(jìn)響應(yīng)中, 也能正確獲取


但是在把項(xiàng)目打包上云, 再進(jìn)行ajax訪問(wèn)時(shí)就出現(xiàn)了問(wèn)題, Cookie獲取失敗了!
再響應(yīng)標(biāo)頭中分明有set-Cookie, 但是再第二次的請(qǐng)求標(biāo)頭中卻找不到Cookie
服務(wù)端獲取cookie失敗報(bào)錯(cuò), 注冊(cè)和更改密碼需要使用Cookie的功能失效, 在查找文檔后發(fā)現(xiàn)錯(cuò)誤來(lái)源于springboot和ajax的跨域cookie丟失問(wèn)題, 由于我是剛接觸后端的小白,
這里只貼出我的解決方案
1. ajax請(qǐng)求中 需要攜帶上 xmlhttp.withCredentials = true;
var xmlhttp = new XMLHttpRequest();
xmlhttp.withCredentials = true;
xmlhttp.open("GET", readyUrl, true);
xmlhttp.send();
2. 添加 corsConfig 配置類(這一步可能是化蛇填足,歡迎找茬)
package com.crisp.myblog.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class corsConfig implements WebMvcConfigurer {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**")
//是否發(fā)送Cookie
.allowCredentials(true)
//放行哪些原始域
.allowedOriginPatterns("這里填你前端代碼所在的域名:端口")
.allowedMethods(new String[]{"GET", "POST", "PUT", "DELETE"})
.allowedHeaders("*")
.exposedHeaders("*");
}
}3. 給Controller中的api中的response設(shè)置響應(yīng)頭, 鍵為"Access-Control-Allow-Origin" 訪問(wèn)控制允許來(lái)源,http請(qǐng)求頭信息,設(shè)定允許資源共享(跨域)的源
response.setHeader("Access-Control-Allow-Origin",request.getHeader("Origin"));值為 request.getHeader("Origin"), 表示當(dāng)前請(qǐng)求資源所在頁(yè)面的協(xié)議和域名
組合在一起表示 允許當(dāng)前請(qǐng)求資源跨域訪問(wèn)后端資源
這三部均設(shè)置好后我就能夠重新獲取到cookie了
2022-12-09 更新內(nèi)容:
發(fā)現(xiàn)了更加簡(jiǎn)潔方便的方法, 添加跨域請(qǐng)求過(guò)濾器
用到了德魯伊數(shù)據(jù)池依賴包的StringUtils.isEmpty 方法, 報(bào)錯(cuò)了的話自己寫一個(gè)替換就行
import com.alibaba.druid.util.StringUtils;
import org.springframework.stereotype.Component;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@Component
public class crispFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
Filter.super.init(filterConfig);
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
HttpServletRequest request = (HttpServletRequest)servletRequest;
HttpServletResponse response = (HttpServletResponse) servletResponse;
System.out.println("跨域請(qǐng)求過(guò)濾器啟動(dòng)");
if (request.getRequestURL().toString().matches(".+.ico$")) {
filterChain.doFilter(servletRequest, servletResponse);
} else {
String origin = request.getHeader("Origin");
// 簡(jiǎn)單請(qǐng)求跨域,如果是跨域請(qǐng)求在響應(yīng)頭里面添加對(duì)應(yīng)的Origin
if (!StringUtils.isEmpty(origin)) {
response.addHeader("Access-Control-Allow-Origin", origin);
}
// 非簡(jiǎn)單請(qǐng)求跨域
response.addHeader("Access-Control-Allow-Headers", "content-type");
// 允許跨域請(qǐng)求的方法
response.addHeader("Access-Control-Allow-Methods", "*");
// 攜帶cookie的跨域
response.addHeader("Access-Control-Allow-Credentials", "true");
// 放行方法
filterChain.doFilter(servletRequest, servletResponse);
}
}
@Override
public void destroy() {
Filter.super.destroy();
}
}到此這篇關(guān)于關(guān)于SpringBoot中Ajax跨域以及Cookie無(wú)法獲取丟失問(wèn)題的文章就介紹到這了,更多相關(guān)Ajax跨域Cookie丟失問(wèn)題內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringMVC?RESTFul實(shí)戰(zhàn)案例刪除功能實(shí)現(xiàn)
這篇文章主要為大家介紹了SpringMVC?RESTFul實(shí)戰(zhàn)案例刪除功能實(shí)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
Mybatis調(diào)用視圖和存儲(chǔ)過(guò)程的方法
MyBatis支持普通sql的查詢、視圖的查詢、存儲(chǔ)過(guò)程調(diào)用,是一種非常優(yōu)秀的持久層框架。接下來(lái)通過(guò)本文給大家介紹mybatis調(diào)用視圖和存儲(chǔ)過(guò)程的方法,感興趣的朋友一起看看吧2016-10-10
使用遞歸算法結(jié)合數(shù)據(jù)庫(kù)解析成Java樹形結(jié)構(gòu)的代碼解析
這篇文章主要介紹了使用遞歸算法結(jié)合數(shù)據(jù)庫(kù)解析成Java樹形結(jié)構(gòu)的代碼解析的相關(guān)資料,需要的朋友可以參考下2017-09-09
Java Swing組件布局管理器之FlowLayout(流式布局)入門教程
這篇文章主要介紹了Java Swing組件布局管理器之FlowLayout(流式布局),結(jié)合實(shí)例形式分析了Swing組件布局管理器FlowLayout流式布局的常用方法及相關(guān)使用技巧,需要的朋友可以參考下2017-11-11
深入聊一聊springboot項(xiàng)目全局異常處理那些事兒
最近在做項(xiàng)目時(shí)需要對(duì)異常進(jìn)行全局統(tǒng)一處理,所以下面這篇文章主要給大家介紹了關(guān)于springboot項(xiàng)目全局異常處理那些事兒,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-01-01
深入解析Java編程中的StringBuffer與StringBuider
這篇文章主要介紹了Java編程中的StringBuffer與StringBuider,是Java入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-09-09

