gpt4 book ai didi

php - AJAX、Laravel 4.2 - POST 状态已取消,如何发布到路由

转载 作者:塔克拉玛干 更新时间:2023-11-01 19:07:44 25 4
gpt4 key购买 nike

我一直在为这个问题绞尽脑汁。我有一个 Jquery block ,可以将 AJAX 帖子发送到网站内的 url。当用户重定向离开他们所在的当前页面时,就会发生这种逻辑。

问题是我在带有 Jquery 脚本的 url 上,我重定向离开页面,然后检查 chrome 中的开发人员控制台并提出一个状态为已取消的 POST。我检查了我数据库中的表,它没有插入记录,所以我认为状态意味着它永远无法到达 URL。

定义了ajaxtest路由的路由文件

<?php
Route::post('ajaxtest', array('before' => 'adminFilter', 'uses' => 'TestsController@ajaxTest'));
?>

涉及的Controller中的方法

  <?php
public function ajaxTest() {
DB::table('test_ajax')->insert(
array('test_string' => 'TestTest')
);
if (Request::isJson()) {
$name = Input::get('name');
$age = Input::get('age');
DB::table('test_ajax')->insert(
array('test_string' => $name.'|'.$age)
);
} else {
DB::table('test_ajax')->insert(
array('test_string' => $name.'|'.$age)
);
}
}
?>

如果用户重定向离开当前页面,则涉及的 Jquery 旨在将 AJAX 发布到 ajaxtest url。

    <script type="text/javascript">
console.log("Host url" + window.location.host);
var formFlag = false;

$("#submitTest").click(function() {
formFlag = true;
});
window.onbeforeunload = function(){
if(!formFlag){
return "Your changes may not be saved.";
}
}
$( window ).unload(function() {
$.post("<?php echo Request::root(); ?>/ajaxtest/", { name: "John", age: "26" });
});
</script>

开发者控制台请求信息,状态为已取消。

Request URL:http://192.168.0.9/ajaxtest/
Request Headers
Provisional headers are shown
Accept:*/*
Content-Type:application/x-www-form-urlencoded; charset=UTF-8
Origin:http://192.168.0.9
Referer:http://192.168.0.9/tests/question
User-Agent:Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/40.0.2214.115 Safari/537.36
X-Requested-With:XMLHttpRequest
Form Dataview sourceview URL encoded
name:John
age:26

最佳答案

由于$.post 是异步方法,$( window ).unload(..) 不会等待执行并取消它。尝试改变这一点

$( window ).unload(function() {
$.post("<?php echo Request::root(); ?>/ajaxtest/", { name: "John", age: "26" });
});

对此:

$( window ).unload(function() {
$.ajax({
type: 'POST',
url: '<?php echo Request::root(); ?>/ajaxtest/',
data: { name: "John", age: "26" },
async: false
});
});

它像同步方法一样调用 POST,所以浏览器应该等到它结束然后卸载。但是不建议在 unload 中等待某些东西。它可能对用户不友好。

关于php - AJAX、Laravel 4.2 - POST 状态已取消,如何发布到路由,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28657777/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com