校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > golang實(shí)現(xiàn)ftp實(shí)時(shí)傳輸文件的案例

golang實(shí)現(xiàn)ftp實(shí)時(shí)傳輸文件的案例

熱門(mén)標(biāo)簽:赤峰電銷(xiāo) 官渡電銷(xiāo)外呼管理系統(tǒng)怎么收費(fèi) 谷歌美發(fā)店地圖標(biāo)注 利用地圖標(biāo)注位置 杭州人工智能電銷(xiāo)機(jī)器人費(fèi)用 地圖區(qū)域圖標(biāo)注后導(dǎo)出 貴州電話(huà)智能外呼系統(tǒng) 江蘇呼叫中心外呼系統(tǒng)有效果嗎 400開(kāi)頭電話(huà)怎樣申請(qǐng)

一、項(xiàng)目簡(jiǎn)介

本項(xiàng)目主要實(shí)現(xiàn)的功能是ftp客戶(hù)端不斷地將xml文件和jpg文件實(shí)時(shí)地上傳到服務(wù)器,當(dāng)然也可以是其他格式的文件。每當(dāng)ftp客戶(hù)端取到一個(gè)文件之后,將文件上傳到服務(wù)器后,然后將其刪除。

項(xiàng)目實(shí)現(xiàn)可配置,如果開(kāi)發(fā)者有類(lèi)似的需求,只需要修改配置文件就可以使用本項(xiàng)目去完成上傳文件的功能。

本項(xiàng)目打日志是按照當(dāng)天時(shí)間來(lái)生成日志文件,每天每一種類(lèi)型的日志只打一個(gè)文件。

二、項(xiàng)目結(jié)構(gòu)圖片

三、項(xiàng)目代碼

config配置中的代碼

config.ini

[path]
  xml_path     = D:\\dian\\out\\    # xml文件所在的路徑
  img_path     = D:\\dian\\out\\wave\\ # 圖片文件所在路徑
[ftp]
  ftpfile_path   = D:\\Itudou       # 在服務(wù)器上的文件存儲(chǔ)路徑
  ftp_server_ip  = 192.168.56.1      # ftp服務(wù)器的IP
  ftp_server_port = 21           # ftp服務(wù)器的端口
  ftp_server_name = 20123762        # ftp服務(wù)器的用戶(hù)名
  ftp_server_pwd  = 123456         # ftp服務(wù)器的密碼
  local_ip     = 192.168.56.1      # 本地主機(jī)的IP
  local_port    = 80           #本地主機(jī)端口
  comm_way     = udp          #ftp的通信方式
[file]
  file_img     =.jpg          #文件后綴為img
  file_xml     =.xml          #文件后綴為xml
  log_print    = ture          #是否打日志,生產(chǎn)環(huán)境上不打日志,在調(diào)式程序的時(shí)候使用

讀配置文件的代碼

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
}

四、總結(jié)

主函數(shù):

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)
  }
}

本項(xiàng)目依賴(lài)包:

完整代碼:https://github.com/guoshijiang/go_ftp

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • golang http 連接超時(shí)和傳輸超時(shí)的例子
  • golang實(shí)現(xiàn)整型和字節(jié)數(shù)組之間的轉(zhuǎn)換操作
  • golang-gin-mgo高并發(fā)服務(wù)器搭建教程
  • Golang中優(yōu)秀的消息隊(duì)列NSQ基礎(chǔ)安裝及使用詳解
  • Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說(shuō)明
  • Golang使用第三方包viper讀取yaml配置信息操作
  • 聊聊Golang中很好用的viper配置模塊

