-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathos.go
262 lines (248 loc) · 5.34 KB
/
os.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
package z
import (
"archive/tar"
"archive/zip"
"bufio"
"bytes"
"compress/gzip"
"crypto/md5"
"crypto/sha1"
"fmt"
"hash"
"io"
"io/ioutil"
"log"
"os"
"os/exec"
"path/filepath"
"regexp"
"strings"
)
// 获取本地MAC地址,只限Linux系统
func GetMac() string {
var mac string
var stdout, stderr bytes.Buffer
cmd := exec.Command("/sbin/ifconfig", "-a")
cmd.Stdout = &stdout
cmd.Stderr = &stderr
cmd.Run()
sOut := stdout.String()
sErr := stderr.String()
if len(sErr) == 0 {
rx, _ := regexp.Compile("[0-9A-F]{2}:[0-9A-F]{2}:[0-9A-F]{2}:[0-9A-F]{2}:[0-9A-F]{2}:[0-9A-F]{2}")
macStr := rx.FindString(strings.ToUpper(sOut))
str := strings.ToUpper(macStr)
mac = strings.Replace(str, ":", "", -1)
} else {
log.Panic(sErr)
}
return Trim(mac)
}
func GetIntMac(v string) string {
var mac string
var stdout, stderr bytes.Buffer
cmd := exec.Command("/sbin/ifconfig", v)
cmd.Stdout = &stdout
cmd.Stderr = &stderr
cmd.Run()
sOut := stdout.String()
sErr := stderr.String()
if len(sErr) == 0 {
rx, _ := regexp.Compile("[0-9A-F]{2}:[0-9A-F]{2}:[0-9A-F]{2}:[0-9A-F]{2}:[0-9A-F]{2}:[0-9A-F]{2}")
macStr := rx.FindString(strings.ToUpper(sOut))
str := strings.ToUpper(macStr)
mac = strings.Replace(str, ":", "", -1)
} else {
log.Panic(sErr)
}
return Trim(mac)
}
// 计算一个文件的 MD5 指纹, 文件路径为磁盘绝对路径
func MD5(ph string) string {
return Finger(md5.New(), ph)
}
// 将磁盘某个文件按照某种算法计算成加密指纹
func Finger(h hash.Hash, ph string) string {
// 打开文件
f, err := os.Open(ph)
if err != nil {
return ""
}
defer f.Close()
// 读取
io.Copy(h, bufio.NewReader(f))
// 返回计算结果
return fmt.Sprintf("%x", h.Sum(nil))
}
// 对字符串进行SHA1哈希
func StrSHA1(data string) string {
t := sha1.New()
io.WriteString(t, data)
return fmt.Sprintf("%x", t.Sum(nil))
}
// 通过唯一时间的字符串,返回唯一的SHA1哈希
func RandomSHA1() string {
return StrSHA1(UnixNano())
}
// 生成一个 UUID 字符串(小写,去掉减号),需要系统支持 "uuidgen" 命令
// 返回的字符串格式如 "1694108edc6348b08364e604dee1bf35"
func UU() string {
return strings.Replace(UU16(), "-", "", -1)
}
// 生成一个 UUID 字符串(小写),需要系统支持 "uuidgen" 命令
// 返回的字符串格式如 "1694108e-dc63-48b0-8364-e604dee1bf35"
func UU16() string {
bs, err := exec.Command("uuidgen").Output()
if nil != err {
log.Fatal("fail to found command 'uuidgen' in $PATH")
}
return strings.ToLower(TrimBytes(bs))
}
// 解压Tar文件
func Untar(file, path string) error {
// 打开文件
f, err := os.Open(file)
if err != nil {
return err
}
defer f.Close()
// 读取GZIP
gr, err := gzip.NewReader(f)
if err != nil {
return err
}
defer gr.Close()
// 读取TAR
tr := tar.NewReader(gr)
for {
hdr, err := tr.Next()
if err == io.EOF {
break
} else if err != nil {
return err
}
if hdr.FileInfo().IsDir() {
os.MkdirAll(path+string(os.PathSeparator)+hdr.Name, hdr.FileInfo().Mode())
} else {
fw, err := os.OpenFile(path+string(os.PathSeparator)+hdr.Name, os.O_CREATE|os.O_WRONLY|os.O_TRUNC, hdr.FileInfo().Mode())
if err != nil {
return err
}
defer fw.Close()
_, err = io.Copy(fw, tr)
if err != nil {
return err
}
}
}
return nil
}
// 运行命令脚本,只限Linux系统
func LinuxCmd(sh string) error {
var stderr bytes.Buffer
var stdout bytes.Buffer
cmd := exec.Command("/bin/sh", sh)
cmd.Stdout = &stdout
cmd.Stderr = &stderr
err := cmd.Run()
if err != nil {
return fmt.Errorf("[%s] [%s]", sh, err)
}
sOut := stdout.String()
if len(sOut) != 0 {
log.Println(sOut)
}
sErr := stderr.String()
if len(sErr) != 0 {
return fmt.Errorf(sh, sErr)
}
return nil
}
// 运行系统命令,只限Linux系统
func LinuxBash(sh string) error {
var stderr bytes.Buffer
var stdout bytes.Buffer
cmd := exec.Command(sh)
cmd.Stderr = &stderr
cmd.Stdout = &stdout
err := cmd.Run()
if err != nil {
return fmt.Errorf("[%s] [%s]", sh, err)
}
sOut := stdout.String()
if len(sOut) != 0 {
log.Println(sOut)
}
sErr := stderr.String()
if len(sErr) != 0 {
return fmt.Errorf(sErr)
}
return nil
}
// 创建压缩文件
func CreateZip(path, ph string) error {
// 创建写入缓冲区
buf := new(bytes.Buffer)
// 创建压缩缓冲区
w := zip.NewWriter(buf)
// 文件列表
files := make([]string, 0)
// 读取文件列表
err := filepath.Walk(path, func(aph string, f os.FileInfo, err error) error {
// 文件不存在
if f == nil {
return nil
}
// 跳过文件夹
if f.IsDir() {
return nil
}
files = append(files, Range(aph, len(path), len(aph)))
return nil
})
// 判断是否出错
if err != nil {
return err
}
// 将文件读取
for _, file := range files {
f, err := w.Create(file)
if err != nil {
return err
}
r, err := os.Open(path + "/" + file)
if err != nil {
return err
}
data, err := ioutil.ReadAll(r)
if err != nil {
return err
}
_, err = f.Write(data)
if err != nil {
return err
}
r.Close()
}
// 关闭缓冲区
err = w.Close()
if err != nil {
return err
}
// 写入
FileWF(ph, func(f *os.File) {
f.Write(buf.Bytes())
})
// 返回
return nil
}
// 字符串
func Range(str string, start, end int) string {
var data string
for i, s := range str {
if i >= start && i < end {
data += string(s)
}
}
return data
}