thinkphp5日志文件权限的问题

由于www用户和root用户(比如command的cli进程日志)都有可能对log文件进行读写。

如果是由www用户创建的log文件,不会出任何问题。

但是如果是先由root用户创建的log文件,然后再到www用户角色去写,就会出问题了

因为一般默认创建的log文件的权限是  -rw-r--r-

也就是www没有权限去写入root用户创建的log文件。

网上的方法大体就是像下面代码一样在mkdir的时候修改目录的权限 

//thinkphp/library/think/log/driver/File.php
$destination = $this->getMasterLogFile();
 
$path = dirname($destination);
if (PHP_SAPI != 'cli') {
     !is_dir($path) && mkdir($path, 0755, true);
}else{
     !is_dir($path) && mkdir($path, 0777, true) && chmod($path, 0777);
}

但是上面只能修改文件夹的权限,并没有修改文件夹下具体的.log文件的权限。

【解决办法】:

修改文件:\thinkphp\library\think\log\driver\File.php里的write()函数

protected function write($message, $destination, $apart = false, $append = false)
    {
        ...
        if (PHP_SAPI == 'cli') {
            $message = $this->parseCliLog($info);
        } else {
            // 添加调试日志
            $this->getDebugLog($info, $append, $apart);

            $message = $this->parseLog($info);
        }

        //return error_log($message, 3, $destination);

        /** 解决root生成的文件,www用户没有写权限的问题 by WbHuang 20190704 begin */
        if (!is_file($destination)) {
            $first = true;
        }

        $ret = error_log($message, 3, $destination);

        try {
            if (isset($first) && is_file($destination)) {
                chmod($destination, 0777);
                unset($first);
            }
        } catch (\Exception $e) { }
        return $ret;
        /** 解决root生成的文件,www用户没有写权限的问题 by WbHuang 20190704 end */
        ...
    }

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对于 ThinkPHP5 的跨域问题,你可以尝试以下几种解决方案: 1. 在应用配置中设置跨域请求头:在 `config` 目录下的 `app.php` 文件中,找到 `response` 配置项,将其中的 `'header' => []` 修改为以下内容: ```php 'header' => [ 'Access-Control-Allow-Origin' => '*', 'Access-Control-Allow-Methods' => 'GET, POST, PUT, DELETE, OPTIONS', 'Access-Control-Allow-Headers' => 'Origin, X-Requested-With, Content-Type, Accept', ], ``` 这样设置之后,所有来源的请求都将被允许访问。 2. 使用中间件处理跨域请求:可以自定义一个中间件来处理跨域请求。首先,在 `app/middleware` 目录下创建一个新的中间件文件,例如 `CorsMiddleware.php`,然后在该文件中编写处理跨域请求的逻辑,示例如下: ```php <?php namespace app\middleware; class CorsMiddleware { public function handle($request, \Closure $next) { header('Access-Control-Allow-Origin: *'); header('Access-Control-Allow-Methods: GET, POST, PUT, DELETE, OPTIONS'); header('Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept'); return $next($request); } } ``` 最后,在 `app/middleware.php` 文件中注册该中间件: ```php <?php return [ ... app\middleware\CorsMiddleware::class, ]; ``` 这样设置之后,所有经过中间件的请求都将被添加跨域请求头。 3. 使用第三方库:你还可以使用第三方库来处理跨域问题,例如使用 `think-cors` 库。在 `composer.json` 文件中添加该库的依赖: ```json "require": { ... "topthink/think-cors": "^2.0" }, ``` 然后执行 `composer update` 命令安装更新依赖。接下来,在应用配置的 `middleware` 配置项中添加 Cors 中间件: ```php 'middleware' => [ ... \think\middleware\Cors::class ] ``` 以上是几种常见的解决 ThinkPHP5 跨域问题的方法,你可以根据具体情况选择适合你的方式来进行处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值