我需要发送一个请求到一个网络服务接口在不同的域从html页面。有时,需要同步请求。例如:使用用户名和密码登录,并在webservice确认后得到响应。
然而,我使用的是jsonp,它被发现不能进行同步请求。( html页面和webservice都在我的控制之下)
有什么好主意吗?提前谢谢。
发布于 2012-12-29 09:40:34
如果你发送报头(‘Access-Control-Allow-Origin:*'),你只能使用一个标准的非异步$.ajax对象。
<?php
header('Access-Control-Allow-Origin: *');
?>
<html>
...
</html>
<script type="text/javascript">
$(document).ready( function()
{
$("#someID").on('click', function()
{
var username = 'username';
var passwd = 'password';
$.ajax(
{
type:'post,
dataType:'json',
url:'http://yoursite.com/web-service.php',
data:{username:username,password:passwd},
async:false,
success:function(data){},
error:function(jqXhr, textStatus, errorThrown){}
});
});
});
</script>
发布于 2012-12-29 10:32:08
async:false
已被弃用,这是有充分理由的。
您的登录函数需要重构,以便在成功回调中使用响应数据。
您的代码需要执行以下操作:
$.ajax({
/* other options*/
success:function( response){
if( response.status=='ok'){
/* run sucessful login code*/
}else{
/* message to user*/
}
}
})
https://stackoverflow.com/questions/14077906
复制相似问题