關(guān)于SpringBoot中Ajax跨域以及Cookie無法獲取丟失問題
在寫自己項目的登錄注冊頁面時, 因為我的注冊和更改密碼功能采用了郵箱驗證, 在發(fā)送驗證碼的時候后端會向響應(yīng)數(shù)據(jù)中添加一個cookie
Cookie cookie = new Cookie(toEmail.split("@")[0],verCode); cookie.setMaxAge(30*60); response.addCookie(cookie);
然后在點擊注冊或更改密碼時, 后端會從請求中獲取Cookie獲得郵箱與驗證碼信息
Cookie[] cookies = request.getCookies();
在本地進行測試時, Cookie能正確添加進響應(yīng)中, 也能正確獲取
但是在把項目打包上云, 再進行ajax訪問時就出現(xiàn)了問題, Cookie獲取失敗了!
再響應(yīng)標(biāo)頭中分明有set-Cookie, 但是再第二次的請求標(biāo)頭中卻找不到Cookie
服務(wù)端獲取cookie失敗報錯, 注冊和更改密碼需要使用Cookie的功能失效, 在查找文檔后發(fā)現(xiàn)錯誤來源于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設(shè)置響應(yīng)頭, 鍵為"Access-Control-Allow-Origin" 訪問控制允許來源,http請求頭信息,設(shè)定允許資源共享(跨域)的源
response.setHeader("Access-Control-Allow-Origin",request.getHeader("Origin"));
值為 request.getHeader("Origin"), 表示當(dāng)前請求資源所在頁面的協(xié)議和域名
組合在一起表示 允許當(dāng)前請求資源跨域訪問后端資源
這三部均設(shè)置好后我就能夠重新獲取到cookie了
2022-12-09 更新內(nèi)容:
發(fā)現(xiàn)了更加簡潔方便的方法, 添加跨域請求過濾器
用到了德魯伊數(shù)據(jù)池依賴包的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"); // 簡單請求跨域,如果是跨域請求在響應(yīng)頭里面添加對應(yīng)的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(); } }
到此這篇關(guān)于關(guān)于SpringBoot中Ajax跨域以及Cookie無法獲取丟失問題的文章就介紹到這了,更多相關(guān)Ajax跨域Cookie丟失問題內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解SpringBoot是如何整合SpringDataRedis的?
今天給大家?guī)淼氖顷P(guān)于Java的相關(guān)知識,文章圍繞著SpringBoot是如何整合SpringDataRedis展開,文中有非常詳細的介紹及代碼示例,需要的朋友可以參考下2021-06-06Java8 實現(xiàn)stream將對象集合list中抽取屬性集合轉(zhuǎn)化為map或list
這篇文章主要介紹了Java8 實現(xiàn)stream將對象集合list中抽取屬性集合轉(zhuǎn)化為map或list的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02Spring框架學(xué)習(xí)筆記之方法注解@Bean的使用
這篇文章主要給大家介紹了關(guān)于Spring框架學(xué)習(xí)筆記之方法注解@Bean使用的相關(guān)資料,這是一個我們很常用的注解,作用是指示一個方法生成一個由Spring管理的Bean,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2023-12-12Java網(wǎng)絡(luò)編程中的TCP/UDP詳解
這篇文章主要介紹了Java網(wǎng)絡(luò)編程中的TCP/UDP詳解,網(wǎng)絡(luò)編程是指編寫運行在多個設(shè)備的程序,這些設(shè)備都通過網(wǎng)絡(luò)連接起來,java.net 包中 J2SE 的 API 包含有類和接口,它們提供低層次的通信細節(jié),需要的朋友可以參考下2023-12-12Java String.replace()方法"無效"的原因及解決方式
這篇文章主要介紹了Java String.replace()方法"無效"的原因及解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08