微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

获得响应时将 NULL 转换为空字符串

如何解决获得响应时将 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 举报,一经查实,本站将立刻删除。