在我的项目中,我使用$request->all()
获得参数。
但$request->all()
包括查询的东西。当我发布name => 1
到我的API 'domain.com/api/users'
var_dump $request->all()
例如:
[
'api/users' => null,
'name' => 1,
]
我想在我的每个'api/users'
中删除像$request->all()
。我该怎么办?
虽然我不能保证我完全理解这个问题,但根据我的理解,过滤掉未作为请求的一部分发送的字段,然后使用request()->only(['field', 'field_2'])
应该足够给定L5.5 upgrade notice中关于request->only
方法的实例:
这意味着给定我的示例,如果请求中不存在field_2
,则将其丢弃。
如果你在Laravel之前的5.5,那么$request->all()
将只给你现有的领域,否则L5.5你使用request->only()
你可以尝试一下,看看它们是如何工作的。
在Laravel <= 5.4和L5.5
最后,如果你仍然将这些字段设为null,那么你可以简单地使用array_filter($request_array)
,例如:
$request_only = $request->all();
$requests_without_null_fields = array_filter($request_only);
这将删除所有空字段,仅保留非空字段。
希望这很有用。
您可以使用“except”或“only”方法过滤请求数据。
$data = $request->except('key-that-you-dont-want-in-request');
// OR
$data = $request->only(['key-that-you-want-in-request', 'another-key']);
你可以在这里了解更多关于https://laravel.com/docs/5.5/requests#retrieving-input的信息
您可以收集传递给一个变量的所有请求参数,如下所示:
$data = $request->only(['name', 'other_request_variables']);
然后根据需要使用它。
编辑:
当您尝试更新模型时,您需要从视图中传递所有变量,即使旧数据未使用新数据更新,您需要传递表单中的所有数据,
在控制器中你可以做这样的事情:
$user = User::find($request->id);
获取所有数据并发送回表单中的视图,并在发送表单数据时,您需要发送所有数据:
$data = $request->(['id', 'name', 'city', 'address']);
$user = User::find($data['id']);
$user->name = $data['name'];
$user->city= $data['city'];
$user->address = $data['address'];
$user->save();
如果您未传递旧数据,则上面的代码将使用相同的null
值进行更新。
并且假设您不想使用空值更新,那么您不必调用它,假设您只调用name和id,那么只需编写:
$data = $request->(['id', 'name', 'city', 'address']);
$user = User::find($data['id']);
$user->name = $data['name'];
$user->save();
所以在这种情况下你的city
和address
将与旧数据相同,但在前端你不知道最终用户正在更新什么值,它可以是name
,city
或address
你必须为最终用户提供灵活性。
假设您要检查空值然后存储它,您可以执行以下操作:
$data = $request->(['id', 'name', 'city', 'address']);
$user = User::find($data['id']);
$user->name = $data['name']: $data['name'] ? $user->name;
$user->city= $data['city'] : $data['city'] ? $user->city;
$user->address = $data['address'] : $data['address'] ? $user->address;
$user->save();
但在这种情况下,您还必须使用所有参数进行更新。
从Laravel 5.5开始你也可以这样做:
$data = $request->except(array_keys($request->query()));
因为$request->query()
只返回一个查询参数的数组。