前言
运用go里面的net包中的相关方法来实现一个基于tcp的简单多人聊天室,用一个服务器来管理,主要反馈客户端是否连接成功并显示客户端输入的内容,并且发送给每一个在服务器上连接的客服端,下面话不多说了,来一起看看详细的介绍吧。
示例代码
服务器代码
// server package main import ( "fmt" "net" ) var ConnMap map[string]*net.TCPConn func checkErr(err error) int { if err != nil { if err.Error() == "EOF" { fmt.Println("用户退出") return 0 } fmt.Println("发生错误") return -1 } return 1 } func say(tcpConn *net.TCPConn) { for { data := make([]byte, 256) total, err := tcpConn.Read(data) if err != nil { fmt.Println(string(data[:total]), err) } else { fmt.Println(string(data[:total])) } flag := checkErr(err) if flag == 0 { break } for _, conn := range ConnMap { if conn.RemoteAddr().String() == tcpConn.RemoteAddr().String() { continue } conn.Write(data[:total]) } } } func main() { //var conn net.TCPConn //localAddr :=conn.LocalAddr().String() //fmt.Println(localAddr) //tcpAddr, _ := net.ResolveTCPAddr("tcp",localAddr) tcpAddr, _ := net.ResolveTCPAddr("tcp", "192.168.128.216:8080") tcpListen, _ := net.ListenTCP("tcp", tcpAddr) ConnMap = make(map[string]*net.TCPConn) for { tcpConn, _ := tcpListen.AcceptTCP() defer tcpConn.Close() ConnMap[tcpConn.RemoteAddr().String()] = tcpConn fmt.Println("连接客户端信息:", tcpConn.RemoteAddr().String()) go say(tcpConn) } }
本来打算用系统的LocalAddr()函数来直接调用本地网络地址,但是这里调用一直报格式的错误,所以这里用本地地址直接输在里面,端口是8080//192.168.247.128:8080,也可以改成和客户端相似的代码来进行调用,但鉴于服务器唯一,所以就不做更改了
客户端代码
// client package main import ( "fmt" "net" "os" ) var ch chan int = make(chan int) var nickname string func reader(conn *net.TCPConn) { buff := make([]byte, 256) for { j, err := conn.Read(buff) if err != nil { ch <- 1 break } fmt.Printf("%s\n", buff[0:j]) } } func main() { if len(os.Args) != 2 { fmt.Fprintf(os.Stderr, "Usage:%s host:port", os.Args[0]) os.Exit(1) } service := os.Args[1] TcpAdd, _ := net.ResolveTCPAddr("tcp", service) //TcpAdd, _ := net.ResolveTCPAddr("tcp", "localhost:8080") conn, err := net.DialTCP("tcp", nil, TcpAdd) if err != nil { fmt.Println("服务没打开") os.Exit(1) } defer conn.Close() go reader(conn) fmt.Println("请输入昵称") fmt.Scanln(&nickname) fmt.Println("你的昵称是:", nickname) //var str string for { var msg string fmt.Scan(&msg) fmt.Print("<" + nickname + ">" + "说:") //for i, _ := range msg { // fmt.Printf("%c", msg[i]) //} fmt.Println(msg) b := []byte("<" + nickname + ">" + "说:" + msg) conn.Write(b) select { case <-ch: fmt.Println("server发生错误,请重新连接") os.Exit(2) default: } } }
客户端主要就是向服务器发起连接,然后发送和接收数据,原计划定义一个字符切片来存储读来的数据,但是出现了调用fmt.Println()来输出是时候显示ASCII码的错误,所以改成直接往一个空字符串里面读写,然后再来调用fmt.Println() ,显示出正确的字符串
运行服务器
go build server.go
./server
或 go run server.go
运行客户端
go build client.go
./client 服务器地址:端口(上面例子是192.168.247.128:8080)
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对小牛知识库的支持。
本文向大家介绍Go语言多人聊天室项目实战,包括了Go语言多人聊天室项目实战的使用技巧和注意事项,需要的朋友参考一下 本文为大家分享了Go语言多人聊天室项目实战,供大家参考,具体内容如下 功能需求 实现单撩 实现群撩 实现用户上线的全网通知 实现用户昵称 实现聊天日志的存储和查看 服务端实现 客户端实现 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍基于Nodejs利用socket.io实现多人聊天室,包括了基于Nodejs利用socket.io实现多人聊天室的使用技巧和注意事项,需要的朋友参考一下 socket.io简介 在Html5中存在着这样的一个新特性,引入了websocket,关于websocket的内部实现原理可以看这篇文章,这篇文章讲述了websocket无到有,根据协议,分析数据帧的头,进行构建websocket
简介 Github 地址 本文使用 go 实现了一个多人聊天室,参考文章为 Writing a Chat Server in Go,点击查看中文翻译版。 本文的特点在于:将原始项目分为自底向上的若干个阶段,新手可以一步步地实现系统的不同模块,逐渐掌握相应知识点。源码里有详细的注释,引导你在不看源代码的情况下自己实现相应代码。 本文假设你: 了解 go 语言的基本语法 了解 git 的使用 完成本项
本文向大家介绍python实现简单多人聊天室,包括了python实现简单多人聊天室的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了python实现多人聊天室的具体代码,供大家参考,具体内容如下 刚开始学习python,写了一个聊天室练练手。 Server.py client.py 运行时先启动服务端。进入聊天室先起一个昵称。服务端会向客户端发送当前聊天室内聊天人的列表。一个客户端发出
本文向大家介绍基于swoole实现多人聊天室,包括了基于swoole实现多人聊天室的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了swoole创建多人多房间聊天室的具体代码,供大家参考,具体内容如下 核心的swoole代码 基本的cs(client-sercer)结构不变,这里利用的是redis的哈希和set来储存和分组;从而达到了分组,统计,定时推送等功能;最后利用onclose事
本文向大家介绍Node.js利用Net模块实现多人命令行聊天室的方法,包括了Node.js利用Net模块实现多人命令行聊天室的方法的使用技巧和注意事项,需要的朋友参考一下 这篇文章介绍的是Node.js利用Net模块实现命令行式的多人聊天室,下面话不多说,来看看详细的介绍吧。 1、net模块基本API 要使用Node.js的net模块实现一个命令行聊天室,就必须先了解NET模块的API使用。NET