如何修复Uncaught(在promise中)SyntaxError:JSON输入的意外结束?

问题描述 投票:0回答:1

所以我想使用React将文件上传到Cloudinary,但我在Upload.js:22 Uncaught (in promise) SyntaxError: Unexpected end of JSON input行中获得了let json = await res.json();。我怎样才能解决这个问题?

class Upload extends React.Component {
  processFile = async e => {
    var file = e.target.files[0];
    var formdata = new FormData();

    formdata.append("file", file);
    formdata.append("cloud_name", "dvrmt2oir");
    formdata.append("upload_preset", "wco0c7sr");

    let res = await fetch(
      "https://api.cloudinary.com/v1_1/dvrmt2oir/image/upload",
      {
        method: "post",
        mode: "cors",
        body: formdata
      }
    );

    let json = await res.json();
    console.log(JSON.stringify(json.secure_url));
  };

  render() {
    return (
      <div>
        <h3>Upload</h3>
        <input type="file" onChange={this.processFile} />
      </div>
    );
  }
}
reactjs post file-upload form-data cloudinary
1个回答
0
投票

我尝试使用以下代码:


import React from "react";
import ReactDOM from "react-dom";

import "./styles.css";

class Upload extends React.Component {
  processFile = async e => {
    var file = e.target.files[0];
    var formdata = new FormData();

    formdata.append("file", file);
    formdata.append("cloud_name", "dvrmt2oir");
    formdata.append("upload_preset", "wco0c7sr");

    let res = await fetch(
      "https://api.cloudinary.com/v1_1/dvrmt2oir/image/upload",
      {
        method: "post",
        mode: "cors",
        body: formdata
      }
    );

    let json = await res.json();
    console.log(JSON.stringify(json.secure_url));
  };

  render() {
    return (
      <div>
        <h3>Upload</h3>
        <input type="file" onChange={this.processFile} />
      </div>
    );
  }
}
ReactDOM.render(<Upload />, document.getElementById("container"));

它奏效了。你能提供你试图上传的图片吗?

© www.soinside.com 2019 - 2024. All rights reserved.