问题 如何使用Phonegap和JqueryMobile上传文件?


我正在使用JQM和PhoneGap为Android构建移动应用程序。 我需要将文件(图像)上传到远程服务器(来自galery或用相机拍照)。 基本上它可以使用phonegap文件AP​​I来完成,问题是服务器是为了支持简单的POST提交而编写的。

我需要的是在我的应用程序请求中“模拟” 精确 因为它将从以下html表单发送。 另外我需要获得服务器响应。

<form name="myWebForm" ENCTYPE="multipart/form-data" action="http://www.myurl.com/api/uploadImage "method="post">
    <input type="file" name="image" />
    <input type="submit" value="Submit"/>       
</form>

我尝试使用phonegap文件AP​​I,但服务器端检索数据的结构与应有的不同。

我试图在我的应用程序中实现该表单,但“选择文件”按钮被禁用...

如何在不对服务器端进行任何更改的情况下实现?


3665
2017-12-13 13:53


起源

有关简单的完整示例,请参阅我的答案。你所要做的就是复制 stackoverflow.com/questions/11402937/... - iOSAndroidWindowsMobileAppsDev


答案:


您不能在Phonegap上使用输入文件。它不受支持。你需要做这样的事情:

    function onDeviceReady() {

        // Retrieve image file location from specified source
        navigator.camera.getPicture(uploadPhoto,
                                    function(message) { alert('get picture failed'); },
                                    { quality: 50, 
                                    destinationType: navigator.camera.DestinationType.FILE_URI,
                                    sourceType: navigator.camera.PictureSourceType.PHOTOLIBRARY }
                                    );

    }

    function uploadPhoto(imageURI) {
        var options = new FileUploadOptions();
        options.fileKey="file";
        options.fileName=imageURI.substr(imageURI.lastIndexOf('/')+1)+'.png';
        options.mimeType="text/plain";

        var params = new Object();

        options.params = params;

        var ft = new FileTransfer();
        ft.upload(imageURI, encodeURI("http://some.server.com/upload.php"), win, fail, options);
    }

    function win(r) {
        console.log("Code = " + r.responseCode);
        console.log("Response = " + r.response);
        console.log("Sent = " + r.bytesSent);
    }

    function fail(error) {
        alert("An error has occurred: Code = " + error.code);
        console.log("upload error source " + error.source);
        console.log("upload error target " + error.target);
    }

在getPicture方法中,您将选择您的文件源。查看更多信息: http://docs.phonegap.com/en/2.1.0/cordova_file_file.md.html#FileTransfer

编辑:

需要指定fileName扩展名以及以“text / plain”格式请求mimeType以文本格式发送图像。 至于params,如果你不需要它们为什么要使用它们?


12
2017-12-13 14:40



这正是我使用的代码,但是服务器端的代码结构与表单提交的结构不同。该方法传递一个名为'files'的数组,该数组有另一个名为'file'的数组(options.fileKey =“file”;),'file'数组具有名称,类型,大小等属性......问题是服务器端寻找名为“image”的变量来保存图像...就像在表单中......任何其他建议? - Victor
查看mimeType到text / plain的更改以及发送空参数。 - A. Magalhães
仍然不起作用...是否可以通过编程方式从navigator.camera.getPicture提交返回的对象而没有phonegap?仅使用jquery或javascript? - Victor
这是我发现上传的唯一解决方案。我忘了告诉你需要把文件扩展名放在文件名上,如options.fileName = imageURI.substr(imageURI.lastIndexOf('/')+ 1)+“。png”; - A. Magalhães
抱歉。但我没有更多的选择。 - A. Magalhães


您不能在Phonegap上使用输入文件。它不受支持。你需要做这样的事情:

        <div ng-click="selectPicture()">selectPicture</div> // Put own HTML format but call the fuction

        // Angular fuction
             $scope.selectPicture = function () {
                var srcType = Camera.PictureSourceType.SAVEDPHOTOALBUM;
                var options = {
                    // Some common settings are 20, 50, and 100
                    quality: 50,
                    destinationType: Camera.DestinationType.FILE_URI,
                    // In this app, dynamically set the picture source, Camera or photo gallery
                    sourceType: srcType,
                    encodingType: Camera.EncodingType.JPEG,
                    mediaType: Camera.MediaType.PICTURE,
                    allowEdit: true,
                    correctOrientation: true  //Corrects Android orientation quirks
                }
                navigator.camera.getPicture(function cameraSuccess(imageUri) {
                    MobileUploadFile(imageUri);

                }, function cameraError(error) {
                    console.debug("Unable to obtain picture: " + error, "app");
                }, options);
            }

            function MobileUploadFile(imageURI) {
                //console.log(imageURI);   
                var options = new FileUploadOptions();
                options.fileKey = "file";
                options.fileName = imageURI.substr(imageURI.lastIndexOf('/') + 1);
                options.mimeType="image/jpeg";
                options.chunkedMode = false;

                var ft = new FileTransfer();
                ft.upload(imageURI, encodeURI("http://www.example.com/upload.php"), function(result){
                    //console.log(JSON.stringify(result));
                }, function(error){
                    //console.log(JSON.stringify(error));
                }, options);
            };

     // php file
     <?php 
       // Directory where uploaded images are saved
        $dirname = "uploads/"; 
        // If uploading file
         if ($_FILES) {
             print_r($_FILES);
             mkdir ($dirname, 0777, true);
             move_uploaded_file($_FILES["file"]{"tmp_name"],$dirname."/".$_FILES["file"]["name"]);
        }
      ?>

0
2018-02-23 10:10