获取响应时将 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 替换为 ""

时应用此中间件