【Go】十九、网络连接与请求发送

文章目录

1、通信

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

通信两个重要的要素:IP+PORT ,IP找到计算机,端口找到对应的应用:

设备之间进行数据传输,遵循一定的规则 => 通信协议 + 七层模型

两个设备之间传输数据,每过一层,就做一层封装(如经过应用层,添加一个APP的头),传输到设备2上以后,再逐层拆封。有点像快递发货和收货了。

2、建立连接与释放连接

三次握手,确定双方的收发能力都正常,然后成功建立TCP连接

四次挥手,释放TCP连接

TCP协议是可靠的,相反,UDP协议是不可靠的,UDP在发送数据之前不需要建立连接,也不需要维护连接状态。

UDP的以上几点,形象说:一个班级计划从学校出发,去地点A春游,十点在地点A集合(地点A类比目标机器,学校就是另一台客户端机器)。但去地点A不是统一过去,大家去地点A的方式不同,有的骑车,有的步行。十点以后,到地点A的学生玩去了,其他半路上迟到的或者迷路的不再管了。

3、创建客户端连接

调用Dial函数:(net包下)

示例:

go 复制代码
package main
import(
        "fmt"
        "net" //所需的网络编程全部都在net包下
)
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)
}

4、创建服务端连接

Listen方法进行监听:

示例:

go 复制代码
package main
import(
        "fmt"
        "net" //所需的网络编程全部都在net包下
)
func main(){
        //打印:
        fmt.Println("服务器端启动了。。")
        //进行监听:需要指定服务器端TCP协议,服务器端的IP+PORT
        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())
                }
        }
}

先启动服务端程序:

启动客户端去连接服务端:

再看服务端:

5、发送终端数据

客户端发送收据:在成功建立连接的基础上,用connect对象的Write方法,向服务端发送数据

go 复制代码
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)//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)
        
}

服务端,创建一个协程去处理客户端的请求:

go 复制代码
package main
import(
        "fmt"
        "net" //所需的网络编程全部都在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("服务器端启动了。。")
        //进行监听:需要指定服务器端TCP协议,服务器端的IP+PORT
        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())
                }
                //准备一个协程,协程处理客户端服务请求:
                go process(conn)//不同的客户端的请求,连接conn不一样的
        }
}

运行:

相关推荐
CC__xy23 分钟前
04 类型别名type + 检测数据类型(typeof+instanceof) + 空安全+剩余和展开(运算符 ...)简单类型和复杂类型 + 模块化
开发语言·javascript·harmonyos·鸿蒙
萤丰信息34 分钟前
技术赋能安全:智慧工地构建城市建设新防线
java·大数据·开发语言·人工智能·智慧城市·智慧工地
Pocker_Spades_A1 小时前
飞算JavaAI家庭记账系统:从收支记录到财务分析的全流程管理方案
java·开发语言
前端世界2 小时前
在鸿蒙里优雅地处理网络错误:从 Demo 到实战案例
网络·华为·harmonyos
墨雨听阁2 小时前
8.18网络编程——基于UDP的TFTP文件传输客户端
网络·网络协议·学习·udp
小晶晶京京2 小时前
day35-负载均衡
运维·网络·网络协议·学习·负载均衡
CHEN5_022 小时前
【Java基础常见辨析】重载与重写,深拷贝与浅拷贝,抽象类与普通类
java·开发语言
Despacito0o2 小时前
C语言基础:变量与进制详解
java·c语言·开发语言
nightunderblackcat3 小时前
进阶向:人物关系三元组,解锁人物关系网络的钥匙
开发语言·python·开源·php
网络研究院3 小时前
网络安全和基础设施安全局 (CISA) 表示微分段不再是可选的
网络·安全·web安全·零信任·微分段