📄 testdigestauthentication.cxx
字号:
#include <assert.h>
#include <iostream>
#include <string.h>
#ifdef WIN32
#include <io.h>
#else
#include <unistd.h>
#endif
#include <memory>
#ifdef WIN32
#define usleep(x) Sleep(x/1000)
#define sleep(x) Sleep(x*1000)
#endif
#include "resip/stack/HeaderFieldValue.hxx"
#include "resip/stack/HeaderTypes.hxx"
#include "resip/stack/ParserCategories.hxx"
#include "resip/stack/Uri.hxx"
#include "resip/stack/Helper.hxx"
#include "resip/stack/test/TestSupport.hxx"
#include "rutil/Timer.hxx"
#include "rutil/DataStream.hxx"
#include "rutil/MD5Stream.hxx"
#include "digcalc.hxx"
using namespace std;
using namespace resip;
int
main(int arc, char** argv)
{
{
Auth auth;
auth.scheme() = "Digest";
Data timestamp((unsigned int)(Timer::getTimeMs()/1000));
auth.param(p_nonce) = "askdfjhaslkjhf498hw98hw98hfsf";
auth.param(p_algorithm) = "MD5";
auth.param(p_realm) = "example.com";
assert(Helper::algorithmAndQopSupported(auth));
auth.param(p_algorithm) = "MD5-sess";
assert(!Helper::algorithmAndQopSupported(auth));
auth.param(p_algorithm) = "monkey";
assert(!Helper::algorithmAndQopSupported(auth));
auth.param(p_algorithm) = "MD5";
auth.param(p_qop) = Symbols::auth;
assert(Helper::algorithmAndQopSupported(auth));
auth.param(p_qop) = Symbols::authInt;
assert(Helper::algorithmAndQopSupported(auth));
auth.param(p_qop) = "monkey";
assert(!Helper::algorithmAndQopSupported(auth));
cerr << "algorithmAndQopSupported passed" << endl;
}
{
assert(Data("").md5() == "d41d8cd98f00b204e9800998ecf8427e");
assert(Data("a").md5() == "0cc175b9c0f1b6a831c399e269772661");
assert(Data("abc").md5() == "900150983cd24fb0d6963f7d28e17f72");
assert(Data("message digest").md5() == "f96b697d7cb7938d525a2f31aaf161d0");
assert(Data("abcdefghijklmnopqrstuvwxyz").md5() == "c3fcd3d76192e4007dfb496cca67e13b");
assert(Data("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789").md5() == "d174ab98d277d9f5a5611c2c9f419d9f");
assert(Data("12345678901234567890123456789012345678901234567890123456789012345678901234567890").md5() == "57edf4a22be3c955ac49da2e2107b67a");
}
{
{
MD5Stream s;
assert(s.getHex() == Data("").md5());
}
{
MD5Stream s;
s << "a";
assert(s.getHex() == Data("a").md5());
}
{
MD5Stream s;
s << "abc";
assert(s.getHex() == Data("abc").md5());
}
{
MD5Stream s;
s << "message digest";
assert(s.getHex() == Data("message digest").md5());
}
{
MD5Stream s;
s << "12345678901234567890123456789012345678901234567890123456789012345678901234567890";
assert(s.getHex() == Data("12345678901234567890123456789012345678901234567890123456789012345678901234567890").md5());
}
{
Data d;
DataStream ds(d);
MD5Stream s;
s << "this involves" << 7.8 << "foo" << 34653453 << -6 << "hike";
ds << "this involves" << 7.8 << "foo" << 34653453 << -6 << "hike";
ds.flush();
assert(d.md5() == s.getHex());
}
}
{
char* alg = "MD5";
char* username = "user";
char* password = "secret";
char* realm = "localhost";
char* method = "REGISTER";
char* uri = "user@host.com";
char* nonce = "92347fea23";
Data responseMD5 = Helper::makeResponseMD5(username,
password,
realm,
method,
uri,
nonce);
HASHHEX a1Hash;
HASHHEX response;
DigestCalcHA1(alg,
username,
realm,
password,
nonce,
(char*)"",
a1Hash);
DigestCalcResponse(a1Hash,
nonce,
(char*)"",
(char*)"",
(char*)"",
method,
uri,
(char*)"",
response);
assert(responseMD5 == response);
}
{
char* alg = "MD5";
char* username = "user";
char* password = "secret";
char* realm = "localhost";
char* method = "REGISTER";
char* uri = "user@host.com";
char* nonce = "92347fea23";
char* cnonce = "72345hef";
char* cnonceCount = "00000001";
char* qop = "auth";
Data responseMD5 = Helper::makeResponseMD5(username,
password,
realm,
method,
uri,
nonce,
qop,
cnonce,
cnonceCount);
HASHHEX a1Hash;
HASHHEX response;
DigestCalcHA1(alg,
username,
realm,
password,
nonce,
cnonce,
a1Hash);
DigestCalcResponse(a1Hash,
nonce,
cnonceCount,
cnonce,
qop,
method,
uri,
(char*)"",
response);
assert(responseMD5 == response);
}
{
char* alg = "MD5";
char* username = "user";
char* password = "secret";
char* realm = "localhost";
char* method = "REGISTER";
char* uri = "user@host.com";
char* nonce = "92347fea23";
Data responseMD5 = Helper::makeResponseMD5(username,
password,
realm,
method,
uri,
nonce);
HASHHEX a1Hash;
HASHHEX response;
DigestCalcHA1(alg,
username,
realm,
password,
nonce,
(char*)"",
a1Hash);
DigestCalcResponse(a1Hash,
nonce,
(char*)"",
(char*)"",
(char*)"",
method,
uri,
(char*)"",
response);
assert(responseMD5 == response);
}
/*
REGISTER sip:kelowna.gloo.net SIP/2.0
To: sip:100@kelowna.gloo.net
From: <sip:100@kelowna.gloo.net>
Call-ID: 000532ff-828108c2-79016ad7-69ac4815@192.168.2.233
CSeq: 102 REGISTER
Contact: sip:100@192.168.2.233:5060
Via: SIP/2.0/UDP 192.168.2.233:5060;received=192.168.2.233;rport=5060
Expires: 3600
Date: Sat, 07 Dec 2002 02:21:59 GMT
Proxy-Authorization: Digest username="sip:100@kelowna.gloo.net:5060",realm="kelowna.gloo.net",uri="sip:kelowna.gloo.net",response="8485db84088e6be6c55717d2eb891eca",nonce="1039227719:9e17fc5e10c30f162e7a21c9f6a4d2a7",algorithm=MD5
User-Agent: CSCO/4
Content-Length: 0
*/
/*
Proxy-Authorization: Digest username="sip:100@kelowna.gloo.net:5060",realm="kelowna.gloo.net",uri="sip:kelowna.gloo.net",response="8485db84088e6be6c55717d2eb891eca",nonce="1039227719:9e17fc5e10c30f162e7a21c9f6a4d2a7",algorithm=MD5
*/
{
char* alg = "MD5";
char* username = "sip:100@kelowna.gloo.net:5060";
char* password = "secret";
char* realm = "kelowna.gloo.net";
char* method = "REGISTER";
char* uri = "sip:kelowna.gloo.net";
char* nonce = "1039227719:9e17fc5e10c30f162e7a21c9f6a4d2a7";
char* cnonce = "";
char* cnonceCount = "";
char* qop = "";
Data responseMD5 = Helper::makeResponseMD5(username,
password,
realm,
method,
uri,
nonce,
qop,
cnonce,
cnonceCount);
HASHHEX a1Hash;
HASHHEX response;
DigestCalcHA1(alg,
username,
realm,
password,
nonce,
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -