1. 程式人生 > 程式設計 >Java後臺判斷ajax請求及處理過程詳解

Java後臺判斷ajax請求及處理過程詳解

一、問題描述:

當訪問一個需要登入的頁面時,會有過濾器或者攔截器進行過濾攔截,如果使用者沒有登入,則跳轉到登入頁面。

當用戶已經登入進入系統後,然後長時間沒操作,等到session過期後,再點選一個ajax請求操作時,這時再跳轉到登入頁面就不合適了,因為這是ajax操作,攔截後跳到頁面返回的結果js識別不了。

二、解決方法:

在過濾器或者攔截器上做識別,針對頁面跳轉請求和ajax請求分別處理。

頁面跳轉的不再詳說,現在說的是ajax請求。

直接貼程式碼:

import java.io.IOException; 
import java.io.PrintWriter; 
 
import javax.servlet.Filter; 
import javax.servlet.FilterChain; 
import javax.servlet.FilterConfig; 
import javax.servlet.ServletException; 
import javax.servlet.ServletRequest; 
import javax.servlet.ServletResponse; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
 
import org.slf4j.Logger; 
import org.slf4j.LoggerFactory; 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.stereotype.Component; 
 
 
 
@Component("authenticationFilter") 
public class AuthenticationFilter implements Filter { 
 
  @Autowired 
  SessionContext sessionContext; 
   
  private Logger log = LoggerFactory.getLogger(AuthenticationFilter.class);  
   
  @Override 
  public void init(FilterConfig filterConfig) throws ServletException { 
 
  } 
 
  @Override 
  public void doFilter(ServletRequest request,ServletResponse response,FilterChain chain) throws IOException,ServletException { 
    HttpServletRequest req = (HttpServletRequest)request; 
    HttpServletResponse res = (HttpServletResponse) response; 
     
    //判斷是否為ajax請求,預設不是 
    boolean isAjaxRequest = false; 
    if(!StrUtils.isBlank(req.getHeader("x-requested-with")) && req.getHeader("x-requested-with").equals("XMLHttpRequest")){ 
      isAjaxRequest = true; 
    } 
     
    SysUser sysUser = sessionContext.getSysUserFromSession(req); 
    if (sysUser != null && sysUser.getUserId() != null) { 
      chain.doFilter(req,res); 
    }else{//Session使用者為空,登入過期 
      if(isAjaxRequest){// 如果是ajax請求,則不是跳轉頁面,使用response返回結果 
        res.setHeader("noAuthentication","true"); 
        ResultWithObject resultWithObject = new ResultWithObject(CC.NEGATIVE_1,CC.RESULT_MESSAGE_TEXT_DEFAULT); 
        resultWithObject.setMsg("登入已失效,請重新整理頁面或重新登入!"); 
        res.setContentType("application/json;charset=UTF-8"); 
        PrintWriter writer = res.getWriter(); 
        writer.write(JasonUtils.Object2String(resultWithObject)); 
        writer.close(); 
        res.flushBuffer(); 
      }else{ 
        res.sendRedirect("http://xxxx.com/loginUI"); 
      } 
    } 
  } 
 
  @Override 
  public void destroy() { 
  } 
} 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。