获取响应时将 NULL 转换为空字符串
Convert NULL into empty string while getting response
我只想知道如何在从数据库获取结果时将 null 转换为空字符串。
例如
User::first();
在用户table中,卷号为空值。我想把它转换成空字符串。
是的,您可以在引导方法中使用这样检索到的观察器来执行此操作。
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
替换为 ""
时应用此中间件
我只想知道如何在从数据库获取结果时将 null 转换为空字符串。 例如
User::first();
在用户table中,卷号为空值。我想把它转换成空字符串。
是的,您可以在引导方法中使用这样检索到的观察器来执行此操作。
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
替换为 ""