我们一起聊聊网络编程

网络 网络管理
把分布在不同地理区域的计算机与专门的外部设备用通信线路互连成一个规模大、功能强的网络系统,从而使众多的计算机可以方便地互相传递信息、共享硬件、软件、数据信息等资源。

引入

【1】网络编程:

把分布在不同地理区域的计算机与专门的外部设备用通信线路互连成一个规模大、功能强的网络系统,从而使众多的计算机可以方便地互相传递信息、共享硬件、软件、数据信息等资源。

设备之间在网络中进行数据的传输,发送/接收数据。

【2】通信两个重要的要素:IP+PORT

【3】设备之间进行传输的时候,必须遵照一定的规则 ---》通信协议:

【4】TCP协议:可靠的

建立连接: 三次握手

释放连接:四次挥手

【5】UDP协议:不可靠的

基于TCP协议的网络通信-创建客户端

【1】调用Dial函数:(net包下)

【2】代码:

package main

import (
	"fmt"
	//所需的网络编程全部都在net包下
	"net"
)

func main()  {
	fmt.Println("客户端启动...")
	//调用Dial函数:参数需要指定tcp协议,需要指定服务器端的IP+PORT
	conn,err := net.Dial("tcp","101.201.48.167:80")
	if err != nil {
		fmt.Println("客户端连接失败:err:",err)
		return
	}
	fmt.Println("连接成功,conn:",conn)
}

基于TCP协议的网络通信-创建服务器端

【1】进行监听:(Listen函数在net包下)

【2】代码:

package main

import (
	"fmt"
	"net"
)

func main()  {
	fmt.Println("服务端启动了...")
	listen,err := net.Listen("tcp","127.0.0.1:8888")
	if err != nil {
		fmt.Println("监听失败,err:",err)
		return 
	}

	for{
		conn,err2 := listen.Accept()
		if err2 != nil {
			fmt.Println("客户端的等待失败,err2:",err2)
		}else {
			fmt.Printf("等待连接成功,con=%v,接收到的客户端信息:%v \n",conn,conn.RemoteAddr().String())
		}
	}
}

基于TCP协议的网络通信-处理终端数据

【1】客户端发送数据:

package main

import (
	"fmt"
	//所需的网络编程全部都在net包下
	"net"
	"bufio"
	"os"
)

func main()  {
	fmt.Println("客户端启动...")
	//调用Dial函数:参数需要指定tcp协议,需要指定服务器端的IP+PORT
	conn,err := net.Dial("tcp","127.0.0.1:8888")
	if err != nil {
		fmt.Println("客户端连接失败:err:",err)
		return
	}
	fmt.Println("连接成功,conn:",conn)

	//通过客户端发送单行数据,然后退出:
	reader := bufio.NewReader(os.Stdin)
	
	//从终端读取一行用户输入的信息:
	str,err := reader.ReadString('\n')
	if err != nil {
		fmt.Println("终端输入失败,err",err)
	}
	
	//将str数据发送给服务器:
	n,err := conn.Write([]byte(str))
	if err != nil {
		fmt.Println("连接失败,err:",err)
	}
	fmt.Printf("终端数据通过客户端发送成功,一共发送了%d字节的数据,并退出",n)
}

【2】服务器端接收数据:

package main

import (
	"fmt"
	"net"
)

func process(conn net.Conn)  {
	//连接用完一定要关闭:
	defer conn.Close()
	for {
		//创建一个切片,准备:将读取的数据放入切片
		buf := make([]byte, 1024)

		//从conn连接中读取数据:
		n,err := conn.Read(buf)
		if err != nil {
			return
		}
		//将读取内容在服务器端输出:
		fmt.Println(string(buf[0:n]))
	}
}

func main()  {
	fmt.Println("服务端启动了...")
	listen,err := net.Listen("tcp","127.0.0.1:8888")
	if err != nil {
		fmt.Println("监听失败,err:",err)
		return 
	}

	for{
		conn,err2 := listen.Accept()
		if err2 != nil {
			fmt.Println("客户端的等待失败,err2:",err2)
		}else {
			fmt.Printf("等待连接成功,con=%v,接收到的客户端信息:%v \n",conn,conn.RemoteAddr().String())
		}
		//准备一个协程,协程处理客户端服务请求:
		//不同的客户端的请求,连接conn不一样的
		go process(conn)
	}
}
责任编辑:武晓燕 来源: 今日头条
相关推荐

2023-07-11 08:34:25

参数流程类型

2023-07-04 13:36:00

同步工具类Phaser

2023-08-04 08:20:56

DockerfileDocker工具

2022-05-24 08:21:16

数据安全API

2023-06-30 08:18:51

敏捷开发模式

2023-09-10 21:42:31

2024-02-20 21:34:16

循环GolangGo

2021-08-27 07:06:10

IOJava抽象

2024-02-19 10:11:00

Kubernetes网络模型

2023-11-29 07:10:50

python协程异步编程

2023-07-24 09:41:08

自动驾驶技术交通

2023-03-26 23:47:32

Go内存模型

2022-02-23 08:41:58

NATIPv4IPv6

2022-09-22 08:06:29

计算机平板微信

2024-07-26 09:47:28

2022-10-08 00:00:05

SQL机制结构

2021-08-12 07:49:24

mysql

2022-11-12 12:33:38

CSS预处理器Sass

2022-02-14 07:03:31

网站安全MFA

2022-04-06 08:23:57

指针函数代码
点赞
收藏

51CTO技术栈公众号