13、go的TCP网络编程
创建客户端
func main() {
// 所需的网络编程全都在net包下
conn, err := net.Dial("tcp", "127.0.0.1:8888")
fmt.Println("客户端启动")
if err != nil { // 连接失败
fmt.Println("客户端连接失败:", err)
return
}
fmt.Println("连接成功:", conn)
}
创建服务端
func main() {
fmt.Println("服务端启动了")
// 进行监听
listen, err := net.Listen("tcp", "127.0.0.1:8888")
if err != nil { // 监听失败
fmt.Println("监听失败:", err)
return
}
// 监听成功以后:
// 等待客户端连接
for {
conn, err2 := listen.Accept()
if err2 != nil { // 客户端等待失败
fmt.Println("客户端等待失败:", err2)
} else {
// 连接成功
fmt.Printf("等待连接成功:%v, 接收到的客户端信息:%v \n", conn, conn.RemoteAddr().String())
}
}
}
连接测试
先启动服务端:
再启动客户端:
客户端正常启动完成后,再回看服务端:
可以继续测试,再启动一次客户端:
回看服务端:可以看到一个新的连接
发送终端数据
服务端:
func process(conn net.Conn) {
// 连接用完一定要关闭
defer conn.Close()
for true {
// 创建一个切片,准备把读取的数据放入切片
bytes := make([]byte, 1024)
// 从conn连接中读取数据
read, err := conn.Read(bytes)
if err != nil {
return
}
fmt.Println(string(bytes[0:read]))
}
}
func main() {
fmt.Println("服务端启动了")
// 进行监听
listen, err := net.Listen("tcp", "127.0.0.1:8888")
if err != nil { // 监听失败
fmt.Println("监听失败:", err)
return
}
// 监听成功以后:
// 等待客户端连接
for {
conn, err2 := listen.Accept()
if err2 != nil { // 客户端等待失败
fmt.Println("客户端等待失败:", err2)
} else {
// 连接成功
fmt.Printf("等待连接成功:%v, 接收到的客户端信息:%v \n", conn, conn.RemoteAddr().String())
}
//准备个协程处理客户端服务的请求
go process(conn)
}
}
客户端:
func main() {
// 所需的网络编程全都在net包下
conn, err := net.Dial("tcp", "127.0.0.1:8888")
fmt.Println("客户端启动")
if err != nil { // 连接失败
fmt.Println("客户端连接失败:", err)
return
}
fmt.Println("连接成功:", conn)
// 通过客户端发送单行数据,然后退出
reader := bufio.NewReader(os.Stdin) //os.Stdin代表终端标准输入
// 从终端读取一行用户输入的信息
str, err := reader.ReadString('\n')
if err != nil {
fmt.Println("终端输入失败:", err)
}
// 成功,把str发给服务器
w, err2 := conn.Write([]byte(str))
if err2 != nil {
fmt.Println("连接失败:", err2)
}
fmt.Printf("终端数据通过客户端发送成功,一共发送%d字节的数据", w)
}
启动服务端:
启动客户端并在终端输入发送的内容:
服务端可以接收到:
《三体》中有句话——弱小和无知不是生存的障碍,傲慢才是。
所以我们不要做一个小青蛙