我正在开发 Cordova 3.3.0 应用程序 + Angularjs。
我正在尝试进行多部分 POST。 服务器正在等待文件,我无法上传 Base64 字符串,并且我有存储在设备中的图像的真实路径。
如果我需要使用它,我还有 Base64 图像。
cordova 不支持输入文件。 显然,出于安全原因,我无法将值设置为输入文件。
所以我必须将 or base64 转换为文件,然后进行发布。
//convert DOM img to file
var data ={
'lumen_moore_editar_usuario_rest[gender]':'M',
'lumen_moore_editar_usuario_rest[file]':file
};
$http({url: WS_EDIT_USER, method: 'POST',
data: $.param(data),
transformRequest: angular.identity,
headers: {'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'}
}).success(function(data, status, headers, config) {
console.log("EDITAR IMAGEN SUCCESS "+ data);
}).error(function(data, status, headers, config) {
console.log("EDITAR IMAGEN ERROR "+ data);
});
这可能吗? 我一直在寻找这个答案,但运气不好,我不想使用 cordova 的 FileTransfer.upload 。
抱歉我的英语不好。
谢谢!
最佳答案
我必须使用 Cordova FileTransfer,它第一次就工作了。 它包含在带有 promise 的服务中。
editProfileUserImg:function(imageURI){
var deferred = $q.defer();
var options = new FileUploadOptions();
options.fileKey="file";
options.fileName=imageURI.substr(imageURI.lastIndexOf('/')+1);
var params = {};
options.params = params;
var headers={ 'Authorization':ACCESS_TOKEN.Authorization,
'X-WSSE':ACCESS_TOKEN.XWSSE};
options.headers = headers;
var ft = new FileTransfer();
ft.upload(imageURI, encodeURI(WS_CHANCE_PIC_USER),
function(r){
console.info("Code = " + r.responseCode);
console.info("Response = " + r.response);
console.info("Sent = " + r.bytesSent);
deferred.resolve(r.response);
},
function(error){
alert("An error has occurred: Code = " + error.code);
console.error("upload error source " + error.source);
console.error("upload error target " + error.target);
deferred.reject(error);
}, options);
return deferred.promise;
}
关于javascript - Angularjs + Cordova + UploadFile 将 Img 转换为文件以执行 POST,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22565822/