ionic2:s3图像上传不起作用

ionic-framework amazon-s3 ionic2

438 观看

2回复

338 作者的声誉

我正在尝试将图像上传到AWS s3,但出现代码1错误。错误代码1表示FileTransferError.FILE_NOT_FOUND_ERR,但是如果我复制源并将其粘贴到浏览器中,则会显示图像。我不知道我在哪里错。我正在使用文件传输功能上传图片。

错误:

body: null
code: 1
exception: null
http_status: null
source: ""
target: "https://s3.amazonaws.com/xxxxxxx/"

这是我的上传代码:

uploadFile(fileName: string) {
    const fileTransfer: FileTransferObject = this.transfer.create();
    this.newImage = "";

    let options: FileUploadOptions = {
        httpMethod: 'PUT',
        params: {
            "key": this.uploadUrl + fileName,
            "AWSAccessKeyId": this.s3.key,
            "acl": "public-read",
            "policy": this.s3.policy,
            "signature": this.s3.signature,
            "Content-Type": "image/jpeg"
        }
    }

    return fileTransfer.upload(this.newImage, encodeURI(this.uploadUrl), options);
}
作者: MTA 的来源 发布者: 2017 年 9 月 15 日

回应 2


0

25439 作者的声誉

您正在尝试使用Ionic Native的直接上载图像数据filetransfer

但是函数代替图像数据作为参数。FileTransfer uploadfileUrl

upload(fileUrl, url, options, trustAllHosts)

表示设备上的文件或数据URI的文件系统URL。为了向后兼容,这也可以是设备上文件的完整路径。

您将需要尝试使用常规http.post功能,但不建议这样做。您应将文件保存在一个临时目录中,并使用该URL进行上传。

作者: Suraj Rao 发布者: 2017 年 9 月 15 日

0

849 作者的声誉

Ionic2提供FileTransfer来上传图像。要使用它,应安装此插件

$ ionic cordova plugin add cordova-plugin-file-transfer

$ npm install --save @ionic-native/file-transfer

然后配置上传:

key: [key value is configured from frontend],

AWSAccessKeyId: [AWSAccessKeyId value received from backend],

acl: [acl value received from backend],

policy: [policy value received from backend],

signature: [signature value received from backend],

import { Inject, Injectable } from '@angular/core';
import { Http, RequestOptions, Headers } from '@angular/http';
import { FileTransfer, FileUploadOptions, FileTransferObject } from '@ionic-native/file-transfer';
import { File } from '@ionic-native/file';

@Injectable()
export class UploadServiceProvider {
  apiUrl = `${your host to get api}`
  constructor(public http: Http, private transfer: FileTransfer, private file: File) {
  }

  //config S3 params
  s3UploadConfig(file, s3Params) {
    return{
      url: s3Params.bucket_name,
      method: 'POST',
      chunkedMode: false,
      headers: {
        connection: "close"
      },
      params : {
        key: `uploads/${file.substr(file.lastIndexOf('/')+1)}`,
        AWSAccessKeyId: s3Params.key,
        acl: s3Params.acl,
        policy: s3Params.policy,
        signature: s3Params.signature,
        'Content-Type' : "image/jpeg"
      }
    };
  }

  // Get Signature
  generateSignature(token) {
    const headers: Headers = new Headers();
    headers.append('Content-Type', 'application/x-www-form-urlencoded');
    headers.append('Accept', 'application/json');
    headers.append('Authorization-Token', token);

    const options: RequestOptions = new RequestOptions();
    options.headers = headers;
    // Call API to get Signature
    return this.http.get(`${this.apiUrl}/generate-signature`, options)
  }

  // Upload Image to s3
  upload(file,token): Promise<any>{
    return new Promise((resolve, reject) => {
      this.generateSignature(token)
        .map(response => response.json().data)
        .subscribe(
          response => {
            let s3Params = response;
            let serveConfig = this.s3UploadConfig(file, s3Params);
            let key = `uploads/${file.substr(file.lastIndexOf('/')+1)}`;
            const fileTransfer: FileTransferObject = this.transfer.create();

            fileTransfer.upload(file, encodeURI(s3Params.bucket_name), serveConfig)
              .then((result) => {
                // when finished upload photo. S3 will return a link of image.
                // This link is combined from `s3Params.bucket_name + key`
                resolve(s3Params.bucket_name + key);
              }, (error) => {
                resolve(error.json());
              });
          });
    });
  }

    }

这是我的博客https://mymai91.github.io/ionic/2017/09/17/upload-image-to-s3-using-ionic2.html,您可以了解一下详细信息(包括代码示例) )

作者: My Mai 发布者: 2017 年 9 月 18 日
32x32