как я могу загрузить файл с помощью пользовательских ключей - PullRequest
0 голосов
/ 03 мая 2019

Мне нужно создать систему викторин для сайта. Я должен загрузить вопрос о типе изображения, а также параметры типа изображения на одной странице, используя angularjs и webapi. Я хочу проверить в api, какое изображение для опции и какое изображение для вопроса, в то время как массив изображений с видимым именем. Я могу показать изображения в массиве, вот мой код:

app.directive('uploadFiles', function () {
return {
    scope: true,        //create a new scope  
    link: function (scope, el, attrs) {
        el.bind('change', function (event) {
            var files = event.target.files;
            console.info(files);
            for (var i = 0; i < files.length; i++) {
                scope.$emit("seletedFile", { file: files[i] });
            }
        });
    }
};
});
app.controller('questionairController', function ($scope, $http) {
    $scope.files = [];

    $scope.$on("seletedFile", function (event, args) {
        $scope.fileList = true;
        $scope.$apply(function () {
            $scope.files.push(args.file);
        });
    });

    $scope.addQuestionair = function () {
        var cID = document.getElementById("CustomerID").value;
        var pID = document.getElementById("ProjectID").value;

        $scope.question.CustomerID = cID;
        $scope.question.ProjectID = pID;

        console.info($scope.question);
        console.info($scope.OptionsList);

        var viewObj = {
            questionair: $scope.question,
            options: $scope.OptionsList
        };

        console.info(viewObj);
        $http({
            method: 'POST',
            url: 'api/Questions/AddQuestion',
            headers: { 'Content-Type': undefined },
            uploadEventHandlers: {
                progress: function (e) {
                    if (e.lengthComputable) {
                        var progressValue = (e.loaded / e.total) * 100;
                        $scope.ProgressWidth = 0;
                        $scope.ProgressWidth = { 'width': progressValue + '%' };
                    }
                }
            },
            transformRequest: function (data) {
                console.info("in transform");
                var formData = new FormData();
                formData.append("model", angular.toJson(data.model));
                for (var i = 0; i < data.files.length; i++) {
                    formData.append(data.files[i].name, data.files[i]);
                }
                return formData;
            },
            data: { model: viewObj, files: $scope.files }
        }).then(function (response) {
            console.info(response);
            $scope.SaveMessage = response.data;
            GetQuestionair();
            $scope.question = null;
        }, function (error) {

        });
    };

Вот моя функция API

    [HttpPost]
    public HttpResponseMessage AddQuestion()
    {
        if (!Request.Content.IsMimeMultipartContent())
        {
            throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType);
        }

        HttpFileCollection hfc = HttpContext.Current.Request.Files;
        var model = HttpContext.Current.Request["model"];

        ViewModel viewModel = Newtonsoft.Json.JsonConvert.DeserializeObject<ViewModel>(model);
        if (viewModel == null)
        {
            throw new HttpResponseException(HttpStatusCode.BadRequest);
        }

        var root = HttpContext.Current.Server.MapPath("~/SiteImages/");

        if (!Directory.Exists(root))
        {
            Directory.CreateDirectory(root);
        }

        HttpPostedFile hpf = hfc[0];

        if (hpf.ContentLength > 0)
        { 
            hpf.SaveAs(root + "/" + Path.GetFileName(hpf.FileName));
        }
        {
            db.Tbl_Questionair.Add(viewModel.questionair);
            db.SaveChanges();

            foreach (var item in viewModel.options)
            {
                item.CreatedOn = DateTime.Now;
                item.QID = viewModel.questionair.ID;
                item.CustomerID = viewModel.questionair.CustomerID;
                item.ProjectID = viewModel.questionair.ProjectID;
                db.Options.Add(item);
                db.SaveChanges();
            }
            return Request.CreateResponse(HttpStatusCode.OK, "Data successfully saved!");
        }
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...