1

我正在尝试将从相机捕获的图像上传到服务器。下面的方法适用于任何 Android 设备,但由于某种原因,它在 iOS 上失败了。它返回一个 401 错误,这没有意义:

var options = new FileUploadOptions();
    options.fileKey="files[]";
    options.fileName = 'image_' + obj.id + '.jpg';
    options.mimeType="image/jpeg";
    options.chunkedMode = false;

    var params = new Object();
    params.headers = {
        Authorization: 'Basic ' + loginCreds
    }

    options.params = params;
    var ft = new FileTransfer();
    ft.upload(imageURI, CONTEXT+'URL/files", 
        function(r){
            alert('Finished upload!');
            $.mobile.loading( 'hide' );  
        }, 
        function(error){
            console.log(error.http_status);
            alert('Error uploading image: ' +error.http_status+ ' and code - ' +error.code); 
            $.mobile.loading( 'hide' );  
        }, 
        options, true);

我知道在 iOS 中设置标题存在问题,但我认为从 Phonegap 1.9.0 开始就已修复。我在这里做错了吗?

我检查了服务器日志,似乎授权标头只是没有在 iOS 中设置。奇怪的...

4

1 回答 1

6

因此,经过一整天的角力,想出了这个。事实证明,Android 和 iOS 在获取 headers 参数的方式上有所不同。

安卓:

var params = new Object();
params.headers = {Authorization: 'Basic ' + loginCreds};
options.params = params;

或者

options.headers = {Authorization: 'Basic ' + loginCreds};

IOS:

options.headers = {Authorization: 'Basic ' + loginCreds};

希望这可以在某个地方节省一些人的头疼...

于 2013-01-14T21:23:42.697 回答