2016-07-14 15 views
1

私はphonegap、 my appを使用してアプリケーションを開発しています。カメラまたはギャラリーから画像をキャプチャして、特定のフォルダに移動した後、サーバにアップロードします。フォームからいくつかのデータもアップロードします。 私の問題は、ギャラリーの画像を使用するとすべてが機能しますが、カメラから取り込むと機能しません。ここに私のコードjsがあります。ajaxを使用してphonegapで画像をアップロード

var pictureSource; // picture source 
var destinationType; // sets the format of returned value 
document.addEventListener("deviceready",onDeviceReady,false); 

function onDeviceReady() { 
pictureSource=navigator.camera.PictureSourceType; 
destinationType=navigator.camera.DestinationType; 
} 

function onPhotoDataSuccess(imageURI) { 

var Image = document.getElementById('Image'); 
var form = document.getElementById('up'); 
var b1 = document.getElementById('b1'); 
var b2 = document.getElementById('b2'); 
Image.style.display = 'block'; 
form.style.display = 'block'; 
b1.style.display = 'none'; 
b2.style.display = 'none'; 
Image.src = imageURI; 
movePic(imageURI); 
} 

function capturePhoto() { 
// Take picture using device camera and retrieve image 
navigator.camera.getPicture(onPhotoDataSuccess, onFail, { quality: 50, 
destinationType: destinationType.FILE_URI, 
}); 
} 

function getPhoto(source) { 
navigator.camera.getPicture(onPhotoDataSuccess, onFail, { quality: 50, 
    destinationType: destinationType.FILE_URI, 
    sourceType: source }); 
} 

function onFail(message) { 
alert('Failed because: ' + message); 
} 

/*****************save*****************/ 

function movePic(file){ 
    window.resolveLocalFileSystemURI(file, resolveOnSuccess, resOnError); 
} 
//Callback function when the file system uri has been resolved 
function resolveOnSuccess(entry){ 
var d = new Date(); 
var n = d.getTime(); 
var newFileName = n + ".jpg"; 
var myFolderApp = "folder"; 
window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, function(fileSys) { 
    //creo la cartella geofolder e salvo le foto scattate 
    fileSys.root.getDirectory(myFolderApp, 
      {create:true, exclusive: false}, 
      function(myFolderApp) { 
       entry.moveTo(myFolderApp, newFileName, successMove,           resOnError); 
       document.forms['up'].foto.value = newFileName; 

      }, 
      resOnError); 
    }, 
    resOnError); 
return newFileName; 
} 

//Callback function when the file has been moved successfully 
function successMove(entry) { 
//Store imagepath in session for future use 
// like to store it in database 
sessionStorage.setItem('imagepath', entry.fullPath); 
} 

function resOnError() { 
alert(error.code); 
} 

////upload/// 

$("#upload").click(function(){ 
    //some variable 

    uploadimage(foto); 
    $.ajax({ 
     type: "POST", 
     url: "http://x.org/upload.php", 
     data: {//some data from the form}, 
     success: function(responce){ 
      if(responce=='success') 
      { 
      alert('ok'); 
      } 
      else 
      { 
      alert("errore"); 

      } 
     } 
    }); 
    return false;}); 

function uploadimage(foto) { 

var Image = document.getElementById('Image').getAttribute("src"); 

var options = new FileUploadOptions(); 
options.fileKey="file"; 
options.fileName=foto; 
options.mimeType="image/jpeg"; 

var params = new Object(); 
params.nome = "test"; 

options.params = params; 
options.chunkedMode = false; 

var ft = new FileTransfer(); 
ft.upload(Image, "http://x.org/uploadphoto.php", win, fail, options); 
} 

function win() { 
alert("ok bro"); 
} 
function fail() { 
alert("not bro"); 

} 

答えて

1

問題がmovePic()機能である:

あなたは、あなたがそれを動かすため、もはや存在しないURIをアップロードしようとしています!

entry.copyTo() 代わりの

entry.moveTo(); 
を試してみてください
関連する問題