PhoneGapアプリからWebサーバーに画像を問題なくアップロードできます。しかし、私がしたいのは、写真を撮って自動的にアップロードしないことです。フォーム入力フィールドに自分の名前を入力するまで待ってから、[送信]をクリックすると、フォームが送信されて画像がアップロードされます。ファイルを処理するphpスクリプトは、名前を画像名に連結して、誰がアップロードしたかがわかるようにします。
コンテストに写真を投稿できるようにしたいのですが、投稿した写真とユーザーを一致させる方法が必要です。それほど複雑でなければ、おそらくこれを行う別の方法ですか?
これが私のアップロードするJavaScriptです
function captureSuccess(mediaFiles) {
var i, len;
for (i = 0, len = mediaFiles.length; i < len; i += 1) {
uploadFile(mediaFiles[i]);
}
}
// Called if something bad happens.
//
function captureError(error) {
var msg = 'Something went wrong'
navigator.notification.alert(msg, null, 'Uh oh!');
}
// A button will call this function
//
function captureImage() {
// Launch device camera application,
// allowing user to capture up to 2 images
navigator.device.capture.captureImage(captureSuccess, captureError, {limit: 2});
}
// Upload files to server
function uploadFile(mediaFile) {
var ft = new FileTransfer(),
path = mediaFile.fullPath,
name = mediaFile.name;
ft.upload(path,
"http://www.example.com/upload.php",
function(result) {
console.log('Upload success: ' + result.responseCode);
console.log(result.bytesSent + ' bytes sent');
var user_id = Math.floor(Math.random()*1001)
var day_uploaded = new Date().getDay();
var hour_uploaded = new Date().getHours();
var minute_uploaded = new Date().getMinutes();
var sec_uploaded = new Date().getSeconds();
var msg = 'Your file was uploaded! Your picture ID is ' + day_uploaded + hour_uploaded + minute_uploaded + sec_uploaded;
navigator.notification.alert(msg, null, 'Thanks!');
},
function(error) {
console.log('Error uploading file ' + path + ': ' + error.code);
},
{ fileName: name });
}