寶塔下thinkphp5日志文件權限的問題,文件緩存也一樣修改


三個辦法解決:

1,修改php-fpm配置文件,把用戶改為root

2,把www拉入root用戶組下,sudo -g root www

3,修改源碼如下

 

由於www用戶和root用戶(比如command的cli進程日志)都有可能對log文件進行讀寫。

如果是由www用戶創建的log文件,不會出任何問題。

但是如果是先由root用戶創建的log文件,然后再到www用戶角色去寫,就會出問題了

因為一般默認創建的log文件的權限是  -rw-r--r-

也就是www沒有權限去寫入root用戶創建的log文件。

網上的方法大體就是像下面代碼一樣在mkdir的時候修改目錄的權限 

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

但是上面只能修改文件夾的權限,並沒有修改文件夾下具體的.log文件的權限。

【解決辦法】:

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

  1.  
    protected function write($message, $destination, $apart = false, $append = false)
  2.  
    {
  3.  
    ...
  4.  
    if (PHP_SAPI == 'cli') {
  5.  
    $message = $this->parseCliLog($info);
  6.  
    } else {
  7.  
    // 添加調試日志
  8.  
    $this->getDebugLog($info, $append, $apart);
  9.  
     
  10.  
    $message = $this->parseLog($info);
  11.  
    }
  12.  
     
  13.  
    //return error_log($message, 3, $destination);
  14.  
     
  15.  
    /** 解決root生成的文件,www用戶沒有寫權限的問題 by Werben 20190704 begin */
  16.  
    if (!is_file($destination)) {
  17.  
    $first = true;
  18.  
    }
  19.  
     
  20.  
    $ret = error_log($message, 3, $destination);
  21.  
     
  22.  
    try {
  23.  
    if (isset($first) && is_file($destination)) {
  24.  
    chmod($destination, 0777);
  25.  
    unset($first);
  26.  
    }
  27.  
    } catch (\Exception $e) { }
  28.  
    return $ret;
  29.  
    /** 解決root生成的文件,www用戶沒有寫權限的問題 by Werben 20190704 end */
  30.  
    ...
  31.  
    }


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM