PHP 在上传图像时从 React Native 接收空数据?

标签 php mysql react-native fetch image-uploading

这花了我一段时间才弄清楚,因为在应用程序屏幕上我得到的只是 JSON Parse Error: '<' 。感谢error_log ,我在 PHP 中发现了这些错误:

[29-Jun-2018 19:35:34 America/Chicago] PHP Deprecated:  Automatically populating $HTTP_RAW_POST_DATA is deprecated and will be removed in a future version. To avoid this warning set 'always_populate_raw_post_data' to '-1' in php.ini and use the php://input stream instead. in Unknown on line 0
[29-Jun-2018 19:35:34 America/Chicago] PHP Warning:  explode() expects parameter 2 to be string, array given in React/user-image-upload.php on line 17
[29-Jun-2018 19:35:34 America/Chicago] PHP Warning:  end() expects parameter 1 to be array, null given in React/user-image-upload.php on line 18
[29-Jun-2018 19:35:34 America/Chicago] PHP Warning:  preg_match() expects parameter 2 to be string, array given in React/user-image-upload.php on line 27
[29-Jun-2018 19:35:34 America/Chicago] PHP Warning:  unlink() expects parameter 1 to be a valid path, array given in React/user-image-upload.php on line 30

这是我用于上传图像的 php 代码:

    <?php
         // Getting the received JSON into $json variable.
 $json = file_get_contents('php://input');

 // decoding the received JSON and store into $obj variable.
 $obj = json_decode($json,true);

$fileName = $obj["userimgSource"]; // The file name
$fileTmpLoc = $obj["userimgSource"]; // File in the PHP tmp folder
$fileType = $obj["userimgSourceType"]; // The type of file it is
$fileSize = $obj["userimgSourceSize"]; // File size in bytes
$fileErrorMsg = $_FILES["uploaded_file"]["error"]; // 0 for false... and 1 for true
$kaboom = explode(".", $fileName); // Split file name into an array using the dot
$fileExt = end($kaboom); // Now target the last array element to get the file extension
// START PHP Image Upload Error Handling --------------------------------------------------
if (!$fileTmpLoc) { // if file not chosen
    echo json_encode("ERROR: Please browse for a file before clicking the upload button.");
    exit();
} else if($fileSize > 5242880) { // if file size is larger than 5 Megabytes
    echo json_encode("ERROR: Your file was larger than 5 Megabytes in size.");
    unlink($fileTmpLoc); // Remove the uploaded file from the PHP temp folder
    exit();
} else if (!preg_match("/.(gif|jpg|jpe|jpeg|png)$/i", $fileName) ) {
     // This condition is only if you wish to allow uploading of specific file types    
     echo json_encode("ERROR: Your image was not .gif, .jpg, .jpe, or .png.");
     unlink($fileTmpLoc); // Remove the uploaded file from the PHP temp folder
     exit();
} 
// END PHP Image Upload Error Handling ----------------------------------------------------
// Place it into your "uploads" folder mow using the move_uploaded_file() function
$moveResult = move_uploaded_file($fileTmpLoc, "../profiles/uploads/$fileName");
// Check to make sure the move result is true before continuing
if ($moveResult != true) {
    echo json_encode("ERROR: File not uploaded. Try again.");
    unlink($fileTmpLoc); // Remove the uploaded file from the PHP temp folder
    exit();
}
if  ($moveResult == true) {
    $db = mysqli_connect("localhost", "root", "password", "photos");
    $sql = "INSERT INTO user_images (images,date) VALUES ('$fileName',CURDATE())";
    mysqli_query($db, $sql);
    echo json_encode("Success: File uploaded.");

}
unlink($fileTmpLoc); // Remove the uploaded file from the PHP temp folder
?>

在向您展示我的所有 React Native 代码之前,我只想说我对 RN 中的图像上传感到陌生。我读了很多关于 SO 的问题来了解如何做到这一点,并观看了一些 YouTube 视频。我不知道我是否应该使用base64 (如果有人可以向我解释这一点,那就太好了),据我所知,我只是提取图像路径、图像大小和图像类型,然后将该图像路径插入到我的文件夹和数据库中:

    SelectPhoto = () =>{
ImagePicker.openPicker({
cropping: true,
title: 'Select an image',
isCamera: true,
}).then((imgResponse) => {
  console.log(imgResponse);
  let imgSource = { uri: imgResponse[0].path.replace(/^.*[\\\/]/, '') };
  this.setState({
    userimgSource: imgSource,
    userimgSourceType: imgResponse[0].mime,
    userimgSourceSize: imgResponse[0].size,
  });
});


}

UploadPhoto = () =>{
  fetch('https://www.example.com/React/user-image-upload.php', {
  method: 'POST',
  headers: {
    'Accept': 'application/json',
    'Content-Type': 'application/json',
  },
  body: JSON.stringify({
    userimgSource : this.state.userimgSource,
    userimgSourceType: this.state.userimgSourceType,
    userimgSourceSize: this.state.userimgSourceSize,

  })

  }).then((response) => response.json())
      .then((responseJson) => {

        // Showing response message coming from server after inserting records.
        Alert.alert(responseJson);


      }).catch((error) => {
        console.error(error);
      });
}

这就是困惑的地方。当我 console.log我的userimgSource: imgSource, userimgSourceType: imgResponse[0].mime, userimgSourceSize: imgResponse[0].size,事实上,我确实得到了正确的数据。我得到图像路径:IMG_2018629.png , mime :image/png ,尺寸:2,097,152 。 PHP 无法从 React Native 中获取数据是否有原因?

最佳答案

将标题更改为此

headers: {
    'Accept': '*',
    'Content-Type': 'multipart/form-data',
  }

  • 当您上传图像时,其内容类型不能是 'application/json'。

  • Accept 请求 header 字段可用于指定响应可接受的某些媒体类型。因此,添加星号将使您的请求接受任何类型的响应。

关于PHP 在上传图像时从 React Native 接收空数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51110949/

相关文章:

javascript - 如何在没有模拟器的情况下使用 firebase?

php - 获取属于模型的所有值

PHP::检测 session 是否开始的最佳方法

mysql - 如何选择两列,其中一列必须是 DISTINCT?

mysql奇怪的 "duplicate entry"错误

javascript - 如何在React Native中下载文件?

php - 在 Laravel 中对只读模型进行单元测试的正确方法是什么?

php - 我的自定义样式表入队功能不起作用

php - MySQL 到谷歌图表 PHP

react-native - 在 i18next 中遍历数组