文件同步
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
4 年前
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. package main
  2. import (
  3. "fmt"
  4. _ "fmt"
  5. "fts/config"
  6. "fts/websocket"
  7. "github.com/fsnotify/fsnotify"
  8. _ "github.com/ipfs/go-ipfs-api"
  9. "io"
  10. "log"
  11. "net/http"
  12. "os"
  13. _ "os"
  14. "path/filepath"
  15. _ "strings"
  16. )
  17. func main() {
  18. config.InitConfig()
  19. //日志设置
  20. _,err := os.Stat(config.LocalWorkSpaceDir)
  21. if err != nil {
  22. //创建文件目录
  23. os.MkdirAll(config.LocalWorkSpaceDir, os.ModePerm)
  24. }
  25. logpath :=config.LocalWorkSpaceDir+"\\"+"fts.log"
  26. logFile, err := os.OpenFile(logpath, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0644)
  27. if err != nil {
  28. log.Printf("open log file failed, err:", err)
  29. return
  30. }
  31. multiWriter := io.MultiWriter(os.Stdout,logFile)
  32. log.SetOutput(multiWriter)
  33. log.SetPrefix("[fts] ")
  34. log.SetFlags(log.Ldate | log.Ltime | log.Lshortfile)
  35. //handle.InitLocalWorkSpace(nil,"324523676458291200","11.4")
  36. //http://localhost:7777/ws
  37. http.HandleFunc("/upload", websocket.UploadHandler)
  38. http.HandleFunc("/subscriptionFileChange", websocket.SubscriptionFileChangeHandler)
  39. http.HandleFunc("/download", websocket.DownloadHandler)
  40. http.HandleFunc("/init", websocket.InitLocalWorkSpaceHandler)
  41. http.HandleFunc("/getFolderFileInfo", websocket.GetFolderFileInfoHandler)
  42. //服务端启动
  43. log.Println("服务启动成功,监听端口7777,等待连接。")
  44. http.ListenAndServe("0.0.0.0:7777", nil)
  45. }
  46. //func main() {
  47. // watch, _ := fsnotify.NewWatcher()
  48. // w := Watch{
  49. // watch: watch,
  50. // }
  51. // w.watchDir("C:\\Users\\yuan_rh\\easycloud\\324523676458291200");
  52. // select {};
  53. //}
  54. type Watch struct {
  55. watch *fsnotify.Watcher;
  56. }
  57. //监控目录
  58. func (w *Watch) watchDir(dir string) {
  59. //通过Walk来遍历目录下的所有子目录
  60. filepath.Walk(dir, func(path string, info os.FileInfo, err error) error {
  61. //这里判断是否为目录,只需监控目录即可
  62. //目录下的文件也在监控范围内,不需要我们一个一个加
  63. if info.IsDir() {
  64. path, err := filepath.Abs(path);
  65. if err != nil {
  66. return err;
  67. }
  68. err = w.watch.Add(path);
  69. if err != nil {
  70. return err;
  71. }
  72. fmt.Println("监控 : ", path);
  73. }
  74. return nil;
  75. });
  76. go func() {
  77. for {
  78. select {
  79. case ev := <-w.watch.Events:
  80. {
  81. if ev.Op&fsnotify.Create == fsnotify.Create {
  82. fmt.Println("创建文件 : ", ev.Name);
  83. //这里获取新创建文件的信息,如果是目录,则加入监控中
  84. fi, err := os.Stat(ev.Name);
  85. if err == nil && fi.IsDir() {
  86. w.watch.Add(ev.Name);
  87. fmt.Println("添加监控 : ", ev.Name);
  88. }
  89. }
  90. if ev.Op&fsnotify.Write == fsnotify.Write {
  91. fmt.Println("写入文件 : ", ev.Name);
  92. }
  93. if ev.Op&fsnotify.Remove == fsnotify.Remove {
  94. fmt.Println("删除文件 : ", ev.Name);
  95. //如果删除文件是目录,则移除监控
  96. fi, err := os.Stat(ev.Name);
  97. if err == nil && fi.IsDir() {
  98. w.watch.Remove(ev.Name);
  99. fmt.Println("删除监控 : ", ev.Name);
  100. }
  101. }
  102. if ev.Op&fsnotify.Rename == fsnotify.Rename {
  103. fmt.Println("重命名文件 : ", ev.Name);
  104. //如果重命名文件是目录,则移除监控
  105. //注意这里无法使用os.Stat来判断是否是目录了
  106. //因为重命名后,go已经无法找到原文件来获取信息了
  107. //所以这里就简单粗爆的直接remove好了
  108. w.watch.Remove(ev.Name);
  109. }
  110. if ev.Op&fsnotify.Chmod == fsnotify.Chmod {
  111. fmt.Println("修改权限 : ", ev.Name);
  112. }
  113. }
  114. case err := <-w.watch.Errors:
  115. {
  116. fmt.Println("error : ", err);
  117. return;
  118. }
  119. }
  120. }
  121. }();
  122. }