表User
Users
默认情况下,此表中的某些字段为null。
我需要更新这些字段并设置非空数据。
为此,我尝试在Laravel中使用PATCH
方法:
路由:
Route::patch('users/update', 'UsersController@update');
控制器:
public function update(Request $request, $id)
{
$validator = Validator::make($request->all(), [
"name" => 'required|string|min:3|max:50',
"email_work" => 'email|max:255|unique:users',
"surname" => 'required|string|min:3|max:50',
"tel" => 'required|numeric|size:11',
"country" => 'required|integer',
"region" => 'required|integer',
"city" => 'required|integer'
]);
if ($validator->fails()) {
return response()->json(["message" => $validator->errors()->all()], 400);
}
$user = User::where("user_id", $id)->update([
"name" => $request->name,
"surname" => $request->surname,
"tel" => $request->tel,
"country" => $request->country,
"city" => $request->city,
"region" => $request->region,
"email_work" => $request->email
]);
return response()->json(["user" => $user]);
}
这是否意味着我可以传递任何数据进行更新?
我应该将$id
参数相对地传递给路由和控制器吗?
如何在Laravel中使用PATCH方法的权限处理程序?
答案 0 :(得分:31)
你的路线是:
Route::patch('users/update', 'UsersController@update');
使用以下用于所有CRUD操作的路线替换您的路线:
Route::resource('users', 'UsersController');
如果您使用ajax提交数据,请将您的类型和网址替换为以下内容:
type: "patch",
url: "{{url('/')}}users/" + id,
如果您不使用ajax而不是使用以下内容:
<form method="POST" action="{{route('users.update',['id' => $id])}}">
{{csrf_field()}}
{{ method_field('PATCH') }}
</form>
在版本5.6之后更新,您可以在任何刀片文件中使用以上函数的这些语法:
<form method="POST" action="{{route('users.update',['id' => $id])}}>
@csrf
@method('PATCH')
</form>
答案 1 :(得分:2)
是的,您需要发送路由补丁的ID。 Laravel的https://laravel.com/docs/5.4/controllers#resource-controllers示例
PUT / PATCH - / photos / {photo},因此您的路线中不需要update
字。只是用户/ id和方法PUT或PATCH。
CRUD操作的UPD:
// Routes
Route::resource('items', 'ItemsController');
// Form for update item with id=1
<form method="POST" action="{{ route('items.update', ['id' => 1])}}">
{!! csrf_field() !!}
<input name="_method" type="hidden" value="PATCH">
<!-- Your fields here -->
</form>
// Controller
public function update($id, Request $request)
{
// Validation here
$item = Item::findOrFail($id);
// Update here
}
答案 2 :(得分:1)
按照以下
更新路由Route::patch('/users/update/{id}',[
'uses' => 'UsersController@update'
]);
答案 3 :(得分:-2)
<form method="POST" action="{{url('admin/forms',['id' => $form->domain_id])}}">
@csrf
@method('PATCH')
路线:
Route::resources([
'forms' => FormsController::class,
]);