Ruby操作文件权限技巧分享

Ruby语言虽然是一个比较新型的语言,但是其灵活性易操作性使得这款解释型脚本语言的应用范围非常广泛。那么今天我们就为大家介绍有关Ruby操作文件权限的一些技巧。

为了得到一个文件的权限和所有者,我们能够是用File的uid和gid方法来实现Ruby操作文件权限:

  1. data = File.stat("somefile")   
  2. owner_id = data.uid   
  3. group_id = data.gid 

类File::Stat 有一个实力方法mode,它返回文件的权限:

  1. perms = File.stat
    ("somefile").mode 

File的chown方法能够改变一个文件的拥有者和组id:

uid = 201   


gid = 10   


File.chown(uid, 
gid, "alpha", "beta")   


f1 = File.new("delta")   


f1.chown(uid, gid)   


f2 = File.new("gamma")   


f2.chown(nil, gid) # 
Keep original owner id 

chmod 方法能够改变一个文件的权限:

File.chmod(0644, 
"epsilon", "theta")   


f = File.new("eta")   


f.chmod(0444) 

我们经常需要知道某个文件,我们是否有读或者写的权限,我们可以使用File::Stat类的一些Ruby操作文件权限实例方法:

info = File.stat("
/tmp/secrets")   


rflag = info.readable?   


wflag = info.writable?   


xflag = info.executable? 

有时我们需要区分有效的用户id,和实际的用户id,我们可以使用readable_real?, writable_real?, 和 executable_real?:

info = File.stat("/tmp/secrets")   


rflag2 = info.readable_real?   


wflag2 = info.writable_real?   


xflag2 = info.executable_real? 

可以通过比较当前进程的有效用户ID(和组ID)来测试文件的所有权,File::Stat类有实例方法 owned?和grpowned?

注意这些Ruby操作文件权限方法,很多在FileTest里面也有:

rflag = FileTest::readable?
("pentagon_files")   


# Other methods are: 
writable? executable? readable_real?   


writable_real?   


# executable_real? owned? grpowned?   


# Not found here: uid gid mode 

和进程联系在一起的umask方法决定了一个新的文件的初始权限.(unmask的具体含义去网上搜索搜索就有了).

可以通过File的类方法unmask方法来获取umask。如果指定一个参数,则umask将会被设置为这个,并且将会返回原来的umask:

相关推荐