本文介绍了时区中间件不工作的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我创建了一个中间件,以便根据数据库中设置的身份验证用户时区设置时区:

<?php

namespace AppHttpMiddleware;

use Closure;

class TimezoneMiddleware
{
    /**
     * Handle an incoming request.
     *
     * @param  IlluminateHttpRequest  $request
     * @param  Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        if ($request->user()->guest()) {
            $timezone = config('app.timezone');
        }
        else {
            $timezone = $request->user()->timezone;
        }

        date_default_timezone_set($timezone);

        return $next($request);
    }
}

我在Kernel.php中将此类添加到全局HTTP中间件声明的底部。

问题是它不起作用。显示created_at字段时,无论我在数据库中设置什么用户时区,时间都保持不变。

推荐答案

我强烈建议将您的日期保留在世界协调时的数据库中-这将为您以后的工作省去麻烦。

我建议使用Eloquent Mutators,它可以应用于您的模型。

这将使您仍然可以使用数据表,因为突变就在从数据库中提取数据之后发生。

您或许可以在您的应用程序中创建一个可重用的类,其中包含用于解析日期的静态方法,例如:

<?php

namespace App;

use CarbonCarbon;

class DateTimeZoneMutator
{

    public static function mutate($value)
    {

        if (auth()->user()->guest()) {
            $timezone = config('app.timezone');
        }
        else {
            $timezone = auth()->user()->timezone;
        }

        return new Carbon(
            $value, $timezone
        );

    }

}

然后在您的模型中,为了便于讨论,我们假设您的日期字段名为"REGISTERED_AT",您将添加以下方法:

<?php

namespace App;

use AppDateTimeZoneMutator;
use IlluminateDatabaseEloquentModel;

class Something extends Model
{

    // ...

    public function getRegisteredAtAttribute($value)
    {
        return DateTimeZoneMutator::mutate($value);
    }

    // ...

}

这篇关于时区中间件不工作的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

10-28 20:37