⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 testdigestauthentication.cxx

📁 这是国外的resip协议栈
💻 CXX
📖 第 1 页 / 共 2 页
字号:
#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;intmain(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.0To: sip:100@kelowna.gloo.netFrom: <sip:100@kelowna.gloo.net>Call-ID: 000532ff-828108c2-79016ad7-69ac4815@192.168.2.233CSeq: 102 REGISTERContact: sip:100@192.168.2.233:5060Via: SIP/2.0/UDP 192.168.2.233:5060;received=192.168.2.233;rport=5060Expires: 3600Date: Sat, 07 Dec 2002 02:21:59 GMTProxy-Authorization: Digest username="sip:100@kelowna.gloo.net:5060",realm="kelowna.gloo.net",uri="sip:kelowna.gloo.net",response="8485db84088e6be6c55717d2eb891eca",nonce="1039227719:9e17fc5e10c30f162e7a21c9f6a4d2a7",algorithm=MD5User-Agent: CSCO/4Content-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 + -