青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評論 :: 0 Trackbacks
公告
我的隨筆
我的評論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
(502)
1. C/C++(166)
(rss)
2. 網游開發(108)
(rss)
3. Golang(20)
(rss)
4. Linux/Unix(30)
(rss)
5. 軟工與管理(44)
(rss)
6. Python(23)
(rss)
7. Erlang(18)
(rss)
8. Rust(16)
(rss)
9. 其它(77)
(rss)
隨筆檔案
(423)
2023年1月 (1)
2022年11月 (1)
2022年10月 (2)
2022年9月 (1)
2022年4月 (6)
2022年1月 (2)
2021年12月 (4)
2021年11月 (6)
2021年10月 (2)
2021年9月 (2)
2021年8月 (7)
2021年7月 (2)
2021年5月 (2)
2021年3月 (1)
2021年2月 (2)
2021年1月 (1)
2020年12月 (1)
2020年10月 (1)
2020年9月 (5)
2020年8月 (1)
2020年7月 (1)
2020年6月 (1)
2020年4月 (2)
2020年3月 (3)
2020年2月 (3)
2020年1月 (1)
2019年12月 (1)
2019年9月 (2)
2019年4月 (2)
2019年1月 (1)
2018年12月 (1)
2018年11月 (3)
2018年10月 (1)
2018年9月 (3)
2018年8月 (3)
2018年7月 (2)
2018年6月 (4)
2018年5月 (4)
2018年4月 (4)
2018年3月 (1)
2018年1月 (2)
2017年12月 (2)
2017年11月 (3)
2017年10月 (3)
2017年8月 (7)
2017年7月 (1)
2017年6月 (1)
2017年5月 (3)
2017年4月 (3)
2017年3月 (3)
2017年2月 (2)
2017年1月 (2)
2016年12月 (5)
2016年11月 (2)
2016年10月 (2)
2016年9月 (1)
2016年8月 (6)
2016年7月 (3)
2016年6月 (2)
2016年5月 (4)
2016年4月 (2)
2016年3月 (2)
2016年1月 (3)
2015年12月 (2)
2015年11月 (2)
2015年10月 (1)
2015年8月 (2)
2015年7月 (1)
2015年6月 (1)
2015年5月 (4)
2015年4月 (3)
2015年3月 (4)
2015年2月 (5)
2015年1月 (4)
2014年12月 (3)
2014年11月 (3)
2014年10月 (2)
2014年9月 (3)
2014年8月 (1)
2014年4月 (4)
2014年3月 (1)
2014年2月 (4)
2014年1月 (5)
2013年12月 (5)
2013年11月 (5)
2013年9月 (2)
2013年8月 (2)
2013年7月 (2)
2013年6月 (2)
2013年5月 (1)
2013年1月 (2)
2012年12月 (1)
2012年11月 (1)
2012年9月 (1)
2012年8月 (3)
2012年7月 (2)
2012年6月 (1)
2012年4月 (3)
2012年3月 (2)
2012年2月 (3)
2012年1月 (2)
2011年11月 (2)
2011年10月 (3)
2011年9月 (2)
2011年8月 (2)
2011年7月 (3)
2011年6月 (2)
2011年5月 (3)
2011年1月 (2)
2010年12月 (1)
2010年11月 (2)
2010年10月 (2)
2010年9月 (3)
2010年8月 (2)
2010年7月 (3)
2010年6月 (1)
2010年5月 (3)
2010年4月 (3)
2010年3月 (5)
2010年2月 (4)
2010年1月 (4)
2009年12月 (2)
2009年11月 (3)
2009年10月 (4)
2009年9月 (3)
2009年8月 (2)
2009年7月 (4)
2009年6月 (1)
2009年5月 (3)
2009年4月 (4)
2009年3月 (2)
2009年2月 (5)
2009年1月 (1)
2008年12月 (7)
2008年11月 (4)
2008年10月 (1)
2008年9月 (3)
2008年8月 (4)
2008年7月 (3)
2008年6月 (4)
2008年5月 (6)
2008年4月 (7)
2008年3月 (6)
2008年1月 (5)
2007年12月 (7)
2007年11月 (4)
2007年10月 (5)
2007年9月 (6)
2007年8月 (8)
2007年7月 (5)
相冊
公告照片
搜索
積分與排名
積分 - 662255
排名 - 25
最新評論
1.?re: boost::asio::spawn 將一統C++網絡庫
asio 成為C++首選網絡庫
--linda
2.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--金慶
3.?re: mingw編譯OrzNet
能發送一個mingw編譯好的OrzNet庫給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
5.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯誤(11075)
2.?SVN中邪惡的replace(11000)
3.?VS2005編譯libevent(10456)
4.?混音算法的學習與研究(10258)
5.?C調用lua腳本的效率測試(9025)
評論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯誤(18)
4.?C++引用優于指針(17)
5.?ACE與ASIO之間關于Socket編程的比較(16)
Wow, Mangos登錄時的SRP6認證
Wow, Mangos登錄時的SRP6認證
以Mangos代碼為參考, 解析SRP6的原理和實現.
(轉載請注明來源于金慶的專欄)
SRP全稱Secure Remote Password(安全遠程密碼),是一個開源認證協議。
SRP簡化后的原理是:
1. 服務器不保存密碼或密碼的散列值, 防止字典攻擊.
而只是保存驗證因子(verifier).
2. 客戶端和服務器可以各自計算出一個會話秘鑰(session key), 其值相同. 防止竊聽.
參考:
Wow 服務器解析 ( http://m.shnenglu.com/Jedimaster/archive/2006/10/14/13674.aspx )
SRP Protocol Design ( http://srp.stanford.edu/design.html )
魔獸世界服務器端編寫參考資料 ( http://www.asstudio.de/wow/wow.htm )
源碼 mangos/src/realmd/AuthSocket.cpp
RFC2954中文翻譯 ( http://www.cnpaf.net/rfc/rfc2945.txt )
SRP是什么意思?_百度知道 ( http://zhidao.baidu.com/question/59783252.html )
== Mangos SRP6認證過程 ==
1. 客戶端發送用戶名和版本信息
struct AUTH_LOGON_CHALLENGE_C
{
uint8 cmd;
uint8 error;
uint16 size;
uint8 gamename[4];
uint8 version1;
uint8 version2;
uint8 version3;
uint16 build;
uint8 platform[4];
uint8 os[4];
uint8 country[4];
uint32 timezone_bias;
uint32 ip;
uint8 I_len;
uint8 I[1];
};
大部份信息用來決定是否封阻該用戶登錄.
SRP6相關的只有I, 為用戶名.
SRP6相關的字段都是按協議中的符號定義的.
1.1 _SetVSFields(rI)設置v, s字段
從數據庫中獲取密碼散列值rI(字段名sha_pass_hash), 應該是密碼p,
x = H(s, p)
v = g^x (密碼學中的計算一般都是在最后對大質數N取模: v = g.ModExp(x, N);)
這個應該是驗證因子v.
然后v, s存入數據庫. x為臨時值, 用后丟棄.
salt值s是在連接時設置的隨機值.
/// Accept the connection and set the s random value for SRP6
void AuthSocket::OnAccept()
{
s.SetRand(s_BYTE_SIZE * 8);
}
s是32字節長, s_BYTE_SIZE = 32.
安全大質數N, 及其生成元g, 是固定的:
N.SetHexStr("894B645E89E1535BBDAD5B8B290650530801B18EBFBF5E8FAB3C82872A3E9BB7");
g.SetDword(7);
RFC2945:
For
maximum security, N should be a safe prime (i.e. a number of the form
N = 2q + 1, where q is also prime). Also, g should be a generator
modulo N (see [SRP] for details), which means that for any X where 0
< X < N, there exists a value x for which g^x % N == X.
為了最大化安全性,N可以是一個安全的素數
(也就是,一個類似于N=2q + 1形式的數,同時q是個素數)。
而且,g將是一個以N為模的生成元,
意味著,對任何X,有0 < X < N,存在一個值x,使得g^x % N == X。
Mangos保存了密碼p, 是錯誤的. 服務器不應該保存密碼或其散列值.
應該在創建用戶時, 由客戶端取s值, 計算v, 將{I, s, v}傳輸到服務器并保存.
登錄時, 特定用戶的s, v應該是固定的, 從數據庫讀取, 而不是每次登錄時隨機.
1.2 取b值, 計算B
b.SetRand(19 * 8);
BigNumber gmod=g.ModExp(b, N);
B = ((v * 3) + gmod) % N;
b為19字節長的隨機數. 不知為何是19字節長, 不是16或32?
b是服務器的臨時秘鑰, B為臨時公鑰.
B = kv + g^b
在SRP6中k=3, 而在最新的SRP6a中, k=H(N, g).
1.3 服務端返回 CMD_AUTH_LOGON_CHALLENGE 數據包
返回的數據結構沒有用struct定義, 只是用ByteBuffer依次填入數據.
ByteBuffer pkt;
pkt << (uint8) AUTH_LOGON_CHALLENGE;
pkt << (uint8) 0x00;
pkt << (uint8)REALM_AUTH_SUCCESS;
pkt.append(B.AsByteArray(32), 32); // 32 bytes
pkt << (uint8)1;
pkt.append(g.AsByteArray(), 1);
pkt << (uint8)32;
pkt.append(N.AsByteArray(), 32);
pkt.append(s.AsByteArray(), s.GetNumBytes()); // 32 bytes
pkt.append(unk3.AsByteArray(), 16);
pkt << (uint8)0; // Added in 1.12.x client branch
SendBuf((char const*)pkt.contents(), pkt.size());
B, g, N, s 是服務器發給客戶端的SRP6參數.
unk3是個16字節長的隨機數, 不知道干什么用的. (unknown3?)
按SRP6的協議, 應該是客戶端先發送自己的用戶名和公鑰(I, A), 但在Mangos中,
是服務器在沒有收到A時就發送鹽值和自己的公鑰(s, B).
這個次序應該無關緊要. 這樣做的原因是服務器要先發送N, g到客戶端, 這樣可少一次消息交互.
客戶端計算公鑰A時要用到N, g: A = g^a (隱含對N取模).
2. 客戶端發送 CMD_AUTH_LOGON_PROOF 數據包請求驗證
struct AUTH_LOGON_PROOF_C
{
uint8 cmd;
uint8 A[32];
uint8 M1[20];
uint8 crc_hash[20];
uint8 number_of_keys;
uint8 unk; // Added in 1.12.x client branch
};
A, M1有用
2.1 計算u, S, K
u = sha(A, B);
S = (A * (v.ModExp(u, N))).ModExp(b, N);
K = H(S);
其中K分奇偶位分別計算, 應該不是SRP的方法, 不知是否會降低散列效果.
2.2 計算M并與M1比較驗證
M = sha(sha(N) xor sha(g), sha(I), s, A, B, K)
2.3 M1驗證通過后計算M2, 用于客戶端驗證
M2 = sha(A, M, K)
2.4 服務端發回 CMD_AUTH_LOGON_PROOF
包含了 SRP6 驗證的結果 M2
struct AUTH_LOGON_PROOF_S
{
uint8 cmd;
uint8 error;
uint8 M2[20];
uint32 unk1;
uint32 unk2;
uint16 unk3;
};
posted on 2009-04-10 13:06
金慶
閱讀(4118)
評論(0)
編輯
收藏
引用
所屬分類:
1. C/C++
、
2. 網游開發
只有注冊用戶
登錄
后才能發表評論。
相關文章:
How are dtLinks created in NavMesh
C++ parameter passing rules
Naming Conventions for Accessors
Visual Studio 2019 Compiler Hangs
Fbx File Format Identifier
查找內存錯誤
std::thread 中的異常會丟失調用棧
用賦值代替 protobuf CopyFrom()
vs2017 linux 編譯輸出改成 vs 格式
為 LiteIDE 添加選中標記
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
久久精品国产精品
|
久久精品国产99
|
欧美色图麻豆
|
欧美日韩调教
|
欧美午夜免费
|
国产精品亚洲激情
|
国产一区91
|
精品69视频一区二区三区
|
国产精品视频在线观看
|
国产伦精品一区二区三区高清版
|
久久aⅴ国产紧身牛仔裤
|
亚洲男女自偷自拍图片另类
|
亚洲影音一区
|
久久久99免费视频
|
香蕉成人啪国产精品视频综合网
|
亚洲国产小视频
|
久久一区二区三区国产精品
|
日韩视频在线一区
|
国产自产精品
|
亚洲国产欧美国产综合一区
|
亚洲第一偷拍
|
一色屋精品视频在线观看网站
|
国语自产精品视频在线看
|
亚洲成人在线免费
|
亚洲欧美日韩精品久久久久
|
六月天综合网
|
亚洲精品乱码久久久久久
|
亚洲欧美日韩成人
|
麻豆精品一区二区综合av
|
国产精品电影网站
|
亚洲国产高清视频
|
午夜欧美电影在线观看
|
亚洲第一天堂av
|
香蕉久久国产
|
欧美午夜影院
|
日韩亚洲欧美一区
|
久久中文精品
|
亚洲一区网站
|
欧美日韩成人在线
|
亚洲激情电影在线
|
久久久久久久网站
|
一区二区三区免费看
|
欧美aⅴ一区二区三区视频
|
国产欧美日本在线
|
亚洲一区二区三区高清不卡
|
亚洲国产精品www
|
久久久久国产精品麻豆ai换脸
|
国产精品久久久久77777
|
99精品久久
|
亚洲黄网站黄
|
欧美二区不卡
|
亚洲毛片av
|
亚洲激情欧美
|
每日更新成人在线视频
|
韩国在线视频一区
|
久久久视频精品
|
午夜精彩视频在线观看不卡
|
国产精品久久久91
|
香蕉免费一区二区三区在线观看
|
99国产精品视频免费观看一公开
|
久久精品国产一区二区三区免费看
|
免播放器亚洲一区
|
久久先锋资源
|
久久精品国产亚洲5555
|
国产日本欧美视频
|
新狼窝色av性久久久久久
|
一区二区三区导航
|
国产精品手机视频
|
久久国产乱子精品免费女
|
欧美一区二区三区男人的天堂
|
久久爱91午夜羞羞
|
国内精品国产成人
|
免费日韩精品中文字幕视频在线
|
久久激情中文
|
亚洲国产精品热久久
|
最近中文字幕日韩精品
|
欧美日韩国产黄
|
亚洲视频精品在线
|
一区二区三区你懂的
|
国产亚洲激情
|
欧美凹凸一区二区三区视频
|
欧美国产激情二区三区
|
99精品热视频
|
亚洲主播在线观看
|
国语精品中文字幕
|
亚洲精华国产欧美
|
国产精品亚洲激情
|
美女亚洲精品
|
欧美视频第二页
|
久久精品观看
|
免费不卡中文字幕视频
|
亚洲制服欧美中文字幕中文字幕
|
亚洲综合社区
|
亚洲激情校园春色
|
亚洲特色特黄
|
亚洲第一在线综合在线
|
av成人免费观看
|
精品成人一区
|
中国成人黄色视屏
|
一区二区亚洲精品国产
|
9人人澡人人爽人人精品
|
国产综合久久
|
中文国产成人精品久久一
|
在线免费高清一区二区三区
|
在线亚洲成人
|
亚洲裸体视频
|
久久免费偷拍视频
|
亚洲欧美在线高清
|
欧美成人精品一区二区
|
久久久国产精品亚洲一区
|
欧美激情精品久久久久久大尺度
|
午夜精品视频在线观看
|
欧美大片91
|
久久综合电影
|
国产精品亚洲精品
|
亚洲美女av黄
|
最新国产成人av网站网址麻豆
|
亚洲一级黄色片
|
久久国产成人
|
欧美久久久久久久
|
麻豆久久久9性大片
|
国产精品入口日韩视频大尺度
|
亚洲第一福利视频
|
在线免费观看视频一区
|
亚洲欧美国产va在线影院
|
99精品国产热久久91蜜凸
|
欧美成人tv
|
欧美亚洲日本国产
|
国产精品久久久久久亚洲调教
|
亚洲每日更新
|
亚洲视频在线播放
|
欧美精品黄色
|
最新国产精品拍自在线播放
|
…久久精品99久久香蕉国产
|
欧美在线欧美在线
|
久久精品视频免费
|
国产亚洲高清视频
|
欧美在线1区
|
久久久999精品免费
|
国产日韩综合一区二区性色av
|
亚洲午夜影视影院在线观看
|
亚洲一区二区三区视频播放
|
欧美日韩精品一区二区天天拍小说
|
91久久精品一区二区别
|
亚洲毛片在线观看.
|
欧美激情精品久久久久久久变态
|
亚洲精品美女91
|
亚洲综合第一
|
国产精品午夜春色av
|
亚洲欧美日韩在线不卡
|
久久久久久久久伊人
|
亚洲激情网址
|
欧美亚洲第一区
|
欧美亚洲网站
|
欧美成人精品三级在线观看
|
亚洲精选中文字幕
|
国产精品成人观看视频免费
|
亚洲欧美日韩国产一区二区三区
|
久久久久久久综合
|
伊人成人开心激情综合网
|
欧美国产日本高清在线
|
99精品黄色片免费大全
|
亚洲欧美激情视频
|
国产亚洲欧洲
|
欧美激情视频给我
|
亚洲性图久久
|
蜜臀va亚洲va欧美va天堂
|
亚洲精选一区
|
国产日韩精品久久
|
欧美r片在线
|
亚洲网站啪啪
|
欧美成人免费全部
|
亚洲一区免费看
|
在线免费观看欧美
|
国产精品久久久久久久7电影
|
久久国内精品视频
|
日韩一级二级三级
|
免费看的黄色欧美网站
|
亚洲少妇自拍
|
在线视频成人
|
国产深夜精品福利
|
欧美日韩三级在线
|
久久人人爽人人爽
|
亚洲男同1069视频
|
日韩视频免费看
|
欧美刺激性大交免费视频
|
香蕉乱码成人久久天堂爱免费
|
亚洲国产成人精品女人久久久
|
国产精品久久影院
|
欧美激情精品久久久久久大尺度
|
永久域名在线精品
|
欧美日韩一区三区四区
|
久久久久久久久久久久久9999
|
9人人澡人人爽人人精品
|
欧美aⅴ一区二区三区视频
|
午夜在线播放视频欧美
|
影音先锋久久精品
|
欧美亚洲一区
|
中日韩高清电影网
|
狠狠久久婷婷
|