Heim >Backend-Entwicklung >Golang >So implementieren Sie die Dateiübertragungsfunktion in Golang
Dieser Artikel stellt hauptsächlich die Dateiübertragungsfunktion in Golang ausführlich vor und hat einen gewissen Referenzwert Das Beispiel in diesem Artikel gibt den spezifischen Code für die Dateiübertragung in Golang als Referenz weiter: | Verwenden Sie TCP, um die Dateiübertragung abzuschließen:
2. Der Empfänger (Server) sendet eine OK-Nachricht an den Client zurück, um zu bestätigen, dass der Dateiname erfolgreich gespeichert wurde.
3. Nach Erhalt der Nachricht beginnt der Absender (Client) mit dem Senden von Dateidaten an den Server.
4. Der Empfänger (Server) liest den Dateiinhalt und schreibt ihn in die zuvor gespeicherte Datei.
Ermitteln Sie zunächst den Dateinamen. Verwenden Sie die Funktion stat() im Betriebssystempaket, um Dateiattributinformationen abzurufen. Fügen Sie den Dateinamen und die Dateigröße in die von der Funktion zurückgegebenen Dateieigenschaften ein. Der Stat-Parametername wird im absoluten Pfad des Dateizugriffs übergeben. Die Funktion Name() in FileInfo kann den Dateinamen separat extrahieren.
func Stat(name string) (FileInfo, error) type FileInfo interface { Name() string Size() int64 Mode() FileMode ModTime() time.Time IsDir() bool Sys() interface{} }
Sender:
package main import ( "fmt" "io" "net" "os" ) func sendFile(conn net.Conn, filePath string) { // 只读打开文件 f, err := os.Open(filePath) if err != nil { fmt.Println("os.Open err:", err) return } defer f.Close() // 从本文件中,读数据,写给网络接收端。 读多少,写多少。原封不动。 buf := make([]byte, 1024) for { n, err := f.Read(buf) if err != nil { if err == io.EOF { fmt.Println("发送文件完成。") } else { fmt.Println("os.Open err:", err) } return } // 写到网络socket中 _, err = conn.Write(buf[:n]) if err != nil { fmt.Println("conn.Write err:", err) return } } } func main() { list := os.Args // 获取命令行参数 if len(list) != 2 { fmt.Println("格式为:go run xxx.go 文件绝对路径") return } // 提取 文件的绝对路径 filePath := list[1] //提取文件名 fileInfo, err := os.Stat(filePath) if err != nil { fmt.Println("os.Stat err:", err) return } fileName := fileInfo.Name() // 主动发起连接请求 conn, err := net.Dial("tcp", "127.0.0.1:8000") if err != nil { fmt.Println("net.Dial err:", err) return } defer conn.Close() // 发送文件名给 接收端 _, err = conn.Write([]byte(fileName)) if err != nil { fmt.Println("conn.Write err:", err) return } // 读取服务器回发的 OK buf := make([]byte, 1024) n, err := conn.Read(buf) if err != nil { fmt.Println("conn.Read err:", err) return } if "ok" == string(buf[:n]) { // 写文件内容给服务器——借助conn sendFile(conn, filePath) } }Empfänger:
package main import ( "fmt" "net" "os" ) func recvFile(conn net.Conn, fileName string) { // 按照文件名创建新文件 f, err := os.Create(fileName) if err != nil { fmt.Println("os.Create err:", err) return } defer f.Close() // 从 网络中读数据,写入本地文件 buf := make([]byte, 1024) for { n, _ := conn.Read(buf) if n == 0 { fmt.Println("接收文件完成。") return } // 写入本地文件,读多少,写多少。 f.Write(buf[:n]) } } func main() { // 创建用于监听的socket listener, err := net.Listen("tcp", "127.0.0.1:8000") if err != nil { fmt.Println(" net.Listen err:", err) return } defer listener.Close() fmt.Println("接收端启动成功,等待发送端发送文件!") // 阻塞监听 conn, err := listener.Accept() if err != nil { fmt.Println(" listener.Accept() err:", err) return } defer conn.Close() // 获取文件名,保存 buf := make([]byte, 1024) n, err := conn.Read(buf) if err != nil { fmt.Println(" conn.Read err:", err) return } fileName := string(buf[:n]) // 回写 ok 给发送端 conn.Write([]byte("ok")) // 获取文件内容 recvFile(conn, fileName) }
Das Obige ist der gesamte Inhalt dieses Artikels, ich hoffe, er wird für das Studium aller hilfreich sein.
Empfohlenes Lernen: „
Go-Video-Tutorial“
Das obige ist der detaillierte Inhalt vonSo implementieren Sie die Dateiübertragungsfunktion in Golang. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!