HTML blade部分
php
<meta name="_token" content="{{ csrf_token() }}"/>
前端js請求部分(注意那個header屬性,是爲了不跨站僞造請求攻擊寫的)
前端
$.ajax({ type: 'POST', url: '/ajax/create', data: { date : '2015-03-12'}, dataType: 'json', headers: { 'X-CSRF-TOKEN': $('meta[name="_token"]').attr('content') }, success: function(data){ console.log(data.status); }, error: function(xhr, type){ alert('Ajax error!') } });
路由部分route.php(ajax/create路由打到Controllers/Ajax/PollController.php的store方法上處理)ajax
Route::group(['prefix' => 'ajax', 'namespace' => 'Ajax'], function(){ Route::post('create', 'PollController@store'); });
控制器方法PollController.php,json
<?php namespace App\Http\Controllers\Ajax; use App\Http\Requests; use App\Http\Controllers\Controller; use Illuminate\Http\Request; use Illuminate\Http\Response; use App\Poll; // 用數據模型 use Redirect, Input, Auth, Log; class PollController extends Controller { public function store(Request $request) { $poll = new Poll; $poll->date = Input::get('date'); if ($poll->save()) { return response()->json(array( 'status' => 1 'msg' => 'ok', )); } else { return Redirect::back()->withInput()->withErrors('保存失敗!'); } } }