鸳鸯亭资源网 Design By www.gvabc.com
一、项目简介
本项目主要实现的功能是ftp客户端不断地将xml文件和jpg文件实时地上传到服务器,当然也可以是其他格式的文件。每当ftp客户端取到一个文件之后,将文件上传到服务器后,然后将其删除。
项目实现可配置,如果开发者有类似的需求,只需要修改配置文件就可以使用本项目去完成上传文件的功能。
本项目打日志是按照当天时间来生成日志文件,每天每一种类型的日志只打一个文件。
二、项目结构图片
三、项目代码
config配置中的代码
config.ini
[path] xml_path = D:\\dian\\out\\ # xml文件所在的路径 img_path = D:\\dian\\out\\wave\\ # 图片文件所在路径 [ftp] ftpfile_path = D:\\Itudou # 在服务器上的文件存储路径 ftp_server_ip = 192.168.56.1 # ftp服务器的IP ftp_server_port = 21 # ftp服务器的端口 ftp_server_name = 20123762 # ftp服务器的用户名 ftp_server_pwd = 123456 # ftp服务器的密码 local_ip = 192.168.56.1 # 本地主机的IP local_port = 80 #本地主机端口 comm_way = udp #ftp的通信方式 [file] file_img =.jpg #文件后缀为img file_xml =.xml #文件后缀为xml log_print = ture #是否打日志,生产环境上不打日志,在调式程序的时候使用
读配置文件的代码
daos_config.go
package daosconfig import ( "bufio" "io" "os" "strings" ) type Config struct { Mymap map[string]string strcet string } func (c *Config) InitConfig(path string) { c.Mymap = make(map[string]string) f, err := os.Open(path) if err != nil { panic(err) } defer f.Close() r := bufio.NewReader(f) for { b, _, err := r.ReadLine() if err != nil { if err == io.EOF { break } panic(err) } s := strings.TrimSpace(string(b)) if strings.Index(s, "#") == 0 { continue } n1 := strings.Index(s, "[") n2 := strings.LastIndex(s, "]") if n1 > -1 && n2 > -1 && n2 > n1+1 { c.strcet = strings.TrimSpace(s[n1+1 : n2]) continue } if len(c.strcet) == 0 { continue } index := strings.Index(s, "=") if index < 0 { continue } frist := strings.TrimSpace(s[:index]) if len(frist) == 0 { continue } second := strings.TrimSpace(s[index+1:]) pos := strings.Index(second, "\t#") if pos > -1 { second = second[0:pos] } pos = strings.Index(second, " #") if pos > -1 { second = second[0:pos] } pos = strings.Index(second, "\t//") if pos > -1 { second = second[0:pos] } pos = strings.Index(second, " //") if pos > -1 { second = second[0:pos] } if len(second) == 0 { continue } key := c.strcet + "=" + frist c.Mymap[key] = strings.TrimSpace(second) } } func (c Config) Read(node, key string) string { key = node + "=" + key v, found := c.Mymap[key] if !found { return "" } return v }
ftp上传文件核心代码
daos_ftp.go
package daosftp import ( "fmt" "net" "os" "strings" ftp "github.com/ftp" "io/ioutil" "regexp" "path/filepath" cfg "bjdaos_tool/pkg/daosconfig" "bjdaos_tool/pkg/env" "bjdaos_tool/pkg/daoslog" ) func getListDir(dirPth string) (files []string,files1 []string, err error) { dir, err := ioutil.ReadDir(dirPth) if err != nil { return nil,nil, err } PthSep := string(os.PathSeparator) for _, fi := range dir { if fi.IsDir() { files1 = append(files1, dirPth+PthSep+fi.Name()) getListDir(dirPth + PthSep + fi.Name()) }else{ files = append(files, dirPth+PthSep+fi.Name()) } } return files,files1, nil } func GetAllFileName(path string, str string) (int, []string ) { configPath := env.GetConfigPath() ftpConfig := new(cfg.Config) ftpConfig.InitConfig(configPath + "\\config.ini") logPrint := ftpConfig.Read("file", "log_print") files, _, err := getListDir(path) if err != nil { daoslog.WriteLog(logPrint, "System","get file path err") } fileLen := len(files) fileSlice := make([]string,0, fileLen) suffix1 := ftpConfig.Read("file", "file_img") suffix2 := ftpConfig.Read("file", "file_xml") reg_front := regexp.MustCompile("\\d{8}") reg_end := regexp.MustCompile("\\d{14}") if str == suffix1{ for i := 0; i < fileLen; i++{ data_front := reg_front.FindString(files[i]) date_end := reg_end.FindString(files[i]) imgName := data_front + "_" + date_end + str fileSlice = append(fileSlice, imgName) } }else if str == suffix2 { for i := 0; i < fileLen; i++{ data_front := reg_front.FindString(files[i]) date_end := reg_end.FindString(files[i]) imgName := data_front + "_" + date_end + str fileSlice = append(fileSlice, imgName) } } return fileLen, fileSlice } func getLocalIpAddr() string { configPath := env.GetConfigPath() ftpConfig := new(cfg.Config) ftpConfig.InitConfig(configPath + "\\config.ini") logPrint := ftpConfig.Read("file", "log_print") network := ftpConfig.Read("ftp", "comm_way") ip := ftpConfig.Read("ftp", "local_ip") port := ftpConfig.Read("ftp", "local_port") address := ip + ":" + port conn, err := net.Dial(network, address) if err != nil { daoslog.WriteLog(logPrint, "System", "get local ip address err") return "127.0.0.1" } defer conn.Close() return strings.Split(conn.LocalAddr().String(), ":")[0] } func ftpUploadFile(ftpserver, ftpuser, pw, localFile, remoteSavePath, saveName string) { configPath := env.GetConfigPath() ftpConfig := new(cfg.Config) ftpConfig.InitConfig(configPath + "\\config.ini") logPrint := ftpConfig.Read("file", "log_print") ftpfile_path := ftpConfig.Read("ftp", "ftpfile_path") ftp, err := ftp.Connect(ftpserver) if err != nil { daoslog.WriteLog(logPrint, "System", "connect err") } err = ftp.Login(ftpuser, pw) if err != nil { daoslog.WriteLog(logPrint, "System", "Login err") } ftp.ChangeDir(ftpfile_path) dir, err := ftp.CurrentDir() ftp.MakeDir(remoteSavePath) ftp.ChangeDir(remoteSavePath) dir, _ = ftp.CurrentDir() daoslog.WriteLog(logPrint, "System", dir) file, err := os.Open(localFile) if err != nil { daoslog.WriteLog(logPrint, "System", "Open err") } defer file.Close() err = ftp.Stor(saveName, file) if err != nil { daoslog.WriteLog(logPrint, "System", "Stor err") } ftp.Logout() ftp.Quit() logcotent := fmt.Sprintf("%s:%s","success upload file",localFile) daoslog.WriteLog(logPrint, "System", logcotent) } func RemoveFile(filePath string, fileName string){ configPath := env.GetConfigPath() ftpConfig := new(cfg.Config) ftpConfig.InitConfig(configPath + "\\config.ini") logPrint := ftpConfig.Read("file", "log_print") err := os.Remove(filePath + fileName) if err != nil { daoslog.WriteLog("false", "System", "file remove err!") } else { logcotent := fmt.Sprintf("%s:%s","file remove OK!",fileName) daoslog.WriteLog(logPrint, "System", logcotent) } } func SendXmlFileToFtpServer(filePath string, fileType string) { configPath := env.GetConfigPath() ftpConfig := new(cfg.Config) ftpConfig.InitConfig(configPath + "\\config.ini") logPrint := ftpConfig.Read("file", "log_print") flen, fileName := GetAllFileName(filePath, fileType) serverIp := getLocalIpAddr() ftpserverip := ftpConfig.Read("ftp", "ftp_server_ip") ftpPort := ftpConfig.Read("ftp", "ftp_server_port") ftpuser := ftpConfig.Read("ftp", "ftp_server_name") pw := ftpConfig.Read("ftp", "ftp_server_pwd") ftpserver := ftpserverip + ":" + ftpPort filepath.Walk(filePath, func(path string, f os.FileInfo, err error) error { if f == nil { return err } if f.IsDir() { return nil } for i := 0; i < flen; i++{ if f.Name() == fileName[i] { logcotent := fmt.Sprintf("path=",path) daoslog.WriteLog(logPrint, "System", logcotent) pathFields := strings.Split(path, "\\") var domainName string if len(pathFields) > 3 { domainName = pathFields[len(pathFields)-3] } ftpUploadFile(ftpserver, ftpuser, pw, path, domainName, serverIp+"_"+fileName[i]) RemoveFile(filePath, fileName[i]) } } return nil }) } func SendJpgFileToFtpServer(filePath string, fileType string) { configPath := env.GetConfigPath() ftpConfig := new(cfg.Config) ftpConfig.InitConfig(configPath + "\\config.ini") logPrint := ftpConfig.Read("file", "log_print") flen, fileName := GetAllFileName(filePath, fileType) serverIp := getLocalIpAddr() ftpserverip := ftpConfig.Read("ftp", "ftp_server_ip") ftpPort := ftpConfig.Read("ftp", "ftp_server_port") ftpuser := ftpConfig.Read("ftp", "ftp_server_name") pw := ftpConfig.Read("ftp", "ftp_server_pwd") ftpserver := ftpserverip + ":" + ftpPort filepath.Walk(filePath, func(path string, f os.FileInfo, err error) error { if f == nil { return err } if f.IsDir() { return nil } for i := 0; i < flen; i++{ if f.Name() == fileName[i] { logcotent := fmt.Sprintf("path=",path) daoslog.WriteLog(logPrint, "System", logcotent) pathFields := strings.Split(path, "\\") var domainName string if len(pathFields) > 3 { domainName = pathFields[len(pathFields)-3] } ftpUploadFile(ftpserver, ftpuser, pw, path, domainName, serverIp+"_"+fileName[i]) RemoveFile(filePath, fileName[i]) } } return nil }) }
打日志的代码
daos_log.go
package daoslog import ( "fmt" "log" "os" "github.com/golang/glog" "time" "bjdaos_tool/pkg/env" ) func WriteLog(islog, logtype , errcontent string) { if islog == "false" { return } if logtype != "Info" && logtype!= "Debug" && logtype!= "Error" && logtype != "System" { glog.Error("this is not a logtype ") return } data := time.Now().Format("20060102") logPath := env.GetConLogPath() logFilea := logPath + "\\" + data+"_"+ logtype+".log" errcontent = "[" +errcontent + "]" logFile, err := os.OpenFile(logFilea, os.O_RDWR | os.O_CREATE, 0777) if err != nil { fmt.Printf("open file error=%s\r\n", err.Error()) os.Exit(-1) } logger := log.New(logFile, "{"+logtype+"} ", log.Ldate | log.Ltime | log.Lshortfile) logger.Println(errcontent) }
路径处理代码
daos-evn.go
package env import ( "os" "runtime" ) var ostype = runtime.GOOS func GetProjectPath() string{ var projectPath string projectPath, _ = os.Getwd() return projectPath } func GetConfigPath() string{ path := GetProjectPath() if ostype == "windows"{ path = path + "\\" + "config\\" }else if ostype == "linux"{ path = path +"/" + "config/" } return path } func GetConLogPath() string{ path := GetProjectPath() if ostype == "windows"{ path = path + "\\log\\" }else if ostype == "linux"{ path = path + "/log/" } return path }
四、总结
主函数:
main.go
package main import ( "bjdaos_tool/pkg/daosftp" "bjdaos_tool/pkg/env" cfg "bjdaos_tool/pkg/daosconfig" ) func main(){ configPath := env.GetConfigPath() ftpConfig := new(cfg.Config) ftpConfig.InitConfig(configPath + "\\config.ini") xml_path := ftpConfig.Read("path", "xml_path") img_path := ftpConfig.Read("path", "img_path") file_img := ftpConfig.Read("file", "file_img") file_xml := ftpConfig.Read("file", "file_xml") for{ daosftp.SendXmlFileToFtpServer(xml_path, file_xml) daosftp.SendJpgFileToFtpServer(img_path, file_img) } }
本项目依赖包:
完整代码:https://github.com/guoshijiang/go_ftp
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
标签:
golang,ftp实时传输文件
鸳鸯亭资源网 Design By www.gvabc.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
鸳鸯亭资源网 Design By www.gvabc.com
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2025年01月07日
2025年01月07日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]