Commit ae1d9371 by xiongziliang

优化http拆包器代码

parent b3f2bd5b
...@@ -54,10 +54,12 @@ void HttpRequestSplitter::input(const char *data,uint64_t len) { ...@@ -54,10 +54,12 @@ void HttpRequestSplitter::input(const char *data,uint64_t len) {
//数据按照请求头处理 //数据按照请求头处理
const char *index = nullptr; const char *index = nullptr;
while (_content_len == 0 && (index = strstr(ptr,"\r\n\r\n")) != nullptr) { uint64_t remain = len;
while (_content_len == 0 && remain > 0 && (index = onSearchPacketTail(ptr,remain)) != nullptr) {
//_content_len == 0,这是请求头 //_content_len == 0,这是请求头
_content_len = onRecvHeader(ptr, index - ptr + 4); _content_len = onRecvHeader(ptr, index - ptr);
ptr = index + 4; ptr = index;
remain = len - (ptr - data);
} }
/* /*
...@@ -65,7 +67,6 @@ void HttpRequestSplitter::input(const char *data,uint64_t len) { ...@@ -65,7 +67,6 @@ void HttpRequestSplitter::input(const char *data,uint64_t len) {
*/ */
tail_ref = tail_tmp; tail_ref = tail_tmp;
uint64_t remain = len - (ptr - data);
if(remain <= 0){ if(remain <= 0){
//没有剩余数据,清空缓存 //没有剩余数据,清空缓存
_remain_data.clear(); _remain_data.clear();
...@@ -124,6 +125,14 @@ void HttpRequestSplitter::reset() { ...@@ -124,6 +125,14 @@ void HttpRequestSplitter::reset() {
_remain_data.clear(); _remain_data.clear();
} }
const char *HttpRequestSplitter::onSearchPacketTail(const char *data,int len) {
auto pos = strstr(data,"\r\n\r\n");
if(pos == nullptr){
return nullptr;
}
return pos + 4;
}
} /* namespace mediakit */ } /* namespace mediakit */
...@@ -42,7 +42,7 @@ public: ...@@ -42,7 +42,7 @@ public:
* @param data 需要添加的数据 * @param data 需要添加的数据
* @param len 数据长度 * @param len 数据长度
*/ */
void input(const char *data,uint64_t len); virtual void input(const char *data,uint64_t len);
protected: protected:
/** /**
* 收到请求头 * 收到请求头
...@@ -65,6 +65,14 @@ protected: ...@@ -65,6 +65,14 @@ protected:
virtual void onRecvContent(const char *data,uint64_t len) {}; virtual void onRecvContent(const char *data,uint64_t len) {};
/** /**
* 判断数据中是否有包尾
* @param data 数据指针
* @param len 数据长度
* @return nullptr代表未找到包位,否则返回包尾指针
*/
virtual const char *onSearchPacketTail(const char *data,int len);
/**
* 设置content len * 设置content len
*/ */
void setContentLen(int64_t content_len); void setContentLen(int64_t content_len);
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论