PHP - file_get_contents(): 文件名不能为空

新手上路,请多包涵

有人可以帮我处理这个错误吗?我不知道用什么方法或方法来摆脱这个错误。我是 php 的新手并开始学习它。有人可以给我想法吗?

这是错误: 在此处输入图像描述

这是我的 PHP 代码。

 <?php

include_once('connection.php');

 $newsid = $_GET['news_id'];

    if(isset($_POST['esubmit'])){
        /* create a prepared statement */
        if ($stmt = mysqli_prepare($con, "SELECT * FROM news WHERE news_id = ? LIMIT 1")) {
            /* bind parameters */
            mysqli_stmt_bind_param($stmt, "s", $newsid);

            /* execute query */
            mysqli_stmt_execute($stmt);

            /* get the result set */
            $result = mysqli_stmt_get_result($stmt);

            /* fetch row from the result set */
            $row = mysqli_fetch_array($result);
        }

    }

    if(isset($_POST['update'])){

        if(isset($_FILES['image'])){
          $file=$_FILES['image']['tmp_name'];
          /* Below is the line 30 causing the error*/
          $image = addslashes(file_get_contents($_FILES['image']['tmp_name']));
          $image_name= addslashes($_FILES['image']['name']);
          move_uploaded_file($_FILES["image"]["tmp_name"],"img/" . $_FILES["image"]["name"]);
          $newsimage="img/" . $_FILES["image"]["name"];

          $title = $_POST['titles'];
          $date = $_POST['dates'];
          $content = $_POST['contents'];

          $sql ="UPDATE news SET news_title ='$title', news_date ='$date', news_content = '$content', news_image ='$newsimage' WHERE news_id = '$newsid'";
          mysqli_query($con, $sql);
          echo "oh it worked ";
        }
        else{
          $title = $_POST['titles'];
          $date = $_POST['dates'];
          $content = $_POST['contents'];
          $sql ="UPDATE news SET news_title ='$title', news_date ='$date', news_content = '$content' WHERE news_id = '$newsid'";
          mysqli_query($con, $sql);
          echo "oh it worked again ";
        }

    }
?>
<!DOCTYPE HTML>
<html>
<head>
</head>
<body>

<?php

    if(isset($_POST['esubmit'])){
        ?>

        <form method="post" action ="edit2.php?news_id=<?php echo $row['news_id']; ?>" enctype="multipart/form-data">
            Title<input type ="text" name ="titles" value="<?php echo $row['news_title']; ?>"/><br>
            Date<input type ="text" name="dates" value="<?php echo $row['news_date']; ?>" /><br>
            Content<textarea name="contents"><?php echo $row['news_content']; ?></textarea>
            <input class="form-control" id="image" name="image" type="file" accept="image/*" onchange='AlertFilesize();'/>
            <img id="blah" src="<?php echo $row['news_image']; ?>" alt="your image" style="width:200px; height:140px;"/>

            <input type="submit" name="update" value="Update" />
        </form>

        <?php
    }

?>

<script src="js/jquery-1.12.4.min.js"></script>
<script src="js/bootstrap.min.js"></script>
<script type="text/javascript">
    function readURL(input) {
        if (input.files && input.files[0]) {
            var reader = new FileReader();

            reader.onload = function (e) {
                $('#blah').attr('src', e.target.result);
            }

            reader.readAsDataURL(input.files[0]);
        }
    }

    $("#image").change(function(){
        readURL(this);
    });
    </script>
</body>
</html>

原文由 nethken 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 765
2 个回答

你为什么要在你的(临时)文件名中添加slahes?

你的第 30 行:

>  $image= addslashes(file_get_contents($_FILES['image']['tmp_name']));
>
> ```

所以要删除错误警告:

if(!empty(\(_FILES['image']['tmp_name']) && file_exists(\)_FILES[‘image’][‘tmp_name’])) { \(image= addslashes(file_get_contents(\)_FILES[‘image’][‘tmp_name’])); }


- 你可以/应该用这段代码做很多其他事情,但我不能和你一起做太多细节,但基本上你应该检查 `$_FILES['image']['error'] == 0` 以确保代码仅在以下情况下运行文件已成功上传。

- 代替


  > ```
  >   if(isset($_FILES['image'])){
  >
  > ```


通过错误检查:

if($_FILES['image']['error'] == 0){

”`

这意味着只有 OK 上传的文件才会运行 IF 语句内容

  • 停止添加斜杠,不需要。

  • 为您的 SQL 查询使用准备好的语句。

  • Move_uploaded_file 在一个完美的世界中应该被赋予绝对路径而不是相对路径。

  • 您是否意识到您 file_get_contents 正在获取文件中的 数据,而不是引用而是实际的二进制文件数据。这看起来不是您在此阶段需要做的事情。您的 $image 值未在您提供的代码中明确使用,正如 apokryfos 正确指出的那样,您实际上是在向检索到的图像文件数据中添加斜杠。这只会让你的 $image 乱码。

原文由 Martin 发布,翻译遵循 CC BY-SA 3.0 许可协议

如果其他人仍然有这个问题。这对我来说是固定的。将您的 php.ini 文件更改为

; Maximum allowed size for uploaded files.
upload_max_filesize = 40M

; Must be greater than or equal to upload_max_filesize
post_max_size = 40M

说明:php.ini 文件的默认设置是

; Maximum allowed size for uploaded files.
upload_max_filesize = 2M

这就是为什么您不能上传大于 2 MB 的图像的原因。对于 Windows,您只需在底部菜单栏的搜索栏中搜索 php.ini。然后使用编辑器编辑属性。

原文由 NKol 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
Stack Overflow 翻译
子站问答
访问
宣传栏