【问题标题】:Handling multipart/form-data request sent by Alamofire in Swift, in Hapijs backend在 Hapijs 后端处理 Alamofire 在 Swift 中发送的多部分/表单数据请求
【发布时间】:2016-04-08 13:34:51
【问题描述】:

我正在使用 swift 创建一个图像和视频上传 iOS 应用程序。我正在使用 Alamofire 库来处理网络请求。下面是用户选择图片时快速运行的代码

func imagePickerController(picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : AnyObject]) {
    dismissViewControllerAnimated(true, completion: nil)
    guard let image = info[UIImagePickerControllerOriginalImage] as? UIImage else {
            print("Did not get required image")
            return
    }

    guard let imageData = UIImageJPEGRepresentation(image, 0.8) else {
        return
    }

    Alamofire.upload(.POST, "http://localhost:8101/upload_request", multipartFormData: {
        multipartFormData in
        multipartFormData.appendBodyPart(data: imageData, name: "image")
    }, encodingCompletion: {
        encodingResult in
        switch encodingResult {
        case .Success(let upload, _, _):
            upload.responseJSON(completionHandler: {
                response in
                debugPrint(response)
            })
        case .Failure(let encodingError):
            print(encodingError)
        }
    })
}

以下是Hapijs中处理请求的方式

server.route({
  method: 'POST',
  path: '/upload_request',
  config: {
    payload: {
      maxBytes: 10 * 1024 * 1024,
      output: 'stream',
      parse: true,
      allow: 'multipart/form-data'
    }
  },
  handler: (request, reply) => {
      var data = request.payload;
      if (data.image) {
        var filePath = 'new_image.jpg';
        // data.image has data but is not of Stream.Readable

      } else {
        console.log('No data file');
      }
    }
});

问题是我没有在后端获取 request.payload.image 作为流,因此我无法创建 writeStream 并将其通过管道传输到该 writeStream。我做错了什么,还是错过了什么?我应该怎么做才能读取数据并将其作为图像文件写入文件系统?

这是我在 request.payload.image 中获取的数据的开始

����JFIFHH��LExifMM*�i&��� ��8Photoshop 3.08BIM8BIM%��ُ���      ���B~��@ICC_PROFILE0ADBEmntrRGB XYZ �3;acspAPPLnone���-ADBE
cprt�2desc0kwtpt�bkpt�rTRC�gTRC�bTRC�rXYZ�gXYZbXYZtextCopyright 2000 Adobe Systems IncorporateddescAdobe RGB (1998)XYZ �Q�XYZ curv3curv3curv3XYZ �O��XYZ 4��,�XYZ &1/���� �"��  

【问题讨论】:

  • 你从路由处理程序中的console.log(request.payload) 得到什么?如果输出量很大,也许可以在问题中添加一个截断的版本。
  • 嘿,马特。我已经添加了在 request.payload.image 中接收到的数据的起始位。接收到的有效载荷很大。

标签: ios node.js swift alamofire hapijs


【解决方案1】:

我找到了答案。只需要稍作改动。我没有在 Hapi.js 端获取所需格式的数据的原因是因为我没有从 Alamofire 正确发送数据。

这是从 Alamofire 发送请求的方式

Alamofire.upload(
  .POST,
  "http://localhost:8101/upload_request",
  multipartFormData: { multipartFormData in
      multipartFormData.appendBodyPart(data: self.fileData, name: "image", fileName: "imageToUpload.jpg",
        mimeType: "image/jpeg")
    },
  encodingCompletion: { encodingResult in
    switch encodingResult {
    case .Success(let upload, _, _):
      upload.responseJSON(completionHandler: { response in
        debugPrint(response)
      })
    case .Failure(let encodingError):
      print(encodingError)
    }
})

以及它应该在后端处理的方式。只需确保创建了您要写入的目录即可。

server.route({
path: '/upload_request',
method: 'POST',
config: {
    payload: {
        maxBytes: 20 * 1024 * 1024,
        output: 'stream',
        parse: true,
        allow: 'multipart/form-data'
    }
},
handler: (request, reply) => {
    var data = request.payload;
    if (data.image) {
        var name = data.image.hapi.filename;
        var path = __dirname + "/uploads/" + name;
        var file = fs.createWriteStream(path);

        file.on('error', (err) => {
            console.error(err);
        });

        file.on('open', (err) => {
            data.image.pipe(file);    
        });            

        data.image.on('end', (err) => {
            var ret = {
                filename: data.image.hapi.filename,
                headers: data.image.hapi.headers
            }
            reply(ret);
        })
    }
}
});

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-04-27
    • 1970-01-01
    • 2022-12-05
    • 2010-11-03
    • 1970-01-01
    • 2018-03-05
    相关资源
    最近更新 更多