如何解决获得响应时将 NULL 转换为空字符串
我只是想在从db获取结果的同时如何将null转换为空字符串。 例如
User::first();
在用户表中,卷号为空值。我希望它转换为空字符串。
解决方法
是的,您可以在引导方法中使用检索到的观察者来执行此操作。
self::retrieved(function ($model) {
$keys = $model->fillable;
foreach ($keys as $key => $value) {
$model->attributes[$value] = @$model->attributes[$value] == null ? '' : $model->attributes[$value];
}
});
,
我有同样的任务,我通过中间件解决了这个问题
创建NullToBlank.php
中间件
<?php
namespace App\Http\Middleware;
use Closure;
class NullToBlank
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request,Closure $next)
{
$output = $next($request);
if ($output) {
$json = $output->content();
$modelAsArray = json_decode($json,true);
if (is_array($modelAsArray)) {
array_walk_recursive($modelAsArray,function (&$item,$key) {
$item = $item === null ? '' : $item;
});
return response($modelAsArray);
} else {
return $next($request);
}
}
}
}
然后在需要将 NULL
替换为 ""
时应用此中间件
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。