将数据从表单发布到控制器时,MethodNotAllowedHttpException

时间:2019-01-28 08:56:38

标签: php laravel laravel-4

我正在做一个简单的输入字段,并将表单中的数据提交给控制器,但始终会收到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');

4 个答案:

答案 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')}}">