我正在尝试将图片上传到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);
}
答案 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您可以查看详细信息(包括代码示例)