php - Laravel 7无法删除,重定向到主页而不是控制器重定向
问题描述
我有一个名为 vendor 的经过身份验证的用户,我可以添加、更新业务。但是,当我尝试删除一个条目时,它会重定向到主页,而不是我在控制器中指定的重定向。我不确定这是否与我设置中间件的方式有关,但最后,它给了我中间件中身份验证失败的消息,即“您无权访问管理员”仪表板”。我确定我在中间件或控制器中做错了什么。我应该提一下,对于超级管理员来说,这个中间件工作正常。也就是说,管理员可以屏蔽和取消屏蔽用户,查看所有进入的业务。这是以下代码。
供应商中间件.php
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Support\Facades\Auth;
class VendorMiddleware
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
if (Auth::user()->role_as == 'vendor') {
if (Auth::check() && Auth::user()->isBanned) {
$banned = Auth::user()->isBanned == "1";
Auth::logout();
if ($banned == 1) {
$message = 'Your account has been Banned. Please contact the administrator.';
}
return redirect()->route('login')->with('status', $message)->withErrors(['email' => 'Your account has been Banned. Please contact the administrator.']);
}
return $next($request);
} else {
return redirect('/home')->with('status', 'You are not permitted to access the vendor dashboard');
}
}
}
我的资源 vendorEmpresaController.php 中的销毁函数
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy($id)
{
$empresa = Empresa::find($id);
if ($empresa != null) {
$empresa->delete();
return redirect('/vendor-empresas')->with('status', 'Empresa Borrado Exitosamente.');
// return redirect()->to('/vendor-empresas')->with('status', 'Empresa Borrado Exitosamente.');
}
return redirect('/vendor-empresas')->with('status', 'ID Equivocado! La empresa no fue borrado.');
}
表单和模式所在的 index.blade.php
@extends('layouts.vendor-admin')
@section('content')
<!-- Start delete modal-->
<div class="modal fade" id="deleteModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel"
aria-hidden="true">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header text-center">
<h4 class="modal-title w-100 font-weight-bold">Borrar</h4>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
</div>
<form action="vendor-empresas/{vendor_empresa}" method="POST" id="deleteForm">
{{ csrf_field() }}
{{ method_field('DELETE') }}
<div class="modal-body mx-3">
<input type="hidden" name="_method" value="DELETE">
<div class="text-center">
<i class="fas fa-exclamation-triangle mb-4" style="color: #ffc107; font-size: 32px;"></i>
</div>
<h3 class="text-center text-uppercase">¿Estás Seguro/a?
</h3>
</div>
<div class="modal-footer d-flex justify-content-center">
<button class="btn btn-primary" data-dismiss="modal">Cancelar</button>
<button type="submit" class="btn btn-danger">Sí, Borralo!</button>
</div>
</form>
</div>
</div>
</div>
<!--end delete modal-->
<div class="container-fluid mt-5">
<!-- Heading -->
<div class="card mb-4 wow fadeIn">
<!--Card content-->
<div class="card-body d-sm-flex justify-content-between">
<h4 class="mb-2 mb-sm-0 pt-1">
<a href="/">Inicio</a>
<span>/</span>
<span>Empresas Registradas</span>
</h4>
@if (session('status'))
<div class="alert alert-success fade-message" role="alert">
{{ session('status') }}
</div>
@endif
<div class="modal fade" id="modalRegisterForm" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header text-center">
<h4 class="modal-title w-100 font-weight-bold">Añadir Empresa</h4>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
</div>
<form action="/vendor-empresas" method="POST">
{{ csrf_field() }}
<div class="modal-body mx-3">
<div class="md-form mb-1">
<input type="text" name="erfc" id="orangeForm-erfc" class="form-control validate">
<label data-error="wrong" data-success="right" for="orangeForm-erfc">RFC</label>
</div>
<div class="md-form mb-1">
<input type="text" name="enombre" id="orangeForm-enombre" class="form-control validate">
<label data-error="wrong" data-success="right" for="orangeForm-enombre">Nombre</label>
</div>
<div class="md-form mb-1">
<input type="text" name="ecalle" id="orangeForm-ecalle" class="form-control validate">
<label data-error="wrong" data-success="right" for="orangeForm-ecalle">Calle</label>
</div>
<div class="md-form mb-1">
<input type="text" name="ecolonia" id="orangeForm-ecolonia" class="form-control validate">
<label data-error="wrong" data-success="right" for="orangeForm-ecolonia">Colonia</label>
</div>
<div class="md-form mb-1">
<input type="text" name="eciudad" id="orangeForm-eciudad" class="form-control validate">
<label data-error="wrong" data-success="right" for="orangeForm-eciudad">Ciudad</label>
</div>
<div class="md-form mb-1">
<input type="text" name="eestado" id="orangeForm-eestado" class="form-control validate">
<label data-error="wrong" data-success="right" for="orangeForm-eestado">Estado</label>
</div>
<div class="md-form mb-1">
<input type="text" name="ecpostal" id="orangeForm-ecpostal" class="form-control validate">
<label data-error="wrong" data-success="right" for="orangeForm-ecpostal">Codigo Postal</label>
</div>
<div class="md-form mb-1">
<input type="text" name="epais" id="orangeForm-epais" class="form-control validate">
<label data-error="wrong" data-success="right" for="orangeForm-epais">País</label>
</div>
<div style="display: none;" class="md-form mb-1">
<input type="text" name="user_id" readonly id="orangeForm-euser" class="form-control validate" value="{{ Auth::user()->id }}">
</div>
<div style="display: none;" class="md-form mb-1">
<input type="text" name="eregby" readonly id="orangeForm-eregby" class="form-control validate" value="{{ Auth::user()->id }}">
</div>
</div>
<div class="modal-footer d-flex justify-content-center">
<button type="submit" class="btn btn-deep-orange">Añadir</button>
</div>
</form>
</div>
</div>
</div>
<div class="text-center">
<a href="" class="btn btn-default btn-rounded mb-4" data-toggle="modal" data-target="#modalRegisterForm"><i class="fa fa-plus" aria-hidden="true"></i> Añadir</a>
</div>
</div>
</div>
<!-- Heading -->
<!--Grid row-->
<!--Grid column-->
<div class="row">
<!--Card-->
<div class="col-md-12 mb-4">
<!--Card content-->
<div class="card">
<!-- List group links -->
<div class="card-body">
<div class="table-responsive">
<table id="datatable2" class="table table-bordered">
<thead>
<tr>
<th style="display: none;">ID</th>
<th>RFC</th>
<th>Nombre</th>
<th>Calle</th>
<th>Colonia</th>
<th>Ciudad</th>
<th>Estado</th>
<th>Codigo Postal</th>
<th>País</th>
<th>Acción</th>
</tr>
</thead>
<tbody>
@foreach ($empresas as $empresa)
<tr>
<input type="hidden" name="id" value="{{ $empresa->id }}">
<td style="display: none;">{{ $empresa->id }}</td>
<td>{{ $empresa->erfc }}</td>
<td>{{ $empresa->enombre }}</td>
<td>{{ $empresa->ecalle }}</td>
<td>{{ $empresa->ecolonia }}</td>
<td>{{ $empresa->eciudad }}</td>
<td>{{ $empresa->eestado }}</td>
<td>{{ $empresa->ecpostal }}</td>
<td>{{ $empresa->epais }}</td>
<td>
<div class="text-center">
<a class="badge badge-pill btn-primary px-3 py-2" href="{{ url('vendor-empresas/'.$empresa->id).'/edit' }}">Editar</a>
<a class="delete badge badge-pill btn-danger px-3 py-2">Borrar</a>
</div>
</td>
</tr>
@endforeach
</tbody>
</table>
</div>
</div>
<!-- List group links -->
</div>
</div>
<!--/.Card-->
</div>
<!--Grid row-->
</div>
@endsection
@section('scripts')
<script>
$(document).ready(function() {
let table = $('#datatable2').DataTable();
// Start Delete Record
table.on('click', '.delete', function() {
$tr = $(this).closest('tr');
if($($tr).hasClass('child')) {
$tr = $tr.prev('.parent')
}
let data = table.row($tr).data();
console.log(data);
$('#deleteForm').attr('action', '/delete-empresa/'+data[0]);
$('#deleteModal').modal('show');
});
// End Delete Record
});
</script>
<script>
$(document).ready(function($) {
$(function() {
setTimeout(function() {
$('.fade-message').slideUp();
}, 3000);
});
});
</script>
@endsection
提前感谢您提供的任何帮助。
编辑:我已经尝试过 EmpresaPolicy.php 并且无论有没有@can 都没有任何运气。我有 @can('delete', $empresa) @endcan 但它说变量 $empresa 未定义。所以,在 EmpresaPolicy.php 中,我有:
public function delete(User $user, Empresa $empresa)
{
return true;
}
在我的 AuthServiceProvider 中,我有:
protected $policies = [
'App\Empresa' => 'App\Policies\EmpresaPolicy',
];
I tried this in my vendorEmpresasController.php
public function destroy($id)
{
$empresa = Empresa::find($id);
$this->authorizeResource(Empresa::class, 'delete', $empresa);
if ($empresa != null) {
$empresa->delete();
return redirect('/vendor-empresas')->with('status', 'Empresa Borrado Exitosamente.');
// return redirect()->to('/vendor-empresas')->with('status', 'Empresa Borrado Exitosamente.');
} else {
return redirect('/vendor-empresas')->with('status', 'ID Equivocado! La empresa no fue borrado.');
}
}
最后,在我的 web.php 中,我有:
Route::delete('/vendor-empresas/{vendor_empresa}', 'vendorEmpresaController@destroy');
当我想被重定向到 /vendor-empresas 时,我仍然会被重定向回首页。感谢任何帮助。谢谢你。 编辑 #2 这是 vendormiddleware.php 的 dd 输出
解决方案
发现了问题。第一,在我的 web.php 文件中,我需要保持我的供应商和管理员组以及他们的透视路由隔离。这是它现在的样子:
<?php
use Illuminate\Support\Facades\Route;
use Illuminate\Support\Facades\Auth;
Route::get('/', function () {
return view('frontend.index');
});
Auth::routes();
Route::group(['middleware' => ['auth', 'isUser']], function () {
Route::get('/home', 'HomeController@index')->name('home');
});
Route::group(['middleware' => ['auth', 'isAdmin']], function () {
Route::get('/dashboard', function () {
return view('admin.dashboard');
});
// Usuarios
Route::get('registered-user', 'Admin\RegisteredController@index');
Route::delete('/user-delete/{id}', 'Admin\RegisteredController@destroy');
Route::get('role-edit/{id}', 'Admin\RegisteredController@edit');
Route::put('role-update/{id}', 'Admin\RegisteredController@updaterole');
// Empresas
Route::get('registered-empresa', 'Admin\EmpresaController@index');
Route::post('save-empresa', 'Admin\EmpresaController@store');
Route::get('/edit-empresa/{id}', 'Admin\EmpresaController@edit');
Route::put('/empresa-update/{id}', 'Admin\EmpresaController@update');
Route::delete('/delete-empresa/{id}', 'Admin\EmpresaController@destroy');
// Empleados
Route::get('registered-empleado', 'Admin\EmpleadoController@index');
Route::get('/edit-empleado/{id}', 'Admin\EmpleadoController@edit');
Route::put('/empleado-update/{id}', 'Admin\EmpleadoController@update');
Route::post('save-empleado', 'Admin\EmpleadoController@store');
Route::delete('/delete-empleado/{id}', 'Admin\EmpleadoController@destroy');
});
Route::group(['middleware' => ['auth', 'isVendor']], function () {
Route::get('/vendor-dashboard', function () {
return view('vendor.dashboard');
});
Route::resource('vendor-empresas', 'vendorEmpresaController');
Route::resource('vendor-empleados', 'vendorEmpleadoController');
Route::delete('/vendor-empresas/{vendor_empresa}', 'vendorEmpresaController@destroy');
});
第二:在我的供应商索引中,我调用的是管理员删除功能,而不是 VendorEmpresaController 中的供应商删除功能。这是现在的代码:
@section('scripts')
<script>
$(document).ready(function() {
let table = $('#datatable2').DataTable();
// Start Delete Record
table.on('click', '.delete', function() {
$tr = $(this).closest('tr');
if($($tr).hasClass('child')) {
$tr = $tr.prev('.parent')
}
let data = table.row($tr).data();
console.log(data);
$('#deleteForm').attr('action', '/vendor-empresas/'+data[0]);
$('#deleteModal').modal('show');
});
// End Delete Record
});
</script>
<script>
$(document).ready(function($) {
$(function() {
setTimeout(function() {
$('.fade-message').slideUp();
}, 3000);
});
});
</script>
@endsection
这是位于 Vendor 文件夹中 vendorEmpressaController 中的控制器代码:
public function destroy($id)
{
$empresa = Empresa::find($id);
if ($empresa != null) {
$empresa->delete();
return redirect('/vendor-empresas')->with('status', 'Empresa Borrado Exitosamente.');
// return redirect()->to('/vendor-empresas')->with('status', 'Empresa Borrado Exitosamente.');
} else {
return redirect('/vendor-empresas')->with('status', 'ID Equivocado! La empresa no fue borrado.');
}
}
我希望这可以帮助有同样问题的人。干杯。
推荐阅读
- matlab - 如何在不使用交错/整形方法的情况下在 Matlab 中读取复杂的 3D 矩阵(二进制文件)?
- c++ - cpp中的随机数组
- typescript - 如何从打字稿中的数组中获取键
- java - Redisson 客户端 setnx
- .net-core - 找出 Newtonsoft 无法解析字符串的位置和原因
- java - 使用 OpenSAML 3 的 SAML 断言验证
- java - 圆形动画 - JavaFX
- tensorflow-datasets - 可重新初始化的迭代器解决了什么问题?
- scheme - Scheme中的斐波那契数列流
- python-3.x - 如何在品脱中转换频率和周期?