问题已得到纠正。 ajax请求的localhost地址应该是127.0.0.1而不是 121.0.0.1
在我的客户端上,我有以下代码在localhost / login上请求POST
<html>
<title> Welcome </title>
<script>
function makeRequestObject(){
var xmlhttp=false;
try {
xmlhttp = new ActiveXObject('Msxml2.XMLHTTP');
} catch (e) {
try {
xmlhttp = new ActiveXObject('Microsoft.XMLHTTP');
} catch (E) {
xmlhttp = false;
}
}
if (!xmlhttp && typeof XMLHttpRequest!='undefined') {
xmlhttp = new XMLHttpRequest();
}
return xmlhttp;
}
function showdata()
{
var xmlhttp=makeRequestObject();
var user=document.getElementById('user_name').value;
var pass=document.getElementById('password').value;
var url = 'https://121.0.0.1/login'; // invalid ip address for localhost
var params = 'uname='+user+'&'+'pass='+pass;
xmlhttp.open('POST', url, true);
xmlhttp.setRequestHeader("content-type", "application/x-www-form-urlencoded");
xmlhttp.onreadystatechange=function() {
if (xmlhttp.readyState==4 && xmlhttp.status == 200) {
var content = xmlhttp.responseText;
if( content ){
document.getElementById('userdiv').innerHTML = content;
}
}
}
xmlhttp.send(params);
}
</script>
<body>
Enter user name : <input type="text" id="user_name" /><br/>
Enter your password : <input type="text" id="password"/><br/>
<input type="button" onclick="showdata()" value="Submit"><br/><br/>
<div id="userdiv">
</div>
</body>
</html>
我的服务器端有以下瘦手柄功能:
$app->post('/login', function () use ($app){
$req = $app->request();
$uname = $req->params('uname');
$pass = $req->params('pass');
$app->response()->header('Content-Type', 'application/json');
echo json_encode($uname);
exit;
});
我的问题是,当服务器上看到请求时,会对服务器进行ajax调用。但是服务器没有回复。
这里是Chrome开发人员工具
中发生的事情的屏幕截图http://s29.postimg.org/5379a7rt3/image.png
我可以看到对localhost的初始调用正在运行 但是下一次登录的ajax调用不起作用,因为只生成请求但没有收到响应。随后的响应超时
答案 0 :(得分:-1)
我认为您的请求应该是GET方法而不是上述情况的帖子。尝试更改以在GET中执行此请求而不是发布。