java web項目Session獲取不到問題及解決

java web項目Session獲取不到

在servlet類中對Session進行瞭設置 但當servlet跳轉到頁面時 頁面獲取不到Session!!!

關於session的生命周期

Session保存在服務器端。Session在用戶第一次訪問服務器的時候自動創建。需要註意隻有訪問JSP、Servlet等程序時才會創建Session,隻訪問HTML、IMAGE等靜態資源並不會創建Session。如果尚未生成Session,也可以使用request.getSession(true)強制生成Session。

而我們在頁面獲取不到Seesion的原因可能是:瀏覽器禁用瞭Cookie

使用url地址重寫即可解決!

  • response.encodeRedirectURL(url)用於對sendRedirect方法後的url地址進行重寫。
  • response.encodeURL(url)用於對表單action和超鏈接的url地址進行重寫
String url=response.encodeRedirectURL("url");
response.sendRedirect(url);

這樣在頁面中即可使用

<%=request.getSession().getAttribute("key")%>

來獲取我們存儲的Seesion!!!

前後端分離獲取不到session問題

前後端分離的項目,前端是vue,後端springboot,或者maven項目,生成驗證碼的時候存瞭一份到session並存到redis裡,前端調後臺註冊獲取不到session,但當用戶從session中取信息的時候發現始終取不到,每次跨域請求時ajax發送的都是新的sessionid,導致無法獲取信息

解決方案

前端在vue的main文件全局添加一下代碼:

import axios from 'axios';
axios.defaults.withCredentials=true;

後臺新增一個過濾器

web.xml文件

<filter>
    <filter-name>contextFilter</filter-name>
    <filter-class>com.zl.filter.ContextFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>contextFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

 

public class ContextFilter implements Filter {
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
    }
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletResponse response = (HttpServletResponse)servletResponse;
        HttpServletRequest request = (HttpServletRequest)servletRequest;
        String origin = request.getHeader("Origin");
        response.setHeader("Access-Control-Allow-Origin", origin);
        response.setHeader("Access-Control-Allow-Methods", "*");
        String headers = request.getHeader("Access-Control-Request-Headers");
         // 支持所有自定義頭
        if (!org.springframework.util.StringUtils.isEmpty(headers)) {
            response.setHeader("Access-Control-Allow-Headers", headers);
        }
        response.setHeader("Access-Control-Allow-Credentials", "true");
        response.setHeader("Access-Control-Max-Age", "3600");
        filterChain.doFilter(request, response);
    }
    @Override
    public void destroy() {
    }
}

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: