typescript ionic 3从相机上传图像不使用文件,文件传输,文件上传插件

mbskvtky  于 2023-11-20  发布在  TypeScript
关注(0)|答案(3)|浏览(188)

我想使用FormData将图像上传到我的后端,但由于Ionic DEVAPP和Ionic VIEW不支持文件,文件传输和文件上传插件,我需要只使用Angular Http或HttpClient来完成。
当使用DestinationType.FILE_URI时,我可以从文件中获取内部URL并将其显示在img对象上,但如果没有本机文件,文件路径和文件传输插件,我无法从该URL创建typescript File对象。

getImage() {
const options: CameraOptions = {
  quality: 100,
  destinationType: this.camera.DestinationType.FILE_URI,
  sourceType: this.camera.PictureSourceType.PHOTOLIBRARY
}

this.camera.getPicture(options).then((imageData) => {
  this.imageURI =  this.sanitizer.bypassSecurityTrustUrl(imageData)
}, (err) => {
  console.log(err)
  this.presentToast(err)
})

字符串
}
使用此模板

<ion-content padding>
  <ion-item>
    <p>{{imageFileName}}</p>
    <button ion-button color="secondary" (click)="getImage()">Get Image</button>
  </ion-item>
  <ion-item>
    <h4>Image Preview</h4>
    <img style="display:block" [src]="imageURI" *ngIf="imageURI" alt="Ionic File" width="300" />
  </ion-item>
  <ion-item>
    <button ion-button (click)="uploadFile()">Upload</button>
  </ion-item>
</ion-content>


当使用DestinationType.DATA_URL时,我可以显示图像,但无法创建原始文件名所需的typescript File对象,以将图像附加到我的Ionic App上传服务上使用的FormData。
似乎我可以找到一种方法来创建这个类型脚本文件对象与原始文件名从FILE_URI和一个base64编码的数据从DATA_URL使用camera.getPicture从cordova相机本机插件。
服务上传文件到我的后端只是使用这种方法:

postImage(image: File): Observable<any> {
        const formData = new FormData()
        .append('file', image, image.name)
        }
        return this.httpClient.post<any>(this.myUrl,formData)
    }


来自组件myPage.ts的getImage和来自uploadservice.ts的postImage都可以正常工作,但是我找不到从camera创建File对象的方法。

fykwrbwg

fykwrbwg1#

答案主要来自here,但适用于@ionic-native/camera插件getPicture命令。

private urltoFile(url, filename, mimeType) {
    return (fetch(url)
        .then(function(res){return res.arrayBuffer();})
        .then(function(buf){return new File([buf], filename, {type:mimeType});})
    );
}

getPicture() {
    const options: CameraOptions = {
      quality: 50,
      destinationType: this.camera.DestinationType.DATA_URL,
      encodingType: this.camera.EncodingType.JPEG,
      mediaType: this.camera.MediaType.PICTURE,
      correctOrientation: true
    }

    this.camera.getPicture(options).then((imageData) => {

      let base64Image = 'data:image/jpeg;base64,' + imageData
      this.urltoFile(base64Image, 'filename.jpg', 'image/jpeg')
      .then((file) => {
          // You now have a file object that you can attach to a form e.g.
          this.myForm.get("imageToUpload").setValue(file)        
      })

    }, (err) => {
     // Handle error
    });
}

字符串
需要注意的要点是
1.目标类型必须为DATA_URL
1.必须将data:image/jpeg;base64,前置到imageData

t8e9dugd

t8e9dugd2#

我有同样的问题,并喜欢这个和它的作品为我。但有一件事要注意,我不显示选定的图像第一。上传后,只有其可见。

openImage() {
const options: CameraOptions = {
  quality: 100,
  destinationType: this.camera.DestinationType.FILE_URI,
  sourceType: this.camera.PictureSourceType.PHOTOLIBRARY,
  correctOrientation: true,
  allowEdit: false
};

this.camera.getPicture(options).then(imageData => {
  this.ImageFile = imageData;
}, err => {
  this.commonProvider.showToast('Error occured while opening the image' + err);
});

字符串
}

upload(msg: string) {
this.businessProvider.upload(this.Id, this.ImageFile)
  .then(
    data => {
      let response = JSON.parse(data["response"]);
      if (response.code === '1') {
        this.commonProvider.showToast('Business successfully ' + msg);
        this.navCtrl.pop();
      } else {
        this.commonProvider.showToast(response.message);
      }
      this.commonProvider.dismissLoader();
    },
    error => {
      this.commonProvider.showToast(JSON.stringify(error));
      this.commonProvider.dismissLoader();
    }
  );


}
这是我的业务提供商

import { Injectable } from '@angular/core';
import { HttpClient, HttpErrorResponse } from '@angular/common/http';
import { Observable } from 'rxjs/Observable';
import { ErrorObservable } from 'rxjs/observable/ErrorObservable';
import { catchError } from 'rxjs/operators';
import { Constant } from '../app/app.constants';
import { AuthenticationProvider } from '../providers/authentication';
import { FileTransfer, FileUploadOptions, FileTransferObject } from '@ionic-native/file-transfer';

@Injectable()
export class BusinessProvider {

  private actionUrl: string;

  constructor(
    private http: HttpClient,
    private auth: AuthenticationProvider,
    private constant: Constant,
    private transfer: FileTransfer
  ) {
    this.actionUrl = this.constant.getServerWithApiUrl() + 'Business/';
  }


  upload(Id: number, ImageFile): any {
    const fileTransfer: FileTransferObject = this.transfer.create();
    const headers = this.auth.getHeader();
    let options: FileUploadOptions = {
      fileKey: 'ionicfile',
      fileName: 'ionicfile.jpg',
      chunkedMode: false,
      mimeType: "image/jpeg",
      headers: { headers }
    }
    return fileTransfer.upload(ImageFile, this.actionUrl + 'Upload/' + Id, options);
  }

}

ef1yzkbh

ef1yzkbh3#

如果你不想使用原生插件,你可以使用angular。在这种情况下,使用离子输入文件:

<ion-input type="file"></ion-input>

字符串
剩下的用angular:https://www.academind.com/learn/angular/snippets/angular-image-upload-made-easy/完成
您可以使用以下示例:
https://github.com/diegogplfree/Ionic3-fileupload-non-native

相关问题