Vla*_*mir 6 javascript php ajax jquery laravel-5
我需要从jQuery post请求接收数据,认为路由或控制器有一些错误,这里是我的帖子请求javascript代码:
$.post('http://localhost:8000/ajax',
{
task: "comment_insert",
userID: _userID,
comment: _comment,
name: _name,
userName: _userName
}
).error(
function(data)
{
alert("Error: "+ data);
}
)
.success(
function( data )
{
comment_insert(jQuery.parseJSON( data ));
console.log("RESPOND TEXT:" + data);
}
);
}
Run Code Online (Sandbox Code Playgroud)
这里是我的Laravel框架路线:
Route::post('ajax', 'AjaxController@index');
Run Code Online (Sandbox Code Playgroud)
控制器:
class AjaxController extends Controller {
/**
* Display a listing of the resource.
*
* @return Response
*/
public function __construct()
{
$this->middleware('guest');
}
public function index()
{
return view('ajax.ajax');
}
}
Run Code Online (Sandbox Code Playgroud)
我的ajax.php脚本进入/resource/views/ajax/ajax.php另外如果我把脚本放到/public/ajax/ajax.php一切正常....我使用Laravel 5 ...请帮忙
编辑:
我发现了什么是问题,但不知道如何解决.
当我禁用csrf保护:kernel.php代码工作时,任何人都知道如何使代码与csrf保护启用?
cgr*_*oss 10
更新:问题是新的CSRF保护不适用于ajax请求.这是你可以做的:
在主模板中添加一个带有当前令牌的新元标记,如下所示
<meta name="csrf-token" content="{{ Session::token() }}">
Run Code Online (Sandbox Code Playgroud)
然后在发送您的ajax调用时,您可以像这样添加令牌:
$.post('http://localhost:8000/ajax',
{
'_token': $('meta[name=csrf-token]').attr('content'),
task: 'comment_insert',
userID: _userID,
comment: _comment,
name: _name,
userName: _userName
})
.error(
...
)
.success(
...
);
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
15675 次 |
| 最近记录: |