Лучший способ динамично установить appender путь к файлу

Пожалуйста, посмотрите timezone_offset_get , а также Список поддерживаемых часовых поясов в документации PHP.

Вот пример того, как достичь такого результата:

/**  Returns the offset from the origin timezone to the remote timezone, in seconds.
*    @param $remote_tz;
*    @param $origin_tz; If null the servers current timezone is used as the origin.
*    @return int;
*/
function get_timezone_offset($remote_tz, $origin_tz = null) {
    if($origin_tz === null) {
        if(!is_string($origin_tz = date_default_timezone_get())) {
            return false; // A UTC timestamp was returned -- bail out!
        }
    }
    $origin_dtz = new DateTimeZone($origin_tz);
    $remote_dtz = new DateTimeZone($remote_tz);
    $origin_dt = new DateTime("now", $origin_dtz);
    $remote_dt = new DateTime("now", $remote_dtz);
    $offset = $origin_dtz->getOffset($origin_dt) - $remote_dtz->getOffset($remote_dt);
    return $offset;
}

Примеры:

// This will calculate the difference. It returns 10800 (3 hours) ...
$offset = get_timezone_offset('America/Los_Angeles','America/New_York');
// or, if your server time is already set to 'America/New_York'...
$offset = get_timezone_offset('America/Los_Angeles');
// You can then take $offset and adjust your timestamp.
$offset_time = time() + $offset;

// To display the formatted time
echo date('Y-m-d h:m:s', $offset_time);

37
задан Community 23 May 2017 в 11:47
поделиться

1 ответ

Вы делаете это твердый путь! Определите свою конфигурацию log4net как XML в конфигурационном файле Вашего приложения и используйте %property{} для способствования:

<appender name="YourAppender" type="log4net.Appender.RollingFileAppender">
  <file type="log4net.Util.PatternString" value="~/App_Data/%property{LogName}" />
  ....
</appender>

Это динамично - просто необходимо установить log4net свойство "113" прежде , Вы инициализируете log4net. Таким образом в Вашем коде любое время перед конфигурированием log4net установило требуемое значение этого свойства:

string LogName = GetType().Assembly.GetName().Name + ".log";
log4net.GlobalContext.Properties["LogName"] = LogName;

, Конечно, можно использовать любое имя свойства. Я выбрал "LogName" для простого примера, но Вы можете иметь один на приложение, если Вы хотите, пока Ваш код знает то, что корректное имя свойства и каково правильное значение должно быть.

96
ответ дан Eddie 27 November 2019 в 04:08
поделиться
Другие вопросы по тегам:

Похожие вопросы: