您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

动态读取python文件并安全地执行它

5b51 2022/1/14 8:20:44 python 字数 2785 阅读 455 来源 www.jb51.cc/python

我正在编写一个应用程序,我希望用户能够输入角落案例的python文件.在我的脑海中,我能想到的最好方法是将文件保存到磁盘并将位置保存到数据库,然后使用__import __()动态导入它,然后执行它.我的问题的第一部分是:这是最好的方法吗?此外,这带来了一些非常大的安全问题.有没有办法在限制下运行他们的模块?不让它看到文件系统或任何东西?编辑:python的

概述

我正在编写一个应用程序,我希望用户能够输入角落案例的python文件.在我的脑海中,我能想到的最好方法是将文件保存到磁盘并将位置保存到数据库,然后使用__import __()动态导入它,然后执行它.我的问题的第一部分是:这是最好的方法吗?

此外,这带来了一些非常大的安全问题.有没有办法在限制下运行他们的模块?不让它看到文件系统或任何东西?

编辑:

python的执行将是从“正常”范围之外的后端服务检索数据,因此它不是一个完整的应用程序.它可能只是自定义协议的定义.

尽管对安全没什么希望.即使您使用了可笑的限制性过滤器,例如将所有内容限制为单个表达式并删除大多数内置函数,arbitrary code can be executed.禁止文件系统访问或访问其他操作系统资源,在Python中也很难,因为代码会在同一个过程中运行.有严格限制的子进程(chroot jail,ulimit等)是可能的,但这不仅是很多工作,它还排除了与宿主应用程序交互的大多数方法.

如果您的应用程序在本地运行并且具有与用户帐户相同的权限,那么最好不要担心并给予他们更多权力,因为他们不能做任何事情/他们无论如何也做不了多少,并且大多数限制都会使任务成为可能(不管它是什么)更难/更烦人.另一方面,如果代码将在服务器或其他东西上执行,则忘记在同一进程中运行它.

总结

以上是编程之家为你收集整理的动态读取python文件并安全地执行它全部内容,希望文章能够帮你解决动态读取python文件并安全地执行它所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