2017-02-22 41 views
0

У меня странная проблема с PhoneGap, я пытаюсь записать видео из приложения и загрузить его на сервер.PhoneGap видеозапись и загрузка на сервер

app.initialize(); 

    $(function(){ 
     //capture callback 
     var captureSuccess = function(mediaFiles) { 
     var i, len; 
     for(i = 0, len = mediaFiles.length; i < len; i += 1) { 
      uploadFile(mediaFiles[i]); 
     } 
     }; 

     function uploadFile(mediaFiles) { 
     var options = new FileUploadOptions(); 
     options.fileKey = 'file'; 
     options.fileName = mediaFiles.name; 
     options.contentType = 'video/mp4'; 
     options.mimeType = mediaFiles.type; 
     options.chunkedMode = true; 

     var ft = new FileTransfer(); 
     var path = mediaFiles.fullPath; 
     //var name = mediaFiles.name; 

     ft.upload(path, 
      'http://domainName/~me/upload.php', 
      function(result) { //success callback 
      navigator.notification.alert('Path: ' + path + ' bytesSent: ' + result.bytesSent + ' responseCode: ' + result.responseCode + ' response: ' + result.response, null, 'Upload Error'); 
      $("#infoMessage").html('Success!'); 
      }, 
      function(error) { //error callback 
      navigator.notification.alert('Error uploading file ' + path + ', Error code: ' + error.code + ' Target: ' + error.target + ' http_status: ' + error.http_status + ' Body: ' + error.body + ' Exception: ' + error.exception.toString(), null, 'Upload Error'); 
      $("#infoMessage").html('Problem') 
      }, 

      options); 
     } 

     // capture error callback 
     var captureError = function(error) { 
     navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error'); 
     }; 

     //start video capture 
     var accessCamera = function() { 
     navigator.device.capture.captureVideo(captureSuccess, captureError, { limit:1 }); 
     }; 

       $("#cambtn").on('click', accessCamera); 

Серверная сторона работает так, как я должен был ее протестировать с помощью приложения Postman. Ответ, который я получаю от приложений PhoneGap «Успех обратного вызова» является: скрипт Screenshot

Сервера настолько основной на данный момент:

$target_dir = "uploads/"; 
if(isset($_FILES['file'])) { 
    $target_file = $target_dir . basename($_FILES["file"]["name"]); 
    move_uploaded_file($_FILES['file']['tmp_name'], $target_file); 
} 
print_r($_FILES); //This line returns empty array when request is send by the application but it returns array with data when I test it with Postman. 
die(); 

Проблема была из-за опцию chunkedMode. Он должен быть установлен в false.

ответ

0

Ваш успех функция обратного вызова говорит: «Ошибка загрузки», если вы прокрутите весь путь направо

 function(result) { //success callback 
      navigator.notification.alert('Path: ' + path + ' bytesSent: ' + result.bytesSent + ' responseCode: ' + result.responseCode + ' response: ' + result.response, null, 'Upload Error'); 
      $("#infoMessage").html('Success!'); 
+0

Этот последний параметр является только заголовок всплывающего уведомления, как вы можете видеть на скриншоте так, что это не проблема вообще. – xcentric

+0

Извините, неправильно понял ваш вопрос. Я видел «Ошибка загрузки» на вашем изображении, прежде чем увидел комментарий в коде, объясняющий ошибку. Я бы проверил монитор Android, а также журнал сервера. Вы можете заставить php написать журнал и устранить его там. Я просматриваю http://stackoverflow.com/questions/29099303/uploading-file-over-https-with-cordova-filetransfer и пытаюсь выяснить, возможно ли, что блок успеха вызван, даже если есть ошибка, если url не является белым или что-то в этом роде, –

+0

Также проверьте заголовок ('Access-Control-Allow-Origin: *'); в вашем php –

 Смежные вопросы

  • Нет связанных вопросов^_^