關于SpringBoot中Ajax跨域以及Cookie無法獲取丟失問題
在寫自己項目的登錄注冊頁面時, 因為我的注冊和更改密碼功能采用了郵箱驗證, 在發(fā)送驗證碼的時候后端會向響應數據中添加一個cookie
Cookie cookie = new Cookie(toEmail.split("@")[0],verCode);
cookie.setMaxAge(30*60);
response.addCookie(cookie);然后在點擊注冊或更改密碼時, 后端會從請求中獲取Cookie獲得郵箱與驗證碼信息
Cookie[] cookies = request.getCookies();
在本地進行測試時, Cookie能正確添加進響應中, 也能正確獲取


但是在把項目打包上云, 再進行ajax訪問時就出現了問題, Cookie獲取失敗了!
再響應標頭中分明有set-Cookie, 但是再第二次的請求標頭中卻找不到Cookie
服務端獲取cookie失敗報錯, 注冊和更改密碼需要使用Cookie的功能失效, 在查找文檔后發(fā)現錯誤來源于springboot和ajax的跨域cookie丟失問題, 由于我是剛接觸后端的小白,
這里只貼出我的解決方案
1. ajax請求中 需要攜帶上 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設置響應頭, 鍵為"Access-Control-Allow-Origin" 訪問控制允許來源,http請求頭信息,設定允許資源共享(跨域)的源
response.setHeader("Access-Control-Allow-Origin",request.getHeader("Origin"));值為 request.getHeader("Origin"), 表示當前請求資源所在頁面的協(xié)議和域名
組合在一起表示 允許當前請求資源跨域訪問后端資源
這三部均設置好后我就能夠重新獲取到cookie了
2022-12-09 更新內容:
發(fā)現了更加簡潔方便的方法, 添加跨域請求過濾器
用到了德魯伊數據池依賴包的StringUtils.isEmpty 方法, 報錯了的話自己寫一個替換就行
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("跨域請求過濾器啟動");
if (request.getRequestURL().toString().matches(".+.ico$")) {
filterChain.doFilter(servletRequest, servletResponse);
} else {
String origin = request.getHeader("Origin");
// 簡單請求跨域,如果是跨域請求在響應頭里面添加對應的Origin
if (!StringUtils.isEmpty(origin)) {
response.addHeader("Access-Control-Allow-Origin", origin);
}
// 非簡單請求跨域
response.addHeader("Access-Control-Allow-Headers", "content-type");
// 允許跨域請求的方法
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();
}
}到此這篇關于關于SpringBoot中Ajax跨域以及Cookie無法獲取丟失問題的文章就介紹到這了,更多相關Ajax跨域Cookie丟失問題內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解SpringBoot是如何整合SpringDataRedis的?
今天給大家?guī)淼氖顷P于Java的相關知識,文章圍繞著SpringBoot是如何整合SpringDataRedis展開,文中有非常詳細的介紹及代碼示例,需要的朋友可以參考下2021-06-06
Java8 實現stream將對象集合list中抽取屬性集合轉化為map或list
這篇文章主要介紹了Java8 實現stream將對象集合list中抽取屬性集合轉化為map或list的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
Java String.replace()方法"無效"的原因及解決方式
這篇文章主要介紹了Java String.replace()方法"無效"的原因及解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08

