загрузка файла angularjs на выбор файла с переполнением стека

Я хотел загрузить изображение после выбора без кнопки отправки.
я использовал danialfarids плагины от GitHub.
Я полагаю, он сделал сервер с C#которую я хотел изменить на php, У меня проблемы с написанием обработчика файла php.

Это мои файлы сценариев.

 var app = angular.module('fileUpload', ['ngFileUpload']);

app.controller('MyCtrl', ['$scope', 'Upload', '$timeout', function ($scope, Upload, $timeout) {
$scope.uploadPic = function(file) {
file.upload = Upload.upload({
method:'POST',
url: 'http://localhost/angular/upload.php',
data: {file: file, username: $scope.username}
});

file.upload.then(function (response) {
$timeout(function () {
file.result = response.data;
});
}, function (response) {
if (response.status > 0)
$scope.errorMsg = response.status + ': ' + response.data;
}, function (evt) {
file.progress = Math.min(100, parseInt(100.0 * evt.loaded / evt.total));
});
}
}]);

И это мой HTML-файл

<form name="myForm"  >
<fieldset>

<legend>Upload on file select</legend>
<br>Photo:
<input type="file" ngf-select="uploadPic(picFile)" ng-model="picFile" name="picFile"accept="image/*" ngf-max-size="2MB" required
ngf-model-invalid="errorFiles">

<img ng-show="myForm.file.$valid" ngf-thumbnail="picFile" class="thumb">

<br>
<button ng-disabled="!myForm.$valid"ng-click="uploadPic(picFile)">Submit</button>

<div class="con">
<div class="pg" style="width:{{picFile.progress}}%"  ></p></div>
</div>
<p ng-bind="picFile.progress + '%'"></p>
<span ng-show="picFile.result">Upload Successful</span>
<span class="err" ng-show="errorMsg">{{errorMsg}}</span>
</fieldset>
</form>

Это ксс

<style>
.thumb {
width: 240px;
height: 240px;
float: none;
position: relative;
top: 7px;
}
form .progress {
line-height: 1px;
}
.progress {
display: inline-block;
width: 300px;
}

.con{
width:300px;
}
.pg {
font-size: smaller;
background: #000000;
width:0px;
height:1px;
}
</style>

И это зачаточное upload.php (находится в localhost / angular /), и я не думаю, что это работает.

<?php if ( !empty( $_FILES ) ) {

$tempPath = $_FILES[ 'picFile' ][ 'tmp_name' ];
$uploadPath = dirname( __FILE__ ) . DIRECTORY_SEPARATOR . 'uploads' . DIRECTORY_SEPARATOR . $_FILES[ 'picFile' ][ 'name' ];

move_uploaded_file( $tempPath, $uploadPath );

$answer = array( 'answer' => 'File transfer completed' );
$json = json_encode( $answer );

echo $json; } else {

echo 'No files'; } ?>

мой xampp сервер работает. И я также включил угловые файлы, angularjs, ng-file-upload-shim.min.js а также ng-file-upload.min.js от danialfarid.

2

Решение

Я нашел ответ на этот вопрос, проблема была не в коде, проблема произошла, потому что я делал XMLHttpRequest в другой домен, чем я был. И простой способ решить эту проблему, добавив расширение для Chrome. Расширение Cors. Это решило проблему.

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]