实体qazxsw poi存储在表qazxsw poi中
默认情况下,此表中的某些字段为null。
我需要更新这些字段并设置非空数据。
为此,我尝试在Laravel中使用User
方法:
路由:
Users
控制器:
PATCH
这是否意味着我可以传递任何数据进行更新?我应该将Route::patch('users/update', 'UsersController@update');
参数相对传递给路由和控制器吗?
如何在Laravel中使用PATCH方法的权限处理程序?
你的路线是:
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]);
}
使用以下用于所有CRUD操作的路径替换您的路由:
$id
如果您使用ajax提交数据,请将您的类型和网址替换为以下内容:
Route::patch('users/update', 'UsersController@update');
如果你不使用ajax而不是使用以下:
Route::resource('users', 'UsersController');
更新:在5.6版之后,您可以在任何刀片文件中使用以上函数的这些语法:
type: "patch",
url: "{{url('/')}}users/" + id,
按照以下更新路由
<form method="POST" action="{{route('users.update',['id' => $id])}}">
{{csrf_field()}}
{{ method_field('PATCH') }}
</form>
是的,您需要发送路由补丁的ID。来自<form method="POST" action="{{route('users.update',['id' => $id])}}>
@csrf
@method('PATCH')
</form>
的Laravel示例
PUT / PATCH - / photos / {photo},所以你的路线中不需要Route::patch('/users/update/{id}',[
'uses' => 'UsersController@update'
]);
字。只是用户/ id和方法PUT或PATCH。
UPD for CRUD操作:
https://laravel.com/docs/5.4/controllers#resource-controllers