Ruby操作文件权限对于一个刚刚接触Ruby语言的朋友来说可能还不是很容易掌握其中的技巧。希望本文介绍的内容可以帮助我们提高实际编程能力。

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

Ruby操作文件权限技巧分享  Ruby操作文件权限 第1张

为了得到一个文件的权限和所有者,我们能够是用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:

  1. uid = 201 
  2. gid = 10 
  3. File.chown(uid, 
    gid, "alpha", "beta") 
  4. f1 = File.new("delta") 
  5. f1.chown(uid, gid) 
  6. f2 = File.new("gamma") 
  7. f2.chown(nil, gid) # 
    Keep original owner id

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

  1. File.chmod(0644, 
    "epsilon", "theta") 
  2. f = File.new("eta") 
  3. f.chmod(0444)

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

  1. info = File.stat("
    /tmp/secrets") 
  2. rflag = info.readable? 
  3. wflag = info.writable? 
  4. xflag = info.executable?

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

  1. info = File.stat("/tmp/secrets") 
  2. rflag2 = info.readable_real? 
  3. wflag2 = info.writable_real? 
  4. xflag2 = info.executable_real?

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

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

  1. rflag = FileTest::readable?
    ("pentagon_files") 
  2. # Other methods are: 
    writable? executable? readable_real? 
  3. writable_real? 
  4. # executable_real? owned? grpowned? 
  5. # Not found here: uid gid mode

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

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

  1. File.umask(0237) # 
    Set the umask 
  2. current_umask = 
    File.umask# 0237

以上就是全部全部Ruby操作文件权限的技巧方法介绍。

转载请说明出处
知优网 » Ruby操作文件权限技巧分享

发表评论

您需要后才能发表评论