python - 使用 Angular 和 Django 上传文件

标签 python django angularjs django-forms django-uploads

所以,我遇到了一个找不到解决方案的问题。我正在使用 Django 开发一个应用程序,我的前端必须在 angular-js 中。现在我可以呈现表单并发布表单中的数据,但我不知道如何使用这些表单上传文件。

这是我的代码:

在 urls.py 中

url(r'^getter/$', TemplateView.as_view(template_name = "upload.html"))
url(r'^getter/test/', views.test, name = "thanks.html")

在 views.py 中

def test(request):
   upload_form = uploadform(request.POST, request.FILES)
   data = json.loads(request.body)
   file_path = data.path

在表单中

select_file = forms.FileField(label = "Choose File")

在我的 Controller 中的 js 文件中

myapp.controller('abc', function ($scope, $http)
$scope.submit = function(){
var file = document.getElementById('id_select_file').value
var json = {file : string(file)}
$http.post('test/',json)
...success fn....
...error fn...

}; });

现在的问题是如果在我看来如果我这样做

f = request.FILES['select_file']

我收到在 MultiValueDict 中找不到的错误“select_file”:{}

可能的问题是发送我的帖子请求的方式没有发送所有元数据....请帮助我解决这个问题我花了一整天寻找解决方案但无济于事。

PS:由于某些限制政策我不能使用Djangular 所以请给我不使用djangular 的解决方案。谢谢

编辑:**将文件属性应用于服务器正在接收的 json 也不起作用 **

最佳答案

我遇到了同样的问题。我找到了一个关于如何使用 Angular $http 将文件发送到 Django Forms 的有效解决方案。

指令

app.directive("filesInput", function() {
  return {
    require: "ngModel",
    link: function postLink(scope,elem,attrs,ngModel) {
      elem.on("change", function(e) {
        var files = elem[0].files;
        ngModel.$setViewValue(files);
      })
    }
  }
});

HTML

<form ng-submit="send()" enctype="multipart/form-data">
    <input type="text" ng-model="producer.name" placeholder="Name">
    <input type="file" files-input ng-model="producer.video">
</form>

Controller

$scope.send = function(){
    var fd = new FormData();
    fd.append('video', $scope.producer.video[0]);
    fd.append("name", $scope.producer.name);

    $http({
        method: 'POST',
        url: '/sendproducer/',
        headers: {
          'Content-Type': undefined
        },
        data: fd,
        transformRequest: angular.identity
    })
    .then(function (response) {
      console.log(response.data)
    })
}

DJANGO View 表单

class ProducerView(View):

    def dispatch(self, *args, **kwargs):
        return super(ProducerView, self).dispatch(*args, **kwargs)

    def post(self, request):
        form = ProducerForm(data = request.POST, files = request.FILES or None)
        if form.is_valid():
            form.save()
            return JsonResponse({"status": "success", "message": "Success"})
        return JsonResponse({"status": "error", "message": form.errors})

关于python - 使用 Angular 和 Django 上传文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24967502/

相关文章:

javascript - 如何创建多选以显示 Django 中每个选定内容的详细信息?

html - 如何在表格中固定标题?

javascript - Angularjs:在自定义指令中,我需要读取使用 ngClick 方法传递的参数

python - 如何在 gae+python 应用程序中只允许选定的用户登录?

c# - 在 C# 中运行 python 模块?

python - 我可以将字典的值分成多列并且仍然能够绘制它们吗?

javascript - 如何通过 django View 将参数传递给外部 javascript

python - 具有基于Python的框架的多个独立博客帐户

angularjs - 何时不在 AngularJS ng-repeat 中使用 'track by $index'?

安装 Spacy 模块后 Python 版本从 3.x 更改为 2.7