如何通过 devapp 在 Ionic 4 的 firebase 存储上上传在 phone 拍摄的照片
How to upload photo taken on phone through devapp on firebase storage in Ionic 4
我正在尝试上传一张通过我的phone相机拍摄的照片(使用 Ionic 4 Native Camera Plugin
通过 DevApp ) 并将其上传到 Firebase Storage
。现在我可以拍照了,但是当我上传照片时,控制台不会抛出任何错误,只是什么也不做。最后,照片没有上传到firebase存储。
这是我的代码:
.html:
<ion-button (click)="takePicture()"></ion-button>
.ts:
takePicture(){
const options: CameraOptions = {
quality: 100,
destinationType: this.camera.DestinationType.FILE_URI,
encodingType: this.camera.EncodingType.JPEG,
mediaType: this.camera.MediaType.PICTURE
}
this.camera.getPicture(options).then((imageData) => {
var storage = firebase.storage().ref();
var photoRef = storage.child('Manager Images');
console.log(photoRef); <-- This reference is correct
let base64Image = 'data:image/jpeg;base64,' + imageData;
console.log(base64Image); <-- Returns ":///storage/emulated/0/Android/data/io.ionic.devapp/cache/1577622281686.jpg"
// Base64 formatted string
var message = imageData;
photoRef.putString(message , 'base64', { contentType: 'image/jpg' }).then((savedPicture) => {
console.log(savedPicture.downloadURL);
});
}, (err) => {
// Handle error
});
}
我的 .putString 方法有问题吗?我参考了 https://firebase.google.com/docs/storage/web/upload-files 的指导方针,但我仍然无法让它发挥作用。请帮忙!
更改此行,它应该可以工作。
var message = base64Image;
imageData 不是 'base64'
或上传为文件,按原样使用文件。
var file = imageData
photoRef.put(file).then(snapshot => {
console.log('Uploaded a blob or file!')
});
将目标类型更改为 this.camera.DestinationType.DATA_URL
以获取 base64,然后将其放入 firebase 存储。
takePicture(){
const options: CameraOptions = {
quality: 100,
destinationType: this.camera.DestinationType.DATA_URL,
...
PS。确定 let base64Image = 'data:image/jpeg;base64,' + imageData;
是否必要,或者 imageData
是否已经具有 base64 格式的编码类型。
我正在尝试上传一张通过我的phone相机拍摄的照片(使用 Ionic 4 Native Camera Plugin
通过 DevApp ) 并将其上传到 Firebase Storage
。现在我可以拍照了,但是当我上传照片时,控制台不会抛出任何错误,只是什么也不做。最后,照片没有上传到firebase存储。
这是我的代码:
.html:
<ion-button (click)="takePicture()"></ion-button>
.ts:
takePicture(){
const options: CameraOptions = {
quality: 100,
destinationType: this.camera.DestinationType.FILE_URI,
encodingType: this.camera.EncodingType.JPEG,
mediaType: this.camera.MediaType.PICTURE
}
this.camera.getPicture(options).then((imageData) => {
var storage = firebase.storage().ref();
var photoRef = storage.child('Manager Images');
console.log(photoRef); <-- This reference is correct
let base64Image = 'data:image/jpeg;base64,' + imageData;
console.log(base64Image); <-- Returns ":///storage/emulated/0/Android/data/io.ionic.devapp/cache/1577622281686.jpg"
// Base64 formatted string
var message = imageData;
photoRef.putString(message , 'base64', { contentType: 'image/jpg' }).then((savedPicture) => {
console.log(savedPicture.downloadURL);
});
}, (err) => {
// Handle error
});
}
我的 .putString 方法有问题吗?我参考了 https://firebase.google.com/docs/storage/web/upload-files 的指导方针,但我仍然无法让它发挥作用。请帮忙!
更改此行,它应该可以工作。
var message = base64Image;
imageData 不是 'base64'
或上传为文件,按原样使用文件。
var file = imageData
photoRef.put(file).then(snapshot => {
console.log('Uploaded a blob or file!')
});
将目标类型更改为 this.camera.DestinationType.DATA_URL
以获取 base64,然后将其放入 firebase 存储。
takePicture(){
const options: CameraOptions = {
quality: 100,
destinationType: this.camera.DestinationType.DATA_URL,
...
PS。确定 let base64Image = 'data:image/jpeg;base64,' + imageData;
是否必要,或者 imageData
是否已经具有 base64 格式的编码类型。