ホームページ >ウェブフロントエンド >jsチュートリアル >セッションタイムアウト後に ajax を使用してログインページにジャンプする
今回は、セッションタイムアウト後にajaxを使用してログインページにジャンプする方法と、セッションタイムアウト後にajaxを使用してログインページにジャンプする方法についてメモを紹介します。実際のケースを見てみましょう。
問題: window.location.href を使用してページにジャンプする場合、バックエンドはセッションがタイムアウトしたときにログイン ページにリダイレクトするための filter を実装するだけで済みます。しかし、ajax を使用するとどうなるでしょうか? ajax を使用して実行すると 302 エラーが発生し、そのページにジャンプすることができません。この問題に対処するために、フロントエンドとバックエンドのコードを以下に投稿します。
1. セッションフィルター
import java.io.IOException; <p style="text-align: center"><img alt=""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 javax.servlet.http.HttpSession; <p style="text-align: center"><img alt=""public class SessionFilter implements Filter { <p style="text-align: center"><img alt="" public void doFilter(ServletRequest req, ServletResponse res, FilterChain filterChain) throws IOException, ServletException { HttpServletRequest request = (HttpServletRequest) req; HttpServletResponse response = (HttpServletResponse) res; <p style="text-align: center"><img alt="" String requestUri = request.getRequestURI(); <p style="text-align: center"><img alt="" if (requestUri.indexOf("/login.html") > 0 || requestUri.indexOf("/system/login") > 0) { return ; } <p style="text-align: center"><img alt="" HttpSession session = request.getSession(false); <p style="text-align: center"><img alt="" if (session == null) { // 如果是session超时,在此处做处理。 response.sendRedirect(request.getContextPath() + "/login.html"); return ; } try { filterChain.doFilter(request, response); } catch (Exception e) { e.printStackTrace(); } return ; } }
2. web.xml に設定を追加します:
<filter> <filter-name>sessionFilter</filter-name> <filter-class>com.manager.filter.SessionFilter</filter-class> </filter> <filter-mapping> <filter-name>sessionFilter</filter-name> <url-pattern>/manager/*</url-pattern> </filter-mapping>
*3. ajax を書き換えます
注: このコードはインデックスページに配置されます
jQuery(function($){ var _ajax=$.ajax; $.ajax=function(opt){ var _success = opt && opt.success || function(a, b){}; var _opt = $.extend(opt, { success:function(data, textStatus){ _success(data, textStatus); }, error:function(XMLHttpRequest, textStatus, errorThrown){ //alert(XMLHttpRequest.responseText); //如果请求发生错误,会返回登陆页面源代码,如果源代码里面存在lovnx这个字符串,前端就重定向到登陆页面 var reData = XMLHttpRequest.responseText + ""; if(reData.indexOf('lovnx') != -1) { window.location.href="/manager/login.html" rel="external nofollow" ; return; } } }); return _ajax(_opt); }; });
4。ログイン ページにコードを追加します
<input type="hidden" value="lovnx">
この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、PHP 中国語 Web サイトの他の関連記事に注目してください。
推奨読書:
Ajax はファイルアップロードのプログレスバーをどのように実装しますか Codular
Ajax ベースのフォームデータ画像とデータアップロードルーの実装
以上がセッションタイムアウト後に ajax を使用してログインページにジャンプするの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。