欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決前后端分離 vue+springboot 跨域 session+cookie失效問題

 更新時間:2019年05月13日 10:50:22   作者:晨風啊  
這篇文章主要介紹了前后端分離 vue+springboot 跨域 session+cookie失效問題的解決方法,解決過程也很簡單 ,需要的朋友可以參考下

環(huán)境:

前端 vue ip地址:192.168.1.205

后端 springboot2.0 ip地址:192.168.1.217

主要開發(fā)后端。

問題:

首先登陸成功時將用戶存在session中,后續(xù)請求在將用戶從session中取出檢查。后續(xù)請求取出的用戶都為null。

解決過程:

首先發(fā)現sessionID不一致,導致每一次都是新的會話,當然不可能存在用戶了。然后發(fā)現cookie瀏覽器不能自動保存,服務器響應set-cookie了

搜索問題,發(fā)現跨域,服務器響應的setCookie瀏覽器無法保存,而且就算保存了域名不同也不能攜帶。

第一步:

后臺添加過濾器,因為前后端分離,不可能每個方法都寫一遍,所以添加過濾器統一處理。

package com.test.filter;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebFilter(urlPatterns = "/*", filterName = "CORSFilter")
public class CORSFilter implements Filter {
 @Override
 public void destroy() {
 }
 /**
  * 此過濾器只是處理跨域問題
  * @param servletRequest
  * @param servletResponse
  * @param chain
  * @throws ServletException
  * @throws IOException
  */
 @Override
 public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain chain) throws ServletException, IOException {
  HttpServletRequest req = (HttpServletRequest) servletRequest;
  HttpServletResponse resp = (HttpServletResponse) servletResponse;
  String origin = req.getHeader("Origin");
  if(origin == null) {
   origin = req.getHeader("Referer");
  }
  resp.setHeader("Access-Control-Allow-Origin", origin);//這里不能寫*,*代表接受所有域名訪問,如寫*則下面一行代碼無效。謹記
  resp.setHeader("Access-Control-Allow-Credentials", "true");//true代表允許攜帶cookie
  chain.doFilter(servletRequest,servletResponse);
 }
 @Override
 public void init(FilterConfig filterConfig) throws ServletException {
 }
}

springboot2.配置過濾器時,啟動類必須加上@ServletComponentScan才會加載過濾器

@SpringBootApplication
@EnableTransactionManagement(order = 10)
@ServletComponentScan
public class Application {
 public static void main(String[] args) {
  SpringApplication.run(Application.class, args);
 }
}

然后前端配置

使用vue.resource發(fā)送請求時配置如下:
main.js中
Vue.http.options.xhr = { withCredentials: true }
使用vue.axios發(fā)送請求時配置如下:
axios.defaults.withCredentials = true;
jquery請求帶上 xhrFields: {withCredentials: true}, crossDomain: true;
$.ajax({
 type: "post",
 url: "",
 xhrFields: {withCredentials: true},
 crossDomain: true,
 data: {username:$("#username").val()},
 dataType: "json",
 success: function(data){ }
});

此時問題已解決。

但我查看請求時,還是沒有帶cookie,太糾結于這一點了。以至于查看全部cookie時突然明白了。

沒有帶cookie。

瀏覽器全部cookie

已經有服務器的cookie了。當向服務器發(fā)送請求時,會攜帶cookie,證明是同一會話。

發(fā)現火狐的請求頭中存在cookie,不知道為什么谷歌的請求頭不顯示,不明白。望解答。

總結

以上所述是小編給大家介紹的解決前后端分離 vue+springboot 跨域 session+cookie失效問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章

  • vue轉react入門指南

    vue轉react入門指南

    因為新公司使用react技術棧,包括Umi、Dva、Ant-design等一系列解決方案。本文就簡單的介紹一下vue轉react入門指南,感興趣的可以了解一下
    2021-10-10
  • vue2和vue3部署到服務器子目錄為空白頁問題及解決

    vue2和vue3部署到服務器子目錄為空白頁問題及解決

    這篇文章主要介紹了vue2和vue3部署到服務器子目錄為空白頁問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • vue3中實現音頻播放器APlayer的方法

    vue3中實現音頻播放器APlayer的方法

    這篇文章主要介紹了vue3中實現音頻播放器APlayer的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • vue實現鍵盤輸入支付密碼功能

    vue實現鍵盤輸入支付密碼功能

    這篇文章主要為大家詳細介紹了vue實現鍵盤輸入支付密碼功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • Vue如何利用flex布局實現TV端城市列表功能

    Vue如何利用flex布局實現TV端城市列表功能

    用vue開發(fā)了三四個組件了,都是H5的,現在來看看PC是如何玩轉組件的,下面這篇文章主要給大家介紹了關于Vue如何利用flex布局實現TV端城市列表功能的相關資料,需要的朋友可以參考下
    2023-01-01
  • VUE2.0自定義指令與v-if沖突導致元素屬性修改錯位問題及解決方法

    VUE2.0自定義指令與v-if沖突導致元素屬性修改錯位問題及解決方法

    這篇文章主要介紹了VUE2.0自定義指令與v-if沖突導致元素屬性修改錯位問題及解決方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • vue引入子組件命名不規(guī)范錯誤的解決方案

    vue引入子組件命名不規(guī)范錯誤的解決方案

    這篇文章主要介紹了vue引入子組件命名不規(guī)范錯誤的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue3+Antd實現彈框顯示內容并加入復制按鈕

    Vue3+Antd實現彈框顯示內容并加入復制按鈕

    這篇文章主要介紹了Vue3+Antd實現彈框顯示內容并加入復制按鈕,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-12-12
  • Vuei18n 在數組中的使用方式

    Vuei18n 在數組中的使用方式

    這篇文章主要介紹了Vuei18n 在數組中的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue中實現在外部調用methods的方法(推薦)

    vue中實現在外部調用methods的方法(推薦)

    下面小編就為大家分享一篇vue中實現在外部調用methods的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02

最新評論