標(biāo)簽:武漢 宜春 保定 松原 河池 鷹潭 黔西 泰安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《golang實(shí)現(xiàn)ftp實(shí)時(shí)傳輸文件的案例》,本文關(guān)鍵詞  golang,實(shí)現(xiàn),ftp,實(shí)時(shí),傳輸,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《golang實(shí)現(xiàn)ftp實(shí)時(shí)傳輸文件的案例》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于golang實(shí)現(xiàn)ftp實(shí)時(shí)傳輸文件的案例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    欧美四级电影在线观看| 国产一区 二区| 亚洲欧美日本韩国| 亚洲视频在线一区二区| 国产精品久久久久精k8| 亚洲麻豆国产自偷在线| 夜夜嗨av一区二区三区四季av| 国产精品久久久久久久久久久免费看| 国产午夜精品理论片a级大结局| 久久精品一区二区| 国产精品理论在线观看| 1区2区3区国产精品| 亚洲综合小说图片| 日韩高清在线观看| 国产精品69毛片高清亚洲| 成人a区在线观看| 在线视频你懂得一区二区三区| 在线播放日韩导航| 精品免费日韩av| 国产精品国产三级国产普通话99| 亚洲少妇最新在线视频| 亚洲va欧美va人人爽午夜| 奇米在线7777在线精品 | 日本大香伊一区二区三区| 国产91丝袜在线播放九色| 91视频www| 欧美精品一卡两卡| 国产欧美日韩激情| 亚洲国产精品综合小说图片区| 日本 国产 欧美色综合| 成人在线视频首页| 欧美三级视频在线观看| 精品三级av在线| 综合色中文字幕| 日本一区中文字幕| 99视频国产精品| 日韩欧美一二三区| 亚洲精品一卡二卡| 国产自产v一区二区三区c| 欧美性一级生活| 国产欧美一区二区精品性色超碰| 一区二区在线观看视频| 国产精品自拍av| 337p亚洲精品色噜噜噜| 国产精品电影院| 国内精品第一页| 欧美揉bbbbb揉bbbbb| 国产精品理论片在线观看| 免费成人小视频| 欧美性生活久久| 成人欧美一区二区三区在线播放| 麻豆精品视频在线观看免费| 色拍拍在线精品视频8848| 久久久亚洲国产美女国产盗摄| 午夜伦理一区二区| www.成人在线| 国产欧美精品在线观看| 久久国产日韩欧美精品| 欧美日韩中文字幕精品| 亚洲麻豆国产自偷在线| zzijzzij亚洲日本少妇熟睡| 日韩美女一区二区三区| 午夜精品在线看| 欧美视频在线不卡| 亚洲另类在线视频| 99久久精品国产一区二区三区| 久久美女艺术照精彩视频福利播放| 香蕉成人伊视频在线观看| 欧美日韩中文精品| 亚洲午夜久久久久| 欧美视频日韩视频| 亚洲成国产人片在线观看| 欧美中文一区二区三区| 亚洲影院在线观看| 69成人精品免费视频| 午夜精品久久久| 555www色欧美视频| 蜜桃av噜噜一区二区三区小说| 欧美麻豆精品久久久久久| 亚洲国产乱码最新视频| 在线播放91灌醉迷j高跟美女 | 精品综合免费视频观看| 日韩欧美另类在线| 国产经典欧美精品| 日本伊人色综合网| 欧美日韩在线播放一区| 欧美精品国产精品| 日韩女优电影在线观看| 免费成人在线播放| 久久久精品免费免费| 成年人午夜久久久| 亚洲摸摸操操av| 欧美理论片在线| 韩国三级中文字幕hd久久精品| 久久综合久久鬼色中文字| 成人一区二区在线观看| 一区二区三区中文在线观看| 欧美疯狂性受xxxxx喷水图片| 国内久久精品视频| 自拍偷拍亚洲激情| 3atv一区二区三区| 国产99久久久久| 亚洲码国产岛国毛片在线| 欧美一级艳片视频免费观看| 国产一区久久久| 一区二区激情小说| 日韩欧美第一区| 色综合久久久久久久久| 免费日本视频一区| 亚洲欧洲国产日本综合| 日韩欧美国产电影| 95精品视频在线| 精品一区二区三区在线视频| 亚洲欧洲在线观看av| 欧美一区二区免费| 99视频一区二区| 国产精品一区免费视频| 午夜精品福利一区二区蜜股av | 欧美日韩国产精品成人| 精品一区二区三区久久| 亚洲精品中文字幕在线观看| 欧美精品一区二区三区在线| 色综合色综合色综合 | 最好看的中文字幕久久| 欧美一区二区在线免费播放| 一本久道中文字幕精品亚洲嫩| 狠狠色综合色综合网络| 五月激情六月综合| 中文字幕日韩一区| 久久嫩草精品久久久精品| 6080午夜不卡| 欧美视频精品在线| 色就色 综合激情| 成人国产精品免费网站| 韩国成人在线视频| 日韩精品成人一区二区三区| 亚洲六月丁香色婷婷综合久久| 国产性做久久久久久| 精品国产一二三区| 91精品婷婷国产综合久久竹菊| 色婷婷精品大视频在线蜜桃视频 | 欧美性欧美巨大黑白大战| 成人黄色电影在线| 丁香五精品蜜臀久久久久99网站 | 精品粉嫩aⅴ一区二区三区四区| 欧美性猛交xxxxxx富婆| 色婷婷国产精品| 91福利在线免费观看| 91丨九色丨黑人外教| 99re视频这里只有精品| 成人短视频下载 | 午夜天堂影视香蕉久久| 亚洲一区在线视频观看| 亚洲与欧洲av电影| 亚洲国产日韩在线一区模特| 亚洲伊人色欲综合网| 亚洲一区二区欧美| 天天综合天天做天天综合| 日本美女一区二区三区视频| 日本va欧美va精品发布| 久久99精品国产麻豆不卡| 国产麻豆9l精品三级站| 国产不卡视频一区| 99久久99久久精品免费看蜜桃| 成人av在线一区二区三区| 成人99免费视频| 欧美网站大全在线观看| 91精品一区二区三区在线观看| 欧美xxxxx裸体时装秀| 国产日韩欧美制服另类| 亚洲欧洲国产日韩| 天堂在线一区二区| 黄色精品一二区| av电影在线不卡| 欧美狂野另类xxxxoooo| 精品国产伦理网| 中文字幕在线一区| 亚洲国产一区在线观看| 久久激情五月婷婷| av一区二区三区| 91精品国产福利| 亚洲国产精品传媒在线观看| 《视频一区视频二区| 五月天婷婷综合| 国产精品一区二区不卡| 日本乱人伦aⅴ精品| 日韩一本二本av| 国产精品嫩草99a| 婷婷综合五月天| 国产精品影视在线| 在线观看视频一区二区| 2020国产精品久久精品美国| 亚洲人成影院在线观看| 美女视频免费一区| 日本福利一区二区| 国产欧美一区二区精品性色| 视频一区二区国产| 色哟哟一区二区三区| 久久午夜色播影院免费高清 | 7777精品伊人久久久大香线蕉|