当前位置: 首页 > 知识库问答 >
问题:

phonegap/cordova从照片库获取图片文件传输不工作

芮意
2023-03-14

我在组合科尔多瓦的camera.getPicture插件和他们的FileTransfer.upload插件时遇到了一些问题。最奇怪的是,当我从相机拍照时,一切都很好,而不是当我从图书馆检索时。

问题看起来像这样:Phonegap/Cordova从图库上传图像在Android Kitkat上不起作用。

但是我用的是Cordova 3,所以这肯定能解决kitkat的问题。

我的代码:

var imageUploadUrl = setting_api_url + "Umbraco/Api/ImageApi/PostUpload";
var formSubmitUrl = setting_api_url + "Umbraco/Api/FormApi/PostSend";
var imageUriStorage = [];
var resultsCollection = [];
var FieldId;

var take_photo = function(fieldId) {
FieldId = fieldId;
navigator.camera.getPicture(onTakeSuccess, 
                            onTakeFail, 
                            { 
    quality: 30, 
    destinationType: Camera.DestinationType.FILE_URI, 
    sourceType: Camera.PictureSourceType.CAMERA,
    targetWidth: 800,
    targetHeight: 800,
    correctOrientation: true
});
};

var get_photo = function(fieldId) {
FieldId = fieldId;
navigator.camera.getPicture(onTakeSuccess, onTakeFail, { 
    quality: 30, 
    destinationType: Camera.DestinationType.FILE_URI, 
    sourceType: Camera.PictureSourceType.PHOTOLIBRARY,
    targetWidth: 800,
    targetHeight: 800,
    correctOrientation: true });
};

var onTakeSuccess = function(imageURI) {
console.log("onTakeSuccess imageURI= " + imageURI);

var image = document.getElementById("preview-" + FieldId);

// UPLOAD PART COPIED
var options = new FileUploadOptions();
options.fileKey = "file";
options.fileName = src.substr(src.lastIndexOf('/') + 1);
var filetype = src.substr(src.lastIndexOf('.') + 1);
if(filetype == "png") {
    options.mimeType = "image/png";
}
else if (filetype == "jpg") {
    options.mimeType = "image/jpeg";
}

var ft = new FileTransfer();
ft.upload(imageURI, encodeURI(imageUploadUrl), image_upload_win, image_upload_fail, options);
// END.


imageUriStorage.push({ 'Id':FieldId, 'Path': imageURI});

image.src = imageURI;
};

var onTakeFail = function(message) {
alert('on take fail. Code: ' + message);
};

// called when upload succeeds        
var image_upload_win = function (r) {
    console.log("Code = " + r.responseCode);
    console.log("Response = " + r.response);
    console.log("Sent = " + r.bytesSent);
};

// when upload fails
var image_upload_fail = function (error) {
    alert("Code = " + error.code + "-" + error.http_status + ", image:" + error.source);
    console.log("upload error source " + error.source);
    console.log("upload error target " + error.target);
};

take_photo和get_phoot在takesuccess上使用相同的函数,因此它们将获得相同的过程。当源是摄像机时,图像被正确上传,服务器给出正确响应(和HTTP 201)。

但是,当源是库时,这将失败。文件传输。上传给出错误代码1(未找到文件),但这不可能是真的,因为图像在我的应用程序的图像元素中显示正确。

服务器发出 HTTP 400 错误请求。

该过程有一个区别,即图像URL的格式,但这应该如何产生这种差异?

记录成功获取图片(相机):

onTakeSuccess imageURI=file:///mnt/sdcard/Android/data/com.XXX.YYY/cache/1404910577158.jpg
Code = 201
Response = "8999"
Sent = 195

记录不成功的获取图片(库):

onTakeSuccess imageURI= file:///mnt/sdcard/Android/data/com.XXX.YYY/cache/modified.jpg?1404910903858
upload error source file:///mnt/sdcard/Android/data/com.XXX.YYY/cache/modified.jpg?1404910903858
upload error target https://CORRECTURL/Umbraco/Api/ImageApi/PostUpload

此外,getPicture (LIBRARY) 情况会发出以下警报:

code=1-400,图像:file:///mnt/sdcard/Android/data/com.XXX.YYY/cache/modified.jpg?1404910903858

共有3个答案

宋嘉禧
2023-03-14

是啊!画廊中的一些文件是这样的格式:modified.jpg?文件名为1438896451328。

为了防止,我在上传中添加了一些代码。php文件:

        $temporary = explode(".", $_FILES["file"]["name"]);
        $file_extension = end($temporary);

   // cortamos caracteres extraños por si llega algun nombre de archivo raro
        $cadena = $file_extension; 
        $patron = "?"; 
   // localicamos en que posición se haya "?"
        $posicion = strpos ($cadena, $patron); 
   // eliminamos los caracteres desde ? hacia la derecha
        if ($posicion !== false){
        $file_extension = substr ($cadena, 0, $posicion); 
        }

然后,您可以操作过滤器文件类型,大小等,最后保存它。

农均
2023-03-14

使用cordova 6.0.0、cordova插件摄像机2.1.0、cordova插件白名单1.2.1

我也有类似问题(虽然可能是因为不同的原因,因为它是一个新版本)。

我发现我需要在config.xml中包含以下行

<access origin="*" />
<access origin="content:///*" />

注意:只有

<access origin="*" />

是不够的

万明辉
2023-03-14

我目前的解决方法是删除“?”以及imageUri之后的所有内容。所以URI看起来总是这样:

file:///mnt/sdcard/Android/data/com.XXX.YYY/cache/modified.jpg

在我的情况下,这可以正常工作并正确传输文件

 类似资料:
  • 有没有人知道使用PhoneGap/Cordova可以从相册中选择多张照片? 使用文档创建一个应用程序来选择一张照片是相当容易的,但没有文档说明如何选择多张照片???

  • 问题内容: 我正在开发phonegap应用程序,我需要将URL中的图像保存到Device Photo Gallery。 我在Phonegap Api上找不到执行此操作的方法,而且我也没有找到用于此目的的phonegap插件。 我需要它才能与Iphone和Android一起使用 非常感谢! 问题答案: 这是任何人都可以使用的文件下载代码。您只有三个参数可以像这样使用- 1) 网址 2)您要在SD卡中

  • 问题内容: 我需要在活动中获得并显示照片库中最近拍摄的3张照片,而无需任何点击。 完成此步骤后,滚动时,我应该以3 x 3的方式拍摄其他照片。 您知道快速执行此操作的正确方法吗?谢谢。 问题答案: 这是使用适用于iOS 8+设备的框架的解决方案:

  • 全部的 我正在尝试使用PhoneGap/Cordova 2获取照片的文件大小(即,不是尺寸,而是磁盘中的实际文件大小)。到目前为止,我唯一能计算出来的方法是通过base64转换,然后对b64字符串的字节进行基本运算。然而,我想知道是否有更优雅的方法来获取文件大小。蒂亚。 澄清:它必须在iOS 5和Android 2.3上工作。

  • 这个问题已经问过好几次了,但大多数这些问题都没有答案。 我正在下载下面这样的文件,它似乎工作正常。但是,它不会出现在iOS、ehm和gallery中。也就是说,在“照片”应用程序中。 结果是 万岁。现在,如何在ios上仅用手指打开下载?

  • 我有一个活动,在android照片库上选择图像 但是我想从我的android studio drawable文件夹中选择图像。 我应该如何修改代码?