Skip to content

Latest commit

 

History

History
55 lines (41 loc) · 1.37 KB

08.13.md

File metadata and controls

55 lines (41 loc) · 1.37 KB

#文件权限

Unix系统编程中的一个热门话题是Unix文件权限。在本节中,假设你有足够的Unix权限,你将学习如何输出任意文件的权限!程序名为permission.go,分为三部分。

permission.go的第一部分代码如下:

package main

import (
	"fmt"
	"os"
)

permission.go的第二部分代码如下:

func main() {
	arguments := os.Args
	if len(arguments) == 1 {
		fmt.Printf("usage:permissions filename\n")
		return
	}

最后一部分代码如下:

	filename := arguments[1]
	info, _ := os.Stat(filename)
	mode := info.Mode()
	fmt.Println(filename, "mode is", mode.String()[1:10])
}

os.Stat(filename)调用返回一个大结构体,其中包含了许多数据。因为我们只对文件的权限感兴趣,我们调用Mode()方式并打印输出。实际上,我们通过mode.String()[1:10]打印了输出的一部分,因为它即是我们感兴趣的那部分。

执行permission.go将产生如下输出:

$ go run permission.go /tmp/adobegc.log
/tmp/adobegc.log mode is rw-rw-rw-
$ go run permissions.go /dev/random
/dev/random mode is crw-rw-rw

ls(1)输出可以验证permission.go的正确性:

$ ls -l /dev/random /tmp/adobegc.log
crw-rw-rw- 1 root wheel 14,   0 Jan 8 20:24 /dev/random
-rw-rw-rw- 1 root wheel  583454 Jan 16 19:12 /tmp/adobegc.log