海量用户通讯系统-项目小结|学习笔记

简介: 快速学习海量用户通讯系统-项目小结

开发者学堂课程【Go 语言核心编程 - 面向对象、文件、单元测试、反射、TCP 编程:海量用户通讯系统-项目小结】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/626/detail/9824


海量用户通讯系统-项目小结

 

内容介绍

一、代码运行

二、代码实现

三、思考题

 

一、代码运行

把代码编译后,尝试是否能运行。整个系统都要进行编译,因为服务器端、客户端都发生了很大的变化。

经过第一轮编译,服务器端和客户端都顺利完成,没有发生错误,此时把三个端口放在一起

image.png

接下来进行测试工作

先启动服务器

D:、goproject>server.exe

登录第一个

D:\goproject>client.exe

输入id100

输入密码:123456

登录成功,此时无法发送群聊消息

在第二个中登录聊天室

D:\goproject>client.exe

输入id:200

密码:123456

此时在200号中可以看见100号在线,在100号中可以看到200号上线

登录300

D:\goproject>client.exe

输入id:300

密码:123456

输入2可以在群聊发送消息

发送:hello

100号和200号中都可以看到300号在群聊中发送了hello

同理,在200号或100号中发送消息,其余二人都可以收到消息,证明代码是正确的。


二、代码整理

1、思路分析:

image.png

粉色:model/CurUser

struct{

Conn

蓝色:SmsMes{

User

Content…

}

虚线:完成客户端可发送消息的思路

新增一个消息结构体SmsMes

新增一个model CurUser

在smsProcess.go增加相应的方法SendGroupMes发送一个群聊的消息

在服务器端接收到SmsMes消息

在server/process/smsProcess.go文件增加群发消息的方法

在客户端还要增加去处理服务器端转发的群发消息SmsMes

2、代码实现

【1】server/process/smsProcess.go

package process2

import (

“fmt”

“net”

“go_code/chatroom/common/message”

“go_code/chatroom/server/utils”

“encoding/json”

)

type SmsProcess struct {

//..[暂时不需字段]
}

//写方法转发消息

func (this *SmsProcess) SendGroupMes(mes *message.Message){

//遍历服务器端的onlineUsers map[int]*UserProcess,

//将消息转发取出

//取出mes的内容 SmsMes

var smsMes message.SmsMes

err := json.Unmarshasl([]byte(mes.Data),&smsMes)

if err !=nil{

fmt.Println(“json.Unmarshal err=”,err)

return

}

data,err :=

json.Marshal(mes)

if err != nil {

fmt.Println(“json.Marshal err=”, err)

}

for id,up := range userMgr.onlineUsers {

//这里,还需要过滤到自己,即不要再发给自己

If id == smsMes.UserId  {

continue

}

this.SendMesToEachOnlineUser(data ,up.Conn)

}

}

func (this *SmsProcess) SendMesToEachOnlineUser (data[]byte ,conn net.Conn){

//创建一个Transfer 实例,发送data

tf :=&utils.Transfer{

Conn : conn, //

}

err := tf.WritePkg(data)

if err != nil {

fmt.Println(“转发消息失败 err=”, err)

}

}

【2】server/main/processor.go

  //处理注册

up := &process2.UserProcess{

Conn : this.Conn,

}

err up.ServerProcessRegister(mes) // type :data

case message.SmsMesType :

//创建一个SmsProcess实例完成转发群聊消息.

smsProcess := &process2.SmsProcess{}

smsProcess.SendGroupMes(mes)

default :

fmt.Println(“消息类型不存在,无法处理…”)

}

【3】client/process/smsMgr.go

package process

import (

“fmt”

“go_code/chatroom/common/message”

“encoding/json”

)

func outputGroupMes(mes *message.Message){//这个地方mes一定SmsMes

//显示即可

//1、反序列化mes,Data

var smsMes message.SmsMes

err :=json.Unmarshal([]byte(mes.Data),&smsMes)

if err != nil {

fmt.Println(“json.Unmarshal err=”,err.Error())

return

}

//显示信息

info := fmt.Sprintf(“用户id:\t%s 对大家说:\t%s”,

smsMes.UserId,smsMes.Content”)

fmt.Println(info)

fmt.Println()

}

【4】client/process/server.go

case message.SmsMesType ://有人群发消息

outputGroupMes(&mes)

default

fmt.Println(“服务器端反悔了未知的消息类型”)

}

//fmt.Printf(“mes=%v\n,mes)

}


三、思考题

18.5.10聊天的项目的扩展功能要求

1.实现私聊.[点对点聊天]

2.如果一个登录用户离线,就把这个人从在线列表去掉

3.实现离线留言,在群聊时,如果某个用户没有在线,当登录后,可以接受离线的消息

相关文章
|
3天前
|
存储 编解码 数据处理
云端问道第4期实践教学——多媒体数据存储与分发方案部署演示
该文档详细介绍了阿里云一键部署和手动部署多媒体数据存储与分发方案的步骤。一键部署通过资源编排服务(ROS)实现自动化,涵盖注册账号、开通服务、创建OSS Bucket、配置CDN加速及绑定IMM等功能,简化了复杂操作。手动部署则更细致地展示了每个配置环节,包括网络规划、资源创建、域名绑定、CDN配置、证书加密及最终的验证与清理,确保用户对整个流程有清晰理解。两种方式均以OSS为核心,支持数据上传、转码处理和加速分发,保障高效稳定的用户体验。
|
网络协议 前端开发 测试技术
海量用户通讯系统——服务端结构改进1|学习笔记
快速学习海量用户通讯系统——服务端结构改进1
海量用户通讯系统——服务端结构改进1|学习笔记
|
NoSQL 网络协议 关系型数据库
海量用户通讯系统-完成界面|学习笔记
快速学习海量用户通讯系统-完成界面
海量用户通讯系统-完成界面|学习笔记
|
网络协议 测试技术 Go
海量用户通讯系统——客户端结构改进1|学习笔记
快速学习海量用户通讯系统——客户端结构改进1
海量用户通讯系统——客户端结构改进1|学习笔记
|
缓存 JSON 网络协议
海量用户系统-客户端结构改进2|学习笔记
快速学习海量用户系统-客户端结构改进2
海量用户系统-客户端结构改进2|学习笔记
|
网络协议 测试技术 Go
海量用户通讯系统-显示在线用户列表(1)|学习笔记
快速学习海量用户通讯系统-显示在线用户列表(1)
海量用户通讯系统-显示在线用户列表(1)|学习笔记
|
网络协议 测试技术 Go
海量用户通讯系统-收发消息分析|学习笔记
快速学习海量用户通讯系统-收发消息分析
海量用户通讯系统-收发消息分析|学习笔记
|
NoSQL 网络协议 Oracle
海量用户即时通讯系统需求|学习笔记
快速学习海量用户即时通讯系统需求
海量用户即时通讯系统需求|学习笔记
|
JSON 网络协议 测试技术
海量用户通讯系统-登录(指定用户)|学习笔记
快速学习海量用户通讯系统-登录(指定用户)
|
JSON 网络协议 NoSQL
海量用户通讯系统-用户注册(1)|学习笔记
快速学习海量用户通讯系统-用户注册(1)