---
#1.web客户端代码分析
web客户端传4个值,userID,passWord,IPAddr,IPPort,最后2个是连接服务器用的,userID和passWord是验证用户信息用的。
以下是客户端代码:
    var userID = $('#userID').val();
var passWord = $('#passWord').val();
var IpAddr = $('#IpAddr').val();
var IpPort = $('#IpPort').val();
var host = "ws://"+IpAddr+":"+IpPort+"/ws"; //host地址,用来连接服务器

var jsonData = {};
jsonData.MainCmdID = 1;
jsonData.SubCmdID = 2;
jsonData.userID = 1;
jsonData.passWord = hex_md5(passWord);      //对密码进行md5加密处理
toStr = JSON.stringify(jsonData);       //把数据转换为json格式
OutputLog(toStr);

try{
socket = new WebSocket(host);   //连服务器
OutputLog('Socket Status: '+socket.readyState);
socket.onopen = function(){
var myData = new Date();    //获取当前时间信息
OutputLog(myData.toLocaleString()+'Socket Status: '+socket.readyState+'(open)');
socket.send(toStr); //向服务器发送消息
}
socket.onmessage = function(msg){   //收到服务器消息
var myData = new Date();
var jsonData = JSON.stringify(msg.data);
var jsonObj = window.JSON.parse(jsonData);
OutputLog(myData.toLocaleString()+":"+jsonObj);//输出服务器消息
}
socket.onclose = function(){//接收服务器关闭消息
var myData = new Date();
OutputLog(myData.toLocaleString()+'Socket Status: '+socket.readyState+' (Close)');
}
}catch(exception){//异常处理
OutputLog('Error' + exception);
}

---
#2.服务器处理web客户端请求
线程CServerSocketRSThread::OnEventThreadRun() 不停循环执行,
 CServerSocketItem::OnRecvCompleted()函数中的recv捕获客户端信息事件。
 根据:
 //接收数据
int iRetCode = recv(m_hSocket, (char *)m_cbRecvBuf + m_wRecvSize, sizeof(m_cbRecvBuf)-m_wRecvSize, 0);
if (iRetCode <= 0)
{
CloseSocket(m_wRountID);
return true;
}

//TODO 根据连接类型来做接受数据后的处理
//连接类型检测
if (this->m_connectType == ConnectType_unknow){
string s((char *)m_cbRecvBuf);
if (s.find("HTTP") != string::npos){
this->m_connectType = ConnectType_websocket;
}
else{
this->m_connectType = ConnectType_socket;
}
}
判断是否是web信息,然后发送给子项去处理具体消息。

然后在CAttemperEngineSink::OnEventTCPNetworkRead()函数中捕获网络事件,
增加函数:
    ///< qsz 解析网络登录包
