Laravel唯一的组合验证规则



我正在尝试对两个属性的唯一组合制定验证规则。Etudiant只能选择一次Theme。我做了一个表etudiantsChoixThemes,该表记录了不同的选择。这是etudiantsChoixThemes的表结构:

<?php
use IlluminateSupportFacadesSchema;
use IlluminateDatabaseSchemaBlueprint;
use IlluminateDatabaseMigrationsMigration;
class CreateEtudiantsChoixThemesTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('etudiantsChoixThemes', function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->integer('idEtudiant');
            $table->integer('idThematique');
            $table->string('description');
            $table->string('outils');
            $table->timestamps();
        });
    }
    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('etudiantsChoixThemes');
    }
}

studentChooseTheme刀片视图我可以在其中选择etudiant

的当前登录
@extends('layouts.layout')
@section('content')
<body>
{{$theme->intitule}} {{$theme->categorie}}
<div class="container_fluid">
<div class="row">
<div class="alert alert-danger print-error-msg" style="display: none;">
<ul></ul>
</div>
<div class="alert alert-success print-success-msg" style="display: none;">
<center></center>
</div>
</div>
</div>
<form method="post" action=" {{route('registerThemeChoice', $theme->id)}} ">
    @csrf
    <fieldset>Comment comprenez-vous la thématique proposée</fieldset>
    <input type="hidden" name="idEtudiant" value=" {{Auth::guard('web')->user()->id}} ">
    <input type="hidden" name="idThematique" value=" {{$theme->id}} ">
    <textarea name="description" required> {{old('description')}} </textarea>
    <fieldset>Quels outils comptez-vous utiliser pour mener à bien le projet?</fieldset>
    <textarea name="outils" required> {{old('outils')}} </textarea>
    <input class="button-info" type="submit" name="submit" id="submit" value="Valider">
</form>
    <a  href=" {{url('themes/' .$theme->id)}} "><button class="button-danger">Annuler</button></a>
</body>
@jquery
<script type="text/javascript">
    $(function(){
        $('#submit').on('click', function(e){
            e.preventDefault();
            var _token = $("input[name='_token']").val();
            var idEtudiant = $('input[name=idEtudiant]').val();
            var idThematique = $('input[name=idThematique]').val();
            var description = $('textarea[name=description]').val();
            var outils = $('textarea[name=outils]').val();
                $.ajax({
                    url: "{{route('registerThemeChoice',$theme->id)}}",
                    type: 'POST',
                    data: {
                        _token:_token,
                        idEtudiant:idEtudiant,
                        idThematique:idThematique,
                        description:description,
                        outils:outils
                    },
                    success: function(data){
                        if($.isEmptyObject(data.error)){
                            // alert(data.success);
                            $('.print-error-msg').css('display','none');
                            toastr.success(" Votre choix est enregistré ");
                        }
                        else{
                            // console.log(data.error);
                            printErrorMsg(data.error);
                        }
                    }
                });

        function printErrorMsg (msg) {
            $(".print-error-msg").find("ul").html('');
            $(".print-error-msg").css('display','block');
            $.each( msg, function( key, value ) {
                $(".print-error-msg").find("ul").append('<li>'+value+'</li>');
            });
        }
        });
    });
</script>
@endsection

这是studentChooseThemeController

<?php
namespace AppHttpControllers;
use IlluminateHttpRequest;
use AppTheme;
use AppEtudiantsChoixTheme;
use IlluminateSupportFacadesValidator;
use IlluminateValidationRule;
class studentChooseThemeController extends Controller
{
    public function index($id){
        $theme = Theme::findOrFail($id);
        return view('studentChooseTheme', ['theme' => $theme]);
    }
    public function etudiantChoixTheme(Request $request, $id){
        // $theme = Theme::findOrFail($id);
        $validator = Validator::make($request->all(),[
            'description' => 'required',
            'outils' => 'required',
            'idThematique' => Rule::unique('etudiantsChoixThemes')->where(function ($query) use($idEtudiant, $idThematique) {
                return $query->where('idEtudiant', $idEtudiant)
                ->where('idThematique', $idThematique);
            }),
        ]);
        if ($validator->fails()) {
        return response()->json(['error'=>$validator->errors()->all()]);
        }
        $etudiantChoixTheme = new EtudiantsChoixTheme;
        $etudiantChoixTheme->idEtudiant = $request->input('idEtudiant');
        $etudiantChoixTheme->idThematique = $request->input('idThematique');
        $etudiantChoixTheme->description = $request->input('description');
        $etudiantChoixTheme->outils = $request->input('outils');
        $etudiantChoixTheme->save();
    }
}

我正在用ajax提交,它可以很好地适合Ajax部分。我的问题是验证。如上所述,我希望在idEtudiantidThematique上有一个唯一的规则:Etudiant只能选择一次Theme,因此数据库中的idEtudiantidThematique的唯一组合。

我在这里找到了一些东西,并像您在idThematique的控制器代码中所看到的那样应用了它。但是我没有得到预期的结果。

我也尝试过:

$validator = Validator::make($request->all(),[
            'description' => 'required',
            'outils' => 'required',
            'idThematique' =>'unique:etudiantsChoixThemes,idThematique,'.$this->id.',NULL,id,idEtudiant'. $request->input('idEtudiant'),
        ]);

和此:

        $validator = Validator::make($request->all(),[
            'description' => 'required',
            'outils' => 'required',
            'idThematique' =>'unique:etudiantsChoixThemes,idThematique,NULL,id,idEtudiant'. $request->input('idEtudiant'),
        ]);

unique组合仍然可以多次记录。另外,我注意到上面的最后两个代码块,验证不再起作用(对于required零件(。我在这里错过了什么吗?您的帮助将非常欢迎。我正在使用Laravel 5.8

你快到了。

未设置变量$idEtudiant$idThematique传递到where()功能。

这应该有效:

'idThematique' => Rule::unique('etudiantsChoixThemes')->where(function ($query) {
                return $query->where('idEtudiant', request('idEtudiant'))
                    ->where('idThematique', request('idThematique'));
            })

最新更新