J'essaie donc d'obtenir l'emplacement à partir d'une réponse d'en-tête via jQuery get. J'ai essayé d'utiliser getResponseHeader ('Location') et getAllResponseHeaders () mais ils semblent tous les deux retourner null.
Voici mon code actuel
$(document).ready(function(){
var geturl;
geturl = $.ajax({
type: "GET",
url: 'http://searchlight.cluen.com/E5/Login.aspx?URLKey=uzr7ncj8)',
});
var locationResponse = geturl.getResponseHeader('Location');
console.log(locationResponse);
});
Les en-têtes seront disponibles lorsque la demande asynchrone reviendra, vous devrez donc les lire dans la rappel de succès :
$.ajax({
type: "GET",
url: 'http://searchlight.cluen.com/E5/Login.aspx?URLKey=uzr7ncj8)',
success: function(data, status, xhr) {
console.log(xhr.getResponseHeader('Location'));
}
});
pour certains en-têtes dans jQuery Ajax, vous devez accéder à l'objet XMLHttpRequest
var xhr;
var _orgAjax = jQuery.ajaxSettings.xhr;
jQuery.ajaxSettings.xhr = function () {
xhr = _orgAjax();
return xhr;
};
$.ajax({
type: "GET",
url: 'http://example.com/redirect',
success: function(data) {
console.log(xhr.responseURL);
}
});
ou en utilisant du javascript simple
var xhr = new XMLHttpRequest();
xhr.open('GET', "http://example.com/redirect", true);
xhr.onreadystatechange = function () {
if (this.readyState == 4 && this.status == 200) {
console.log(xhr.responseURL);
}
};
xhr.send();
jQuery résume l'objet XMLHttpRequest dans un soi-disant "super ensemble" qui n'expose pas le champ responseURL. C'est dans leurs documents où ils parlent de "l'objet jQuery XMLHttpRequest (jqXHR)"
For backward compatibility with XMLHttpRequest, a jqXHR object will expose the following properties and methods:
readyState
responseXML and/or responseText when the underlying request responded with xml and/or text, respectively
status
statusText
abort( [ statusText ] )
getAllResponseHeaders() as a string
getResponseHeader( name )
overrideMimeType( mimeType )
setRequestHeader( name, value ) which departs from the standard by replacing the old value with the new one rather than concatenating the new value to the old one
statusCode( callbacksByStatusCode )
No onreadystatechange mechanism is provided, however, since done, fail, always, and statusCode cover all conceivable requirements.
Comme vous pouvez le voir, il n'y a aucun moyen d'obtenir l'URL de réponse car l'API jqXHR ne l'expose pas