-
Notifications
You must be signed in to change notification settings - Fork 26
Expand file tree
/
Copy pathHttpHeader.cpp
More file actions
161 lines (144 loc) · 3.76 KB
/
HttpHeader.cpp
File metadata and controls
161 lines (144 loc) · 3.76 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
/*
* Copyright (C) 2012 Yee Young Han <websearch@naver.com> (http://blog.naver.com/websearch)
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#include "SipPlatformDefine.h"
#include "HttpHeader.h"
#include "MemoryDebug.h"
CHttpHeader::CHttpHeader()
{
}
CHttpHeader::CHttpHeader( const char * pszName, const char * pszValue )
{
Set( pszName, pszValue );
}
CHttpHeader::~CHttpHeader()
{
}
/**
* @ingroup HttpParser
* @brief HTTP 헤더 문자열을 파싱하여 CHttpHeader 클래스의 멤버 변수에 저장한다.
* @param pszText HTTP 헤더의 값을 저장한 문자열
* @param iTextLen pszText 문자열의 길이
* @returns 성공하면 파싱한 길이를 리턴하고 그렇지 않으면 -1 를 리턴한다.
*/
int CHttpHeader::Parse( const char * pszText, int iTextLen )
{
Clear();
if( pszText == NULL || iTextLen <= 0 ) return -1;
int iPos, iValuePos;
char cType = 0;
// parse header name & skip prefix space of header value
for( iPos = 0; iPos < iTextLen; ++iPos )
{
if( cType == 0 )
{
if( pszText[iPos] == ':' || pszText[iPos] == ' ' || pszText[iPos] == '\t' )
{
m_strName.append( pszText, iPos );
++cType;
}
else if( pszText[iPos] == '\r' )
{
if( iPos + 1 >= iTextLen || pszText[iPos+1] != '\n' ) return -1;
return iPos + 2;
}
}
else if( pszText[iPos] == ':' || pszText[iPos] == ' ' || pszText[iPos] == '\t' )
{
continue;
}
else
{
break;
}
}
iValuePos = iPos;
// parse header value
for( ; iPos < iTextLen; ++iPos )
{
if( cType == 10 )
{
if( pszText[iPos] != ' ' && pszText[iPos] != '\t' )
{
cType = 11;
--iPos;
iValuePos = iPos;
}
}
else if( pszText[iPos] == '\r' )
{
if( iValuePos != -1 )
{
m_strValue.append( pszText + iValuePos, iPos - iValuePos );
iValuePos = -1;
}
++iPos;
if( iPos == iTextLen || pszText[iPos] != '\n' ) return -1;
++iPos;
if( iPos == iTextLen ) break;
if( pszText[iPos] == ' ' || pszText[iPos] == '\t' )
{
cType = 10;
m_strValue.append( " " );
}
else
{
break;
}
}
}
return iPos;
}
/**
* @ingroup HttpParser
* @brief HTTP 메시지에 포함된 문자열을 작성한다.
* @param pszText HTTP 헤더의 값을 저장할 문자열 변수
* @param iTextSize pszText 변수의 크기
* @returns 성공하면 작성한 문자열 길이를 리턴하고 그렇지 않으면 -1 를 리턴한다.
*/
int CHttpHeader::ToString( char * pszText, int iTextSize )
{
if( pszText == NULL || iTextSize <= 0 ) return -1;
if( m_strValue.empty() )
{
return snprintf( pszText, iTextSize, "%s: \r\n", m_strName.c_str() );
}
else
{
return snprintf( pszText, iTextSize, "%s: %s\r\n", m_strName.c_str(), m_strValue.c_str() );
}
}
/**
* @ingroup HttpParser
* @brief 헤더의 이름과 값을 설정한다.
* @param pszName 헤더 이름
* @param pszValue 헤더 값
*/
void CHttpHeader::Set( const char * pszName, const char * pszValue )
{
m_strName = pszName;
m_strValue = pszValue;
}
/**
* @ingroup HttpParser
* @brief 멤버 변수를 초기화시킨다.
*/
void CHttpHeader::Clear()
{
m_strName.clear();
m_strValue.clear();
}