javascript - 通过 xmlhttprequest 上传文件生成多部分 : NextPart: EOF

标签 javascript ajax file-upload go

我正在尝试通过 XMLHttpRequest 上传文件,目前我正在使用 golang

当我使用 CURL 测试上传时一切正常,文件上传到 Amazon S3 存储桶,但是当使用 Javascript 时我收到以下错误:multipart: NextPart: EOF

这是 JS 部分:

document.getElementById("attachment").addEventListener("change", function(e) {
    var file = this.files[0];
    var xhr = new XMLHttpRequest();
    var formdata = new FormData();
    formdata.append("attachment", file);
    boundary=Math.random().toString().substr(2);

    xhr.onreadystatechange = function(e) {
        if ( 4 == this.readyState ) {
            console.log(["xhr upload complete", e]);
        }
    };
    xhr.open("POST", "https://upload_host:8443/upload", true);
    xhr.setRequestHeader("Content-Type","multipart/form-data; charset=utf-8; boundary=---------------------------"+boundary+";");
    xhr.send(formdata);
}, false);

对于 go 处理程序:

func upload_handler(w http.ResponseWriter, r *http.Request, m render.Render) {
  w.Header().Set("Access-Control-Allow-Origin", "*")
  file, header, err := r.FormFile("C.Storage.FieldName")
  if err != nil {
    // ERROR THROWN HERE
    ServeHTTP(400, err.Error(), m)
    return
  }

  content, err := ioutil.ReadAll(file)

  if err != nil {
    ServeHTTP(400, err.Error(), m)
    return
  }

  fileSize, err := file.Seek(0, 2) //2 = from end
  if err != nil {
    ServeHTTP(400, err.Error(), m)
    return
  }

  if fileSize > int64(C.Storage.FileSize) {
    ServeHTTP(400, "File size limit exceeded", m)
    return
  }

  ftype := http.DetectContentType(content)

  if !strings.Contains(C.Storage.AllowedMimes, ftype) {
    ServeHTTP(400, "File type not allowed", m)
    return
  }

  //FUNCTION TO UPLOAD TO AMAZON S3 

  file.Close()
}

最佳答案

要上传,您可以使用 PlUploader Code example (也用于大文件上传)。

关于javascript - 通过 xmlhttprequest 上传文件生成多部分 : NextPart: EOF,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32202699/

相关文章:

javascript - jquery可以像prototype一样实现类继承吗

javascript - AngularJS 多次处理调用 promise

javascript - 为什么我的 jQuery 事件处理程序在附加到多个元素时会失败?

javascript - 在 Express Node js 中使用 multer sftp 将文件上传到远程服务器?

asp.net - PostedFile.FileName 在 .Net 4.0 中的工作方式是否有所不同?

php - 如何用 PHP 编写文件上传测试?

javascript - 5 秒后提交文本值

javascript - 跨域iframe问题

javascript - Typescript 无法推送到 knockout 可观察数组,因为即使在初始化后也未定义

javascript - JQuery Ajax : Random order of dynamic div elements