中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot中Ajax跨域及Cookie無法獲取丟失問題怎么解決

發布時間:2023-03-31 14:58:25 來源:億速云 閱讀:100 作者:iii 欄目:開發技術

這篇文章主要介紹“SpringBoot中Ajax跨域及Cookie無法獲取丟失問題怎么解決”,在日常操作中,相信很多人在SpringBoot中Ajax跨域及Cookie無法獲取丟失問題怎么解決問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”SpringBoot中Ajax跨域及Cookie無法獲取丟失問題怎么解決”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

在寫自己項目的登錄注冊頁面時, 因為我的注冊和更改密碼功能采用了郵箱驗證, 在發送驗證碼的時候后端會向響應數據中添加一個cookie

Cookie cookie = new Cookie(toEmail.split("@")[0],verCode);
cookie.setMaxAge(30*60);
response.addCookie(cookie);

然后在點擊注冊或更改密碼時, 后端會從請求中獲取Cookie獲得郵箱與驗證碼信息

Cookie[] cookies = request.getCookies();

在本地進行測試時, Cookie能正確添加進響應中, 也能正確獲取

SpringBoot中Ajax跨域及Cookie無法獲取丟失問題怎么解決

SpringBoot中Ajax跨域及Cookie無法獲取丟失問題怎么解決

但是在把項目打包上云, 再進行ajax訪問時就出現了問題, Cookie獲取失敗了!

再響應標頭中分明有set-Cookie, 但是再第二次的請求標頭中卻找不到Cookie

服務端獲取cookie失敗報錯, 注冊和更改密碼需要使用Cookie的功能失效, 在查找文檔后發現錯誤來源于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("/**")
                //是否發送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"), 表示當前請求資源所在頁面的協議和域名

組合在一起表示 允許當前請求資源跨域訪問后端資源

這三部均設置好后我就能夠重新獲取到cookie了

2022-12-09 更新內容:

發現了更加簡潔方便的方法, 添加跨域請求過濾器

用到了德魯伊數據池依賴包的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無法獲取丟失問題怎么解決”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

桐柏县| 黄梅县| 深州市| 通渭县| 昌图县| 名山县| 荔波县| 定陶县| 板桥市| 昌宁县| 宁波市| 绿春县| 长春市| 永兴县| 古田县| 蓝田县| 塔河县| 三门峡市| 克东县| 普宁市| 哈尔滨市| 岳阳县| 元谋县| 民丰县| 额济纳旗| 剑川县| 江达县| 特克斯县| 洮南市| 县级市| 高阳县| 海林市| 通州市| 成安县| 扎兰屯市| 无为县| 平罗县| 永川市| 新巴尔虎左旗| 夏津县| 齐齐哈尔市|