我有一个用Python编写的安装脚本(在linux中)以root身份运行,需要检查某些文件是否可由非root用户读取.
出于这个原因,我不能使用os.path.exists()或open(filename)(并捕获任何异常).
目前我正在考虑检查每个文件的权限位,但唯一的问题是我必须检查通向文件名的路径上的权限位(目录需要设置rx位),这可能如果我有成千上万的文件,那么进程会很慢.
我的解决方案是最好的解决方案,还是有更好的选择?
编辑:我需要在检查文件后以root身份运行脚本,因此不幸的是,删除root权限不是一个选项.
最佳答案您可以使用os.seteuid将有效用户更改为某些非root用户.然后尝试打开文件.如果权限被拒绝,将引发IOError.import osos.seteuID(65534) # user 65534 is `nobody`filename='/etc/passwd-'try: open(filename,'r')except IOError as err: print(err)# [Errno 13] Permission denIEd: '/etc/passwd-'
总结 以上是内存溢出为你收集整理的python – 检查非root用户是否可以访问路径全部内容,希望文章能够帮你解决python – 检查非root用户是否可以访问路径所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)