我该如何处理laravel中的控制器资源

时间:2019-10-16 01:44:56

标签: laravel

我正在为控制器和路线使用资源工具,但是存储方法似乎不起作用。你能强调我做错了吗。控制器名称是否必须与模型名称相同?我很困惑

FarmController

<?php

namespace App\Http\Controllers;

use App\Animal;
use Auth;
use Illuminate\Http\Request;

class FarmController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */

    public function __construct()
    {
        $this->middleware('auth');
    }


    public function index()
    {
        $animal = Animal::all();
        return view('farms.index', compact('animal'));
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        $user = Auth::user();
        $animal = new Animal();
        return view('farms.create', compact('user', 'animal'));
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store()
    {
        Animal::create($this->validateRequest());


        return redirect('farms.show');
    }
    private function validateRequest()
    {
        return request()->validate([
            'dateOfBirth' => 'required|date',
            'placeOfBirth' => 'required',
            'gender' => 'required',
            'user_id' => 'required',
        ]);
    }

Animal.php(控制器)

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Animal extends Model
{
    protected $guarded = [];
    public function user(){
        return $this->belongsTo(User::class);
    }}

animals (table)

<?php

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;

class CreateAnimalsTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('animals', function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->unsignedBigInteger('user_id')->index();
            $table->date('dateOfBirth');
            $table->string('gender');
            $table->string('placeOfBirth');
            $table->timestamps();

            $table->foreign('user_id')->references('id')->on('users');
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('animals');
    }
}

create.blade.php

@extends('layouts.app')
@section('title', 'Add Animal')
@section('content')
    <div class="row">
        <div class="col-12">
            <h1>Farm</h1>
        </div>
    </div>
    <h3>Welcome {{ $user->name }} Please Add an animal</h3>
    <div class="row">
        <div class="col-12">
            <form action="{{ url('farms') }}" method="POST">
                <div class="form-group">
                    <label for="dateOfBirth">Date Of Birth: </label>
                    <input type="date" name="dateOfBirth" class="form-control" placeholder="dd/mm/yyyy">
                </div>
                <div class="pb-5">
                    {{ $errors->first('dateOfBirth') }}
                </div>
                <div class="form-group">
                    <label for="placeOfBirth">Place Of Birth</label>
                    <input type="text" name="placeOfBirth" class="form-control">
                </div>
                <div class="pb-5">
                    {{ $errors->first('placeOfBirth') }}
                </div>
                <div class="form-group">
                    <label for="gender">Gender: </label>
                    <select name="gender" class="form-control">
                        <option value="M">Male</option>
                        <option value="F">Female</option>
                    </select>
                </div>
                <div class="form-group">
                    <label for="user">User</label>
                    <select class="form-control" name="user">
                        <option value="{{ $user->id }}" name="user">{{ $user->name }}</option>
                    </select>
                </div>
                <button type="submit" class="btn btn-primary">Add Farm</button>

                @csrf
            </form>
        </div>
    </div>
@endsection

web.php(路由)

<?php

/*
|--------------------------------------------------------------------------
| Web Routes
|--------------------------------------------------------------------------
|
| Here is where you can register web routes for your application. These
| routes are loaded by the RouteServiceProvider within a group which
| contains the "web" middleware group. Now create something great!
|
*/

Route::get('/', function () {
    return view('welcome');
});

Auth::routes();

Route::middleware('admin')->group(function () {

    // All your admin routes go here.

    Route::resource('/admin', 'AdminController');
});

Route::middleware('farms')->group(function () {

    // All your admin routes go here.
    Route::resource('/farms', 'FarmController');
});

当我提交表单时,似乎只是刷新页面而不在表中添加任何内容。我已经整整两天坚持了这一点。欢迎任何帮助

2 个答案:

答案 0 :(得分:0)

validateRequest函数中,您拥有

'user_id' => 'required',

但是您视图中的表单没有名为user_id的字段

select元素被命名为user

<select class="form-control" name="user">
  <option value="{{ $user->id }}" name="user">{{ $user->name }}</option>
</select>

更改其中之一以便它们可以匹配,我想页面刷新只是验证失败

您可能要检查视图中的任何验证错误,以根据the docs

找出问题所在

例如

@if ($errors->any())
    <div class="alert alert-danger">
        <ul>
            @foreach ($errors->all() as $error)
                <li>{{ $error }}</li>
            @endforeach
        </ul>
    </div>
@endif

希望这会有所帮助

答案 1 :(得分:0)

只需更改表单动作,然后按正确的方法即可。这是您表单的操作

{{route('farms.store')}}