色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

python檢查目錄文件權(quán)限并修改目錄文件權(quán)限的操作

瀏覽:8日期:2022-08-02 17:02:17

我就廢話不多說了,還是直接看代碼吧!

# -*- coding: utf-8 -*-# @author flynetcnimport sys, os, pwd, stat, datetime; LOG_FILE = ’/var/log/checkDirPermission.log’; nginxWritableDirs = [’/var/log/nginx’,’/usr/local/www/var’,]; otherReadableDirs = [’/var/log/nginx’,’/usr/local/www/var/log’,]; dirs = [];files = []; def logger(level, str):logFd = open(LOG_FILE, ’a’);logFd.write(datetime.datetime.now().strftime(’%Y-%m-%d %H:%M:%S.%f’)+': '+('WARNING ' if level else 'NOTICE ')+str);logFd.close(); def walktree(top, callback):for f in os.listdir(top):pathname = os.path.join(top, f);mode = os.stat(pathname).st_mode;if stat.S_ISDIR(mode):callback(pathname, True);walktree(pathname, callback);elif stat.S_ISREG(mode):callback(pathname, False);else:logger(1, 'walktree skipping %sn' % (pathname)); def collectPath(path, isDir=False):if isDir:dirs.append(path);else:files.append(path); def checkNginxWritableDirs(paths):uid = pwd.getpwnam(’nginx’).pw_uid;gid = pwd.getpwnam(’nginx’).pw_gid;for d in paths:dstat = os.stat(d);if dstat.st_uid != uid:try:os.chown(d, uid, gid);except:logger(1, 'chown(%s, nginx, nginx) failedn' % (d)); def checkOtherReadableDirs(paths, isDir=False):for d in paths:dstat = os.stat(d);if isDir:checkMode = 5;willBeMode = dstat.st_mode | stat.S_IROTH | stat.S_IXOTH;else:checkMode = 4;willBeMode = dstat.st_mode | stat.S_IROTH;if int(oct(dstat.st_mode)[-1:]) & checkMode != checkMode:try:os.chmod(d, willBeMode);except:logger(1, 'chmod(%s, %d) failedn' % (d, oct(willBeMode))); if __name__ == '__main__':for d in nginxWritableDirs:walktree(d, collectPath)dirs = dirs + files;checkNginxWritableDirs(dirs);dirs = [];files = [];for d in otherReadableDirs:walktree(d, collectPath)checkOtherReadableDirs(dirs, True);checkOtherReadableDirs(files, False);

補充知識:Python中獲取某個用戶對某個文件或目錄的訪問權(quán)限

在Python中我們通常可以使用os.access()函數(shù)來獲取當(dāng)前用戶對某個文件或目錄是否有某種權(quán)限,但是要獲取某個用戶對某個文件或目錄是否有某種權(quán)限python中沒有很好的方法直接獲取,因此我寫了個函數(shù)使用stat和pwd模塊來實現(xiàn)這一功能。

#!/usr/bin/env python# -*- coding: utf-8 -*-import osimport pwdimport statdef is_readable(path, user): user_info = pwd.getpwnam(user) uid = user_info.pw_uid gid = user_info.pw_gid s = os.stat(path) mode = s[stat.ST_MODE] return ( ((s[stat.ST_UID] == uid) and (mode & stat.S_IRUSR > 0)) or ((s[stat.ST_GID] == gid) and (mode & stat.S_IRGRP > 0)) or (mode & stat.S_IROTH > 0) )def is_writable(path, user): user_info = pwd.getpwnam(user) uid = user_info.pw_uid gid = user_info.pw_gid s = os.stat(path) mode = s[stat.ST_MODE] return ( ((s[stat.ST_UID] == uid) and (mode & stat.S_IWUSR > 0)) or ((s[stat.ST_GID] == gid) and (mode & stat.S_IWGRP > 0)) or (mode & stat.S_IWOTH > 0) )def is_executable(path, user): user_info = pwd.getpwnam(user) uid = user_info.pw_uid gid = user_info.pw_gid s = os.stat(path) mode = s[stat.ST_MODE] return ( ((s[stat.ST_UID] == uid) and (mode & stat.S_IXUSR > 0)) or ((s[stat.ST_GID] == gid) and (mode & stat.S_IXGRP > 0)) or (mode & stat.S_IXOTH > 0) )

使用方法

print is_readable(’/home’, root)print is_writable(’/home’, root)print is_executable(’/home’, root)print is_readable(’/tmp’, admin)print is_writable(’/tmp’, admin)print is_executable(’/tmp’, admin)

以上這篇python檢查目錄文件權(quán)限并修改目錄文件權(quán)限的操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 日本一区二区不卡视频 | 免费中文字幕在线 | 中国一级特黄真人毛片 | 欧美精品一区二区三区免费播放 | 国产伦码精品一区二区三区 | 成人羞羞视频国产 | 国产永久免费高清动作片www | 美女动作一级毛片 | 99热久久免费精品首页 | 成人片网址 | 国产成人精品三级在线 | 久久黄色视屏 | 国产区精品在线 | 九九大香尹人视频免费 | 狠狠色综合色综合网站久久 | 三级毛片子 | 精品中文字幕在线观看 | 亚洲国内自拍 | 国产成人亚洲精品老王 | 日产国产精品久久久久久 | 国产成人精品视频频 | 日本国产在线 | 亚洲视频一区二区三区 | 91成人精品视频 | 深夜一级毛片 | a在线观看欧美在线观看 | 久久99九九精品免费 | 日韩性网 | 色视频在线观看免费 | 欧美大陆日韩 | 久久精品国产线看观看亚洲 | 黄色网址视频在线观看 | 久久免费视频在线 | 日韩 欧美 中文 亚洲 高清 在线 | 欧美aaa级| 国产午夜精品不卡观看 | 色综合久久88色综合天天小说 | 看v片 | 国内高清久久久久久久久 | 欧美国产日韩一区二区三区 | 国产美女毛片 |