這篇文章給大家分享的是有關(guān)golang實現(xiàn)文件傳輸小demo的方法的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
在靖安等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站制作、成都網(wǎng)站設(shè)計、外貿(mào)營銷網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作按需求定制開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站建設(shè),全網(wǎng)整合營銷推廣,外貿(mào)網(wǎng)站制作,靖安網(wǎng)站建設(shè)費用合理。
獲取文件信息需要用到os. Stat接口,發(fā)送文件前開啟接收者(服務(wù)端),啟動客戶端先發(fā)送文件名給接收者,接收者收到文件名返回確認(rèn)信息"ok",才讀取本地文件 發(fā)送給接收者。
發(fā)送者:
package main import ( "fmt" "io" "net" "os") func main() { fmt.Println("請輸入接收者地址(IP:PORT):") var addr string fmt.Scan(&addr) fmt.Println("請輸入需要傳輸?shù)奈募?) var path string fmt.Scan(&path) info, errf := os.Stat(path) if errf != nil{ fmt.Println("os.Stat errf =", errf) return } conn, err := net.Dial("tcp", addr) if err != nil{ fmt.Println("net.Dial err =",err) return } defer conn.Close() _, err = conn.Write([]byte(info.Name())) if err != nil{ fmt.Println("conn.Write info.Name err =",err) return } var n int buf := make([]byte, 1024) n, err = conn.Read(buf) if err != nil{ fmt.Println("conn.Read ok err =", err) return } if "ok" == string(buf[:n]){ fmt.Println("ok") SendFile(path, conn) } } func SendFile(path string, conn net.Conn){ file , err := os.Open(path) if err != nil{ fmt.Println("os.Open err =", err) return } defer file.Close() buf := make([]byte, 1024 * 4) for { n, err := file.Read(buf) if err != nil{ if err == io.EOF{ fmt.Println("文件發(fā)送完畢") } else{ fmt.Println("file.Read err =",err) } return } if n == 0{ fmt.Println("文件發(fā)送完畢") break } conn.Write(buf[:n]) } }
接收者:
package main import ( "fmt" "io" "net" "os") func main() { fmt.Println("請你的地址(IP:PORT):") var addr string fmt.Scan(&addr) listenner, err := net.Listen("tcp", addr) if err != nil{ fmt.Println("net.Listen err =", err) return } defer listenner.Close() conn, errl := listenner.Accept() if errl != nil{ fmt.Println("listenner.Accept err =", errl) return } var n int buf := make([]byte, 1024) n, err = conn.Read(buf) if err != nil{ fmt.Println("conn.Read fileName err =", err) return } fileName := string(buf[:n]) n, err = conn.Write([]byte("ok")) if err != nil{ fmt.Println("conn.Write ok err =", err) return } RecvFile(fileName, conn) } func RecvFile(fileName string, conn net.Conn){ file , err := os.Create(fileName) if err != nil{ fmt.Println("os.Create err =", err) return } defer file.Close() buf := make([]byte, 1024 * 4) for{ n, err := conn.Read(buf) if err != nil{ if err == io.EOF{ fmt.Println("文件接收完成") } else { fmt.Println("conn.Read err =", err) } return } n, err = file.Write(buf[:n]) if err != nil{ fmt.Println("file.Write err =", err) break } } }
感謝各位的閱讀!關(guān)于golang實現(xiàn)文件傳輸小demo的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!