이 글은 Ajax를 사용할 때 사용자 세션 실패 문제에 대한 해결 방법을 중심으로 자세히 소개하고 있습니다. Ajax에 관심이 있는 친구라면 참고할 만한 내용이 있습니다.
spingMVC를 사용한 사용자 세션 실패 시 차단 , 사용자의 브라우저가 로그인 페이지로 이동하도록 강제하기 위해 JavaScript 문자열의 문자열이 반환됩니다. 그러나 Ajax를 사용하여 데이터를 요청하는 경우 확인 실패 후에는 문자열만 응답하고 JavaScript는 실행되지 않습니다. 이는 확인 실패 후 서버가 아닌 XMLHTTPRequest 객체에 의해 Ajax 요청이 시작되기 때문입니다. 반환 정보는 XMLHTTPRequest 개체에 의해 수신되고 js 개체에 저장됩니다.
이러한 상황에 대처하기 위해 먼저 백그라운드에서 Http 요청을 판단하고, Ajax 요청을 일반 http 요청과 별도로 처리할 수 있습니다.
Ajax에서 보낸 요청 헤더 정보를 보면 Ajax 요청의 헤더 정보에 X-Requested-With:XMLHttpRequest가 포함되어 있음을 알 수 있습니다. 이를 통해 Ajax 요청인지 여부를 확인할 수 있습니다.
String requestType = request.getHeader("X-Requested-With"); if(requestType != null && "XMLHttpRequest".equalsIgnoreCase(requestType.trim())) { //如果是ajax请求 response.setHeader("sessionStatus", "timeout"); response.sendError(601, "session timeout."); return false; }
javascript 코드를 사용하면 Ajax 요청에 대한 전역 기본 옵션을 한 번에 설정할 수 있습니다.
//设置Ajax请求的全局默认options jQuery.ajaxSetup({ type:'post', complete:function(xhr, ts){ //XMLHttpRequest, textStatus var sessionStatus = xhr.getResponseHeader('sessionstatus'); if(sessionStatus == 'timeout') { alert('页面过期,请重新登录!'); window.top.location.href = 'Login.htm'; } } });
프로젝트에서도 DataTables를 사용하여 데이터 테이블을 만듭니다. 오류 정보는 http://datatables.net/tn/7을 참조하세요. ajax
$('#example').dataTable( { "ajax": { "url": "findRoles.htm", "type": "POST", "error": function(xhr, ts, et) { //XMLHttpRequest, textStatus, errorThrown var sessionStatus = xhr.getResponseHeader('sessionstatus'); if(sessionStatus == 'timeout') { alert('页面过期,请重新登录!'); window.top.location.href = 'Login.htm'; } } } });
의 오류 속성을 구성해야 합니다. 위 내용은 이 기사의 전체 내용입니다. 모든 분들의 학습에 도움이 되기를 바라며, PHP 중국어 웹사이트를 지원해 주시길 바랍니다.
관련 권장사항:
Ajax 백그라운드 성공에서 전송된 json 데이터 문제에 대한 간략한 분석
json 형식 데이터를 백그라운드로 전송할 때 415 오류가 발생하는 Ajax 분석 및 원인에 대한 솔루션
위 내용은 Ajax 사용시 사용자 세션 실패 문제에 대한 해결 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!