2017-09-15 148 views
0

我想将图片上传到AWS s3,但我得到代码1错误。错误代码1意味着FileTransferError.FILE_NOT_FOUND_ERR但如果我复制源和粘贴在我的浏览器它显示图像。我不知道我错在哪里。我正在使用File Transfer上传图片。ionic2:s3图片上传不起作用

错误:

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

回答

0

您要上传直接使用离子本土的filetransfer图像数据。

但是FileTransferupload函数以fileUrl作为参数而不是图像数据。

upload(fileUrl, url, options, trustAllHosts) 

Filesystem URL representing the file on the device or a data URI. For backwards compatibility, this can also be the full path of the file on the device.

你需要尝试使用普通http.post功能,但不建议。 您应该将文件保存在临时目录中并使用该URL进行上传。

+0

我也试过这个,但仍然得到了同样的错误,代码=>:return fileTransfer.upload(“https://designpieces.com/wp -content/uploads/2013/05/1119-lorem-pixel.jpg“,encodeURI(this.uploadUrl),options); – MTA

+0

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

+0

现在,我试过这个:return fileTransfer.upload(“../../ assets/images/avatar.png”,encodeURI(this.uploadUrl),options); – MTA

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你可以看看比(包括代码示例以及)