Форма Laravel не работает, она перенаправляет на мою домашнюю страницу - PullRequest
0 голосов
/ 26 июня 2018

пожалуйста, у меня есть эта форма, которая не отправляется, она перенаправляет на домашнюю страницу, и я проверяю свой контроллер, но нет ничего перенаправляющего на домашнюю страницу, как ни странно, у меня есть две формы на этой странице: первая отправляет, вторая - нет Пожалуйста, помогите мне

вот мой код, код для первой формы

<form class="form-horizontal" role="form" action="" method="post" id="form1" enctype="multipart/form-data">

      <div class="col-md-4"> 
        <a class="btn btn-warning btn-sm" href="{{ URL::previous() }}">Back</a><br>
          @php 
          $getBalance = (int) $getBalance; 
          $old = (int) old('totalamount');
          @endphp        
            <label class="control-label"><small>Enter Sum Total Amount if making part payment</small></label>
            <input type="text" class="form-control" readonly id="totalamount" value="{{number_format(($getBalance) ? $getBalance : $old)}}" name="totalamount" placeholder="Enter total amount (Optional)" >
            <input type="hidden" name="selectedid" value="{{ $selected }}">
        </div>

        <div class="col-md-4">           
            <label class="control-label">&nbsp&nbsp</label><br>

            <button  class="btn btn-info btn-xs " onclick="return viewInstruct('{{$instructions}}')" >Read Instruction</button>
            @php
            $path = base_path('../'). env('UPLOAD_PATH', '') .'/' . $sel_id.'.'.$file_ex;
        @endphp

            @if($sel_id != "")                    
            @if(file_exists($path))
                  <a class="btn btn-primary btn-xs " target="blank" href="/pro/file/{{$sel_id.'.'.$file_ex}}" >Download file</a>
                @endif
            @endif
        </div>

        <div class="col-md-4">          
            <label class="control-label">Contract type</label>
            <input type="text" id="contracttype1" name="contracttype1" value="{{($staticcontr->contractType) ? $staticcontr->contractType : old('contracttype1')}}" readonly=""  class="form-control">
        </div>


      <div class="col-md-4">          
            <label class="control-label">Allocation type</label>
            @if($economicCode_as !== "")
            <input type="text"  class="form-control"  readonly value="{{ $econ3 }}" >
            <input type="hidden" class="form-control" id="allocationtype1" name="allocationtype1" placeholder="" readonly value="{{ $alloc5 }}" >
            @else
            <select onchange="return getEconomics()" class="form-control" id="allocationtype1" name="allocationtype1" placeholder="" {{ ($economicCode_as == "") ? "" : "readonly" }}>
              <option value="">Select Allocation</option>
              @foreach($allocationlist as $list)
                <option value="{{$list->ID}}" {{($list->ID == $alloc1 || $list->ID == old('allocationtype1')) ? "selected" : ""}}>{{$list->allocation}}</option>
              @endforeach
            </select>
            @endif
        </div>


        <div class="col-md-4">          
            <label class="control-label">Economic code</label>
            @if($economicCode_as !== "")
              <input type="text"  class="form-control"  readonly value="{{ $econ3 }}" >
              <input type="hidden" name="economicCode1" id="economicCode1" class="form-control"  readonly value="{{ $economicCode_as }}" >
            @else
            <select name="economicCode1" id="economicCode1" class="form-control" >
              <option >Select Economic Code</option>
              @foreach($econocode as $list)
              <option  value="{{ $list->ID }}" {{ ($list->ID == old('economicCode1') || $list->ID == $economiccode1) ? "selected" : "" }}>({{$list->description }}) {{$list->economicCode}}</option>
              @endforeach
              </select>
            @endif

        </div>

</form>

вот маршрут

Route::get('/voucher/continue',                                 'CreateContractVoucherController@continu');
Route::post('/voucher/continue',                                'CreateContractVoucherController@continu');

и контроллер

public function continu(Request $request)
                            'contractTypeID'        => $tblcontracttype,
                                'contractID'            => $tblcontractid,
                                'companyID'         => $tblcompanyid,
                                'PVNO'              => $pvno,
                                'totalPayment'          => $tbltotalpayment,
                                'paymentDescription'        => $narration,
                                'VAT'               => $vatperc,
                                'VATValue'          => $vat,
                                'WHT'               => $whtselect,
                                'WHTValue'          => $wht,
                                'VATPayeeID'            => $tblvatpayeeid,
                                'WHTPayeeID'            => $tblwhtpayeeid,
                                'amtPayable'            => $tblamtPayable,
                                'preparedBy'            => $tblprepareby,
                                'liabilityBy'           => $liabilityby,
                                'allocationType'        => $allocationtype,
                                'economicCodeID'        => $economiccodeid,
                                'status'                => 0,
                                'datePrepared'          => $dateprepared,
                                'period'        => $this->ActivePeriod()                                
                            ])){
                                //$data['success'] = "Voucher was edited successfully!";
                                //$vid = DB::table('tblpaymentTransaction')->where('PVNO', $pvno)->first()->ID;

                                if(DB::table('tblcontractDetails')->where('ID', $tblcontractid)->first()->paymentStatus == ""){
                                    DB::table('tblcontractDetails')->where('ID', $tblcontractid)->update([
                                        'paymentStatus' => 0
                                    ]);
                                }
                                if(DB::table('tblcontractDetails')->where('ID', $tblcontractid)->first()->economicVoult == ""){
                                    DB::table('tblcontractDetails')->where('ID', $tblcontractid)->update([
                                        'economicVoult' => $economiccodeid
                                    ]);
                                }
return view('continue', $data);
}

Ответы [ 2 ]

0 голосов
/ 26 июня 2018

Вам необходимо защитить приложение от подделки межсайтовых запросов.

У Laravel есть простой способ сделать это.

Если вы используете Laravel 5.4, просто добавьте {{ csrf_field() }} в форму.

<form method="POST" action="/profile">
    {{ csrf_field() }}
    ...
</form>

Если вы используете Laravel 5.6+, вы можете использовать @csrf

<form method="POST" action="/profile">
    @csrf
    ...
</form>

Laravel 5.4 - https://laravel.com/docs/5.4/csrf

Laravel 5.6 - https://laravel.com/docs/5.6/csrf

0 голосов
/ 26 июня 2018

просмотрев вашу форму и изучив вашу жалобу, становится ясно, что вы не добавили поле csrf_field

добавьте эту строку в форму

{{ csrf_field() }}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...