if (Command.wMainCmdID == MDM_WEB_MSG)
{
OutputDebugString((char *)pData);
char* resulData = new char[wDataSize + 1];
memcpy(resulData, pData, wDataSize);
resulData[wDataSize] = '\0';

std::string stResult = resulData;
Json::Reader readerJson;
Json::Value  valueJson;

if (readerJson.parse(stResult, valueJson))
{
Command.wMainCmdID = valueJson["MainCmdID"].asInt();
Command.wSubCmdID = valueJson["SubCmdID"].asInt();
//MainCmdID = 11, SubCmdID = 222,   field1=11,field2=222
}
else
return false;

if (Command.wMainCmdID == MDM_GR_LOGON)
{
int userID = valueJson["userID"].asInt();
std::string passWord = valueJson["passWord"].asString();///< 客户端上传时已转成md5
CMD_GR_LogonByUserID * pLogonByUserID = new CMD_GR_LogonByUserID;
pLogonByUserID->dwPlazaVersion = VER_PLAZA_FRAME;
pLogonByUserID->dwUserID = userID;
lstrcpyn(pLogonByUserID->szPassWord, passWord.c_str(), passWord.length() + 1);
pData = pLogonByUserID;
}
解析处理函数消息。

最后增加自己的函数处理返回消息,并发送给客户端。
void CAttemperEngineSink::SendDataEx(DWORD dwSocketID, WORD wMainCmdID, WORD wSubCmdID, void * pData, WORD wDataSize){
int connectType = m_pITCPNetworkEngine->getConnectType(dwSocketID);
if (connectType == 2){//ConnectType_websocket
//TODO tmx Data2WebData处理
Json::Value root;
Json::Value arrayObj;
Json::Value item;

item["MainCmdID"] = 1;
item["SubCmdID"] = 1;

arrayObj.append(item);
root["array"] = arrayObj;
root.toStyledString();
std::string out = root.toStyledString();

OutputDebugString("======CAttemperEngineSink::SendDataEx======\n");
OutputDebugString(out.c_str());
m_pITCPNetworkEngine->SendData(dwSocketID, wMainCmdID, wSubCmdID, (void*)out.c_str(), out.length() );

item.clear();
arrayObj.clear();
root.clear();
}
else{
if (wDataSize == 0)
{
m_pITCPNetworkEngine->SendData(dwSocketID, wMainCmdID, wSubCmdID);
}
else{
m_pITCPNetworkEngine->SendData(dwSocketID, wMainCmdID, wSubCmdID, pData, wDataSize);
}
}
}

至此,web客户端便能登录游戏大厅,并在其它客户端上显示到此玩家信息了!

网狐框架分析八--web登录游戏大厅流程相关推荐

  1. 网狐框架分析六--整体框架 20150623

    --- # 1.首先得分析网狐整套流程(原版)     客户端和服务器的交互:         客户端登录过程(socket连接,服务器接收,数据库判断,返回验证消息,建立连接)         客户 ...

  2. 网狐框架分析一 -- 150616

    --- #1. 基本流程     客户端同服务器建立通信连接     服务器判断游戏是否开始(客户端等待其它玩家入位再游戏或者直接和服务器进行游戏)     客户端同服务器进行交互及客户端界面展示   ...

  3. 网狐棋牌(八) 异步引擎 和 网狐棋牌(九) 服务引擎概览

    相关UML: 核心技术在于:在指定的线程中创建窗口,然后向窗口发送消息,在窗口消息处理中调用外部回调. ------------------------------------------------ ...

  4. 网狐框架移植到linux,Red Hat反驳Linux漏洞报告 应关注危急缺陷!

    在有关Linux/Unix中的缺陷数量多于Windows 的报告出台后,开放源代码社区进行了有力的反击. 开放源代码专家已经对美国CERT发布的这一报告进行了谴责,他们称这一报告是误导性的. CERT ...

  5. 电脑qq游戏程序更改计算机,我的电腦登录游戏大厅时电脑提示程序初始化失败...

    您可以参照下列提示操作下,希望我的回答对您有所帮助! ~ [原因分析]: 1. 虚拟内存不足 2. 游戏启动提示缺少某些D3D文件的报错 3. QQ安装后无法启动及部分游戏启动报错 4. 游戏程序本身 ...

  6. 请登录游戏大厅进行签到

    因为没有登录或者签到网页没有登录.请在大厅里签到.

  7. 网狐棋牌框架内核通信设计原理剖析

            关于网狐框架我使用和了解大致有5年多了,也深知里面的一些坑坑洼洼,其他人写的一些关于网狐框架分析的文章,大多都是贴上大量的代码,模块流程大致的解说,都是一些皮毛解说,并没有点出为什么这 ...

  8. 网狐棋牌游戏平台服务器架构设计分析

    调用模型 模仿COM组件接口模式,利用面向对象思想多态性polymorphism,调用方保存着被调用方的基础接口指针(interface or sink钩子)(Pure Virtual Functio ...

  9. 网狐棋牌游戏平台服务器架构设计分析[转]

    网狐棋牌游戏平台服务器架构设计分析[转] http://blog.csdn.net/weiwangchao_/article/details/7047044 基本设计概念和处理流程 调用模型 模仿CO ...

最新文章

  1. Microsoft.Jet.OLEDB.4.0”提供程序不支持 ITransactionLocal 接口。本地事务不可用于当前提供程序...
  2. 工作随笔——Intellij_idea-14官方快捷键中文版
  3. hadoop3 禁用ec_Hadoop + Amazon EC2 –更新的教程
  4. 前端学习(3219):对props进行限制
  5. java 分析excel模板_java如何读取Excel简单模板
  6. PHP文件操作的经典案例
  7. 转 STL hash_map map
  8. 实践分享丨物联网操作系统中的任务管理
  9. 内存管理--分发您的程序存储器
  10. 动态规划题目-------蓝桥杯真题-------蓝桥杯备战
  11. 使用Git和远程代码库
  12. 常见端口的作用、漏洞和操作建议(转)
  13. Chrome浏览器启动命令行参数大全
  14. 第8章 HDFS HA高可用
  15. 《炬丰科技-半导体工艺》Micro-LED 显示器量化生产关键技术
  16. 如何快速删除 Word 文档中的分节符
  17. 使用Tab键控制切换网页光标位置
  18. Linux开机启动过程-centos7
  19. 3个APP海外推广方式,不走寻常路
  20. mysql查询余额变化,SQL查询解决方案-逐日余额

热门文章

  1. [CareerCup] 18.9 Find and Maintain the Median Value 寻找和维护中位数
  2. 敏捷个人第六次练习讨论:个人价值观练习
  3. vlc学习计划(5)--VLC程序宏及线程分析
  4. 职场健康:缓解脖子酸
  5. Nacos源码服务发现
  6. 分布式ID-百度(uid-generator)
  7. Atomic Integer 原理分析-getAndAddInt
  8. Properties作为Map集合的使用
  9. springboot集成rocketmq生产者
  10. Spring源码分析前篇