ionic2:s3图片上传无效

时间:2017-09-15 05:37:59

标签: ionic-framework amazon-s3 ionic2

我正在尝试将图片上传到AWS s3,但我收到代码1错误。错误代码1表示 FileTransferError.FILE_NOT_FOUND_ERR ,但如果我在我的浏览器中复制源代码并粘贴,则显示图像。我不知道我错在哪里。我正在使用File Transfer上传图片。

错误:

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);
}

2 个答案:

答案 0 :(得分:0)

您正尝试使用Ionic Native filetransfer直接上传图片数据。

但是FileTransfer upload函数将fileUrl作为参数而不是图像数据。

upload(fileUrl, url, options, trustAllHosts)
  

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

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

答案 1 :(得分:0)

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],

CODE

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您可以查看详细信息(包括代码示例)