Maison > Questions et réponses > le corps du texte
L'erreur textStatus en ajax est parsererror.
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<script src="js/jquery-1.8.0.min.js" type="text/javascript" charset="utf-8"></script>
<script src="js/jq.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
$.ajax({
type: "GET",
url: "http://192.168.20.205:8080/platform/banner/bannerApi",
async:true,
dataType: "jsonp",
jsonp: "callback",
success:function(req){
console.log(req);
},
error:function(XMLHttpRequest, textStatus, errorThrown) {
alert(XMLHttpRequest.status);//400
alert(XMLHttpRequest.readyState);//2
alert(textStatus);//parsererror
}
});
</script>
</body>
</html>
S'il vous plaît, donnez-moi quelques conseils, je n'ai jamais rencontré ce problème auparavant. Vous pouvez également trouver d'autres méthodes, attendez de voir
.黄舟2017-06-23 09:14:53
Cela doit probablement être combiné avec l'arrière-plan et spécifier un paramètre nommé jsonpCallback
.
为情所困2017-06-23 09:14:53
Conseils, il s'agit d'un problème inter-domaines. Si vous avez écrit le backend, vous pouvez configurer Cors. J'espère qu'il pourra vous aider. Au fait, Spring doit être scanné.
/**
* Created by sunny on 2017/6/22.
*/
public class CorsConfig extends WebMvcConfigurerAdapter {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**")
.allowedOrigins("*")
.allowCredentials(true)
.allowedMethods("GET", "POST", "DELETE", "PUT")
.maxAge(3600);
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
WebContentInterceptor webContentInterceptor = new WebContentInterceptor();
CacheControl nocache = CacheControl.noCache();
webContentInterceptor.addCacheMapping(nocache, "/**");
registry.addInterceptor(webContentInterceptor);
}
}
天蓬老师2017-06-23 09:14:53
Le dataType renvoyé par l'arrière-plan est incohérent avec le dataType demandé par ajax