php - 0 字段是必需的。 Laravel 5.5 验证错误

标签 php mysql laravel

我有一个“需要 0 字段”。当我没有名为 0 的字段时尝试将数据保存到数据库时出错。如果没有来自 Controller 的验证,数据会保存,但是如果我只验证我想要验证的六个字段中的一个字段,我仍然会收到错误消息。我该如何解决这个问题。请帮忙看看这是我的看法

<form method="post" action="{{ url('agent/add_tenantProperty') }}" data-toggle="validator">
                {{ csrf_field() }}
                <div class="row">
                  <div class="col-md-6">
                    <div class="form-group">
                      <label for="txtMovieTitle">Tenant</label>
                     <select id="ddlGenge" class="form-control" name="tenant_id" required="">
                       @foreach($tenants as $tenant)
                        <option value="{{ $tenant->id }}">
                          {{ $tenant->designation }} {{ $tenant->firstname }} {{ $tenant->lastname }}
                        </option>
                       @endforeach
                      </select>
                       <div class="help-block with-errors"></div>
                    </div>
                  </div>
                  <div class="col-md-6">
                    <div class="form-group">
                      <label for="ddlGenge">Asset Category</label>
                      <select id="ddlGenge" class="form-control" name="asset_id" required="">
                        <option>Choose a Property</option>
                        @foreach($assets as $asset)
                         <option value="{{ $asset->id }}">{{ $asset->category }}</option>
                        @endforeach
                      </select>
                       <div class="help-block with-errors"></div>
                    </div>
                  </div>
                </div>
                <div class="row">
                  <div class="col-md-6">
                    <div class="form-group">
                      <label for="txtDirector">Asset description</label>
                      <select id="ddlGenge" class="form-control" name="description" required="">
                        <option>Choose a Description</option>
                        @foreach($assets as $asset)
                          <option value="{{ $asset->description }}">{{ $asset->description }}</option>
                        @endforeach
                      </select>
                    <div class="help-block with-errors"></div>
                    </div>
                  </div>
                  <div class="col-md-6">
                    <div class="form-group">
                      <label for="txtProducer">Location</label>
                      <select id="ddlGenge" class="form-control" name="address" required="">
                        <option>Choose an Address</option>
                        @foreach($assets as $asset)
                          <option value="{{ $asset->address }}">{{ $asset->address }}</option>
                        @endforeach
                      </select>  
                    <div class="help-block with-errors"></div>
                    </div>
                  </div>
                </div>
                <div class="row">
                  <div class="col-md-6">
                    <div class="form-group">
                      <label for="txtWebsite">Standard price</label>
                      <input id="txtWebsite" type="text" class="form-control" name="price" required="">
                      <div class="help-block with-errors"></div>
                    </div>
                  </div>
                  <div class="col-md-6">
                    <div class="form-group">
                      <label for="txtWriter">Date</label>
                      <input id="txtWriter" type="date" class="datepicker form-control" name="occupation_date"
                             required="">
                    <div class="help-block with-errors"></div>
                    </div>
                  </div>
                </div>
                <button type="submit" class="btn btn-outline btn-primary pull-right">Submit</button>
                <br/>
              </form>

和我的 Controller

public function store(Request $request)
{
    //validation
    $this->validate($request, array([
        'tenant_id' => 'required',
        'asset_id' => 'required',
        'description' => 'required',
        'address' => 'required',
        'price' => 'required',
        'occupation_date' => 'required',
    ]));

    //create and save new data
    $tenantProperty = New TenantProperty();
    $tenantProperty->tenant_id = $request->tenant_id;
    $tenantProperty->asset_id = $request->asset_id;
    $tenantProperty->description = $request->description;
    $tenantProperty->address = $request->address;
    $tenantProperty->price = $request->price;
    $tenantProperty->occupation_date = $request->occupation_date;
    $tenantProperty->save();
    //redirect
    return redirect('agent/tenantProperty_list');
}

路线如下

 Route::get('add_tenantProperty', 'TenantPropertyController@create')->name('/add_tenantProperty');
Route::post('add_tenantProperty', 'TenantPropertyController@store');

最佳答案

当您只编写 $request 时,它会传递整个请求对象,但验证函数期望两个参数都是数组。

所以做一点改变,你就可以开始了:

$this->validate($request, array(  // Removed `[]` from the array.
    'tenant_id' => 'required',
    'asset_id' => 'required',
    'description' => 'required',
    'address' => 'required',
    'price' => 'required',
    'occupation_date' => 'required',
));

关于php - 0 字段是必需的。 Laravel 5.5 验证错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50811258/

相关文章:

php - 插入两行,获取第一行的 AI key 并应用于第二个插入。

php - 获取线程主题中多个用户的信息

mysql - 优化foreach内的sql查询

javascript - 操作 Json(传递到 View 之前)

laravel - 仅当表单值存在时才更新字段

php - 从 Codeigniter 中的两个大表检索数据的最佳查询

php - 我们应该或不应该在模型中使用参数吗?

php - php 中的 DELETE sql 语句不起作用

mysql - 使用两个外键连接两次表

php - Laravel .env 文件返回错误数据