有实体 User
在表 Users
此表中的某些字段默认为空。
我需要更新这些字段并设置非空数据。
为此,我尝试在 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 方法使用正确的处理程序?
原文由 Darama 发布,翻译遵循 CC BY-SA 4.0 许可协议
如果您的路线是:
如果您使用
jQuery.ajax()
来提交数据,请像这样设置您的方法、数据和 URL:如果您不使用 Ajax,请使用以下内容: