博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
WebKit之WebSocket的初步源码分析2
阅读量:4025 次
发布时间:2019-05-24

本文共 2175 字,大约阅读时间需要 7 分钟。

static PassRefPtr<ThreadableWebSocketChannel> 

ThreadableWebSocketChannel::create(ScriptExecutionContext*, WebSocketChannelClient*);
>>其中WebSocketChannelClient是指WebSocket对象
>>该类是一个抽象类(virtual void connect(const KURL&, const String& protocol) = 0;)
>>实现调度 return WebSocketChannel::create(toDocument(context), client); 子类
>>
class WebSocketChannel : public RefCounted<WebSocketChannel>, 
public SocketStreamHandleClient, 
                         public ThreadableWebSocketChannel
{
}
引用通用的枚举类型
virtual ThreadableWebSocketChannel::SendResult send(const Blob&) OVERRIDE;
class ThreadableWebSocketChannel
{
public:
enum SendResult{
EABC,
EABB
};
}
WebSocket::connect()
ThreadableWebSocketChannel::connect()
WebSocketChannel::connect()
{
m_handshake = adoptPtr(new WebSocketHandshake(url, protocol, m_document));
InspectorInstrumentation::didCreateWebSocket(m_document, m_identifier, url, m_document->url(), protocol);//事件通知
m_handle = SocketStreamHandle::create(m_handshake->url(), this);//创建Socket数据流句柄
}
WebSocket协议中握手是一个网络通信的一个环节,此情况确实化作一个对象来专职负责握手的流程。
#讲一个复杂的协议被分解为具体的Object进行表示
{
m_secWebSocketKey = generateSecWebSocketKey();
m_expectedAccept = getExpectedWebSocketAccept(m_secWebSocketKey);//固定字符串 - 计算SHA1值 -> Base64编码
}
所谓的握手不再是简单的socket接受,然后读取,然后判断,而是直接创建一个对应的对象。
所谓的连接不再是简单的校验,而是直接创建一个SocketStreamHandler处理
 class SocketStreamHandle : public RefCounted<SocketStreamHandle>, public SocketStreamHandleBase
{
}//定义的标准的接口类,交由具体的平台加以实现
SocketStreamHandleCurl.cpp platform/network/curl
SocketStreamHandleWin.cpp platform/network/win
SocketStreamHandleQt.cpp platform/network/cqt
SocketStreamHandleBlackBerry.cpp platform/network/blackberry
SocketStreamHandleSoup.cpp platform/network/soup
SocketStreamHandleCFNet.cpp platform/network/cf
m_handle = SocketStreamHandle::create(m_handshake->url(), this);
>>其中this为WebSocketChannel
>>参数2为(SocketStreamHandleClient* client)
int SocketStreamHandle::platformSend(const char* data, int len)
{
return m_p->send(data, len);
}
# SocketStreamHandlePrivate* m_p;
>> 本质是进一步委托QTcpSocket* m_socket;来实现send等动作
bool isSecure = url.protocolIs("wss");
if (isSecure)
m_socket = new QSslSocket(this);
else
m_socket = new QTcpSocket(this);
m_socket->connectToHost(host, port);

你可能感兴趣的文章
S3C6410启动模式介绍
查看>>
Jlink + ADS调试 S3C2440
查看>>
2440初始化存储器原理(接上一篇)
查看>>
S3C2440 USB 设备控制器(转)
查看>>
Linux usb 设备驱动 (1)
查看>>
解决跨网场景下,CAS重定向无法登录的问题(无需修改现有代码)
查看>>
java反编译命令
查看>>
activemq依赖包获取
查看>>
概念区别
查看>>
关于静态块、静态属性、构造块、构造方法的执行顺序
查看>>
final 的作用
查看>>
在Idea中使用Eclipse编译器
查看>>
idea讲web项目部署到tomcat,热部署
查看>>
优化IDEA启动速度,快了好多。后面有什么优化点,会继续往里面添加
查看>>
JMeter 保持sessionId
查看>>
IDEA Properties中文unicode转码问题
查看>>
Idea下安装Lombok插件
查看>>
zookeeper
查看>>
Idea导入的工程看不到src等代码
查看>>
技术栈
查看>>