php warning fclose() expects parameter 1 to be resource boolean given

前端 未结 3 1981
感情败类
感情败类 2021-01-06 13:13

I use newrelic to keep track of anything on my website and I always get this error:

Error message: E_WARNING: fclose() expects parameter 1 to be resou

相关标签:
3条回答
  • 2021-01-06 13:45

    I wrestled with this problem and could not find the answer until I separated my write check (put it first) from the actual file write code. So before I would open the file fopen/fwrite then do the is_writable check and then do the fclose and i would get this error.
    To resolve I moved the is_writable and variable declaration before the fopen/fwrite and the error went away. Shown below (former php code position shown in comments) The first comment did help me realize this... Thank you.

    $myfile = "/var/www/html/newfile.txt";
    
    if (is_writable($myfile))  {
      echo  "The file is writable";
    }
    else {
      echo "The file is not writable";
    }
    
    $txt = "$name, $email, $command, $searchtype,  $keyword \n";
    $myfile = fopen('/var/www/html/newfile.txt', 'w') or die("Unable to open file!");
    fwrite($myfile, $txt);
    
    // $myfile = "/var/www/html/newfile.txt";
    
    // if (is_writable($myfile))  {
    //  echo  "The file is writable";
    // }
    // else {
    //   echo "The file is not writable";
    // }
    
    fclose($myfile);
    
    0 讨论(0)
  • 2021-01-06 13:57

    The error indicates that you are trying to pass a variable with a boolean value (true/false) to a function that needs a resource instead of a boolean value.

    Please make sure that before you use resources from variables, the function that returns the resource has not run into trouble. Only on success perform the other functions that use this resource/variable.

    $fh = fopen('/var/log/bfd_log', 'r');
    // check fh before other functions use this variable
    if (!$fh) {
        echo "Error! Couldn't open the file.";
    } else {
    
        // perform task with resource $fh
        fseek($fh, $res[1]);
        [...]
    
        $lfh = fopen('/etc/snmp/bfd-log-pos.stat', 'w');
    
        // check before other code block is executed and use this variable
        if( $lfh )
        {
    
            // perform task with resource $lfh
            $pos = ftell($fh);
            fwrite($lfh, "$timestamp,$pos");
            fclose($lfh);
            fclose($fh);
    
           [...]
    
        } else {
            // lfh error   
        }
    }
    

    If you always check before using variables, you won't run into this error anymore.

    0 讨论(0)
  • 2021-01-06 13:57

    Try

    $fh = fopen('/var/log/bfd_log', 'a+');
    

    a+ mode will create the file if it does not exists

    0 讨论(0)
提交回复
热议问题