Heim > Web-Frontend > js-Tutorial > Umgang mit Benutzersitzungsfehlern im Ajax-Betrieb

Umgang mit Benutzersitzungsfehlern im Ajax-Betrieb

php中世界最好的语言
Freigeben: 2018-04-02 09:44:26
Original
1606 Leute haben es durchsucht

Dieses Mal zeige ich Ihnen, wie Sie mit dem Ausfall der Sitzung des Ajax-Betriebsbenutzers umgehen und welche Vorsichtsmaßnahmen es bei einem Sitzungsfehler des Ajax-Betriebsbenutzers gibt Fall, werfen wir einen Blick darauf.

Wenn Sie den spingMVC-Interceptor verwenden, um das Problem des Benutzersitzungsfehlers zu lösen, wird eine Zeichenfolge von Javascript-Zeichenfolgen zurückgegeben, wenn die Benutzersitzung fehlschlägt, um den Browser des Benutzers zu zwingen, zur Anmeldung zu springen Seite. Wenn jedoch Ajax zum Anfordern von Daten verwendet wird, wird nach einer fehlgeschlagenen Überprüfung nur eine Zeichenfolge beantwortet und JavaScript wird nicht ausgeführt. Dies liegt daran, dass die Ajax-Anforderung nicht vom Browser, sondern vom XMLHTTPRequest-Objekt initiiert wird gibt zurück Die Informationen werden vom XMLHTTPRequest-Objekt empfangen und im js-Objekt gespeichert.

Um mit dieser Situation umzugehen, können HTTP-Anfragen zunächst im Hintergrund beurteilt werden und Ajax-Anfragen können getrennt von normalen http-Anfragen verarbeitet werden.
Anhand der von Ajax gesendeten Anforderungsheaderinformationen können Sie feststellen, dass die Headerinformationen der Ajax-Anfrage X-Requested-With:XMLHttpRequest enthalten. Dadurch können Sie feststellen, ob es sich um eine Ajax-Anfrage handelt.

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;
}
Nach dem Login kopieren

Javascript-Code, Sie können die globalen Standardoptionen für Ajax-Anfragen ein für alle Mal festlegen

//设置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';
    }
  }
});
Nach dem Login kopieren

DataTables wird in dem Projekt auch verwendet, um Datentabellen zu erstellen dass die Verwendung der oben genannten Javascript-Konfigurationsmethode in Datentabellen nicht wirksam werden kann, Fehlermeldung siehe: http://datatables.net/tn/7 Sie müssen das Fehlerattribut von 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';
    }
  }
 }
});
Nach dem Login kopieren
Ich glaube, Sie haben es gemeistert, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Methoden finden Sie in anderen verwandten Artikeln auf der chinesischen PHP-Website!

Empfohlene Lektüre:

jQuery+Ajax ermittelt, ob der eingegebene Bestätigungscode erfolgreich ist

So erstellen Sie ein intelligentes Suchfeld mit Ajax-Eingabeaufforderungsfunktion

Das obige ist der detaillierte Inhalt vonUmgang mit Benutzersitzungsfehlern im Ajax-Betrieb. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage