我正在做一个简单的输入字段,并将表单中的数据提交给控制器,但始终会收到MethodNotAllowedHttpException。
blade.php
<form class="form-horizontal" method="post" action="sale/api">
<div class="form-group">
<label for="name" class="col-lg-2 control-label">
Subdomain Name
</label>
<div class="col-lg-10">
<input type="text" class="form-control" id="name" name="name">
</div>
</div>
<div class="form-group">
<label for="api_key" class="col-lg-2 control-label">
Api Key
</label>
<div class="col-lg-10">
<input type="api_key" class="form-control" id="api_key" name="api_key">
</div>
</div>
<div class="form-group">
<div class="col-lg-10 col-lg-offset-2">
<button type="submit" class="btn btn-primary">Save</button>
</div>
</div>
<input type="hidden" name="_token" value="{{ csrf_token() }}">
</form>
控制器
public function sync()
{
$input = Input::only('name','api_key');
$user = new Sale;
$user->name = $input['name'];
$user->api_key = $input['api_key'];
Debugbar::info($user->name);
}
路线
Route::post('sale/api','SaleController@sync');
答案 0 :(得分:1)
将您的route.php更新为
Route::post('/sale/api',array('as' => 'sale.api', 'uses' => 'SaleController@sync'));
将您的刀片更新为,
<form class="form-horizontal" method="post" action="{{route('sale.api')}}">
让我知道它是否有效。
答案 1 :(得分:0)
您的操作需要修改:
html:
<form class="form-horizontal" method="post" action="{{ route('sale.api') }}">
@csrf
<div class="form-group">
<label for="name" class="col-lg-2 control-label">
Subdomain Name
</label>
<div class="col-lg-10">
<input type="text" class="form-control" id="name" name="name">
</div>
</div>
<div class="form-group">
<label for="api_key" class="col-lg-2 control-label">
Api Key
</label>
<div class="col-lg-10">
<input type="api_key" class="form-control" id="api_key" name="api_key">
</div>
</div>
<div class="form-group">
<div class="col-lg-10 col-lg-offset-2">
<button type="submit" class="btn btn-primary">Save</button>
</div>
</div>
<input type="hidden" name="_token" value="{{ csrf_token() }}">
路线:
Route::post('/sale/api','SaleController@sync')->name(sale.api);
希望这会有所帮助! :)
答案 2 :(得分:0)
在表单中添加csrf字段。
<form class="form-horizontal" method="post" action="sale/api">
{{csrf_field()}}
Laravel将允许您在没有csrf令牌的情况下进行发布。
答案 3 :(得分:0)
像这样更新表格
<form class="form-horizontal" method="post" action="{{ url('sale/api')}}">