加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – Django:如何允许可疑文件操作/复制文件

发布时间:2020-12-16 23:53:17 所属栏目:Python 来源:网络整理
导读:我想做一个SusjiciousFileOperation,默认情况下django不允许. 我正在编写一个命令(通过manage.py importfiles运行),在我自己编写的Django文件存储库中导入真实文件系统上的给定目录结构. 我想,这是我的相关代码: def _handle_directory(self,directory_path

我想做一个SusjiciousFileOperation,默认情况下django不允许.

我正在编写一个命令(通过manage.py importfiles运行),在我自己编写的Django文件存储库中导入真实文件系统上的给定目录结构.

我想,这是我的相关代码:

def _handle_directory(self,directory_path,directory):
    for root,subFolders,files in os.walk(directory_path):
        for filename in files:
            self.cnt_files += 1
            new_file = File(directory=directory,filename=filename,file=os.path.join(root,filename),uploader=self.uploader)
            new_file.save()

回溯是:

Traceback (most recent call last):
  File ".manage.py",line 10,in 

full model can be found at GitHub. full command is currently on gist.github.com available.

如果您不想检查模型:我的File类的属性文件是FileField.

我假设,这个问题发生了,因为我只是“链接”到找到的文件.但是我需要复制它,对吧?如何将文件复制到文件中?

最佳答案
分析堆栈跟踪的这一部分:

File "C:Python27libsite-packagesdjangocorefilesstorage.py",in path
    raise SuspiciousFileOperation("Attempted access to '%s' denied." % name)

导致标准的Django FileSystemStorage.它希望文件在您的MEDIA_ROOT中.您的文件可以在文件系统中的任何位置,因此会出现此问题.

您应该传递类文件对象而不是文件模型的路径.实现这一目标的最简单方法是使用Django File类,它是python文件类对象的包装器.有关详细信息,请参见File object documentation.

更新:

好的,我在这里建议从文档中获取的路线:

from django.core.files import File as FileWrapper

...

path = os.path.join(root,filename)
with open(path,'r') as f:
    file_wrapper = FileWrapper(f)
    new_file = File(directory=directory,file=file_wrapper,uploader=self.uploader)
    new_file.save()

如果它工作,它应该将文件复制到您的secure_storage callable提供的位置.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读