WebQQ网页hash加密算法PHP版
发布:smiling 来源: PHP粉丝网 添加日期:2014-07-11 14:50:52 浏览: 评论:0
由于最近QQ垃圾信息群发严重,官方选择将WebQQ部分功能实现细节方面做了点手脚,其中获取好友的POST值多了一个hash参数,这个hash是在js里加密完成的,以下是js源码:
- <script type="text/javascript">
- function getHash(b, i) {
- for (var a = i + "password error",
- s = "",
- j = [];;) if (s.length <= a.length) {
- if (s += b, s.length == a.length) break
- } else {
- s = s.slice(0, a.length);
- break
- }
- for (var d = 0; d < s.length; d++) j[d] = s.charCodeAt(d) ^ a.charCodeAt(d);
- a = ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "E", "F"];
- s = "";
- for (d = 0; d < j.length; d++) s += a[j[d] >> 4 & 15],
- s += a[j[d] & 15];
- return s;
- }
- </script>
转成PHP版本处理,源码如下:
- <?php
- /**
- * 获取好友时的POST参数Hash算法
- *
- * public
- * @param string $qq qq号
- * @param string $ptwebqq cookies中的ptwebqq
- * @return string
- */
- function get_hash($qq, $ptwebqq)
- {
- for ($a = $ptwebqq . "password error", $s = "", $j = array();;)
- {
- if (strlen($s) <= strlen($a))
- {
- $s .= $qq;
- if ($s == strlen($a)) break;
- }
- else
- {
- $s = substr($s, 0, strlen($a));
- break;
- }
- }
- for ($d = 0; $d < strlen($s); $d++)
- {
- $j[$d] = uniord(substr($s,$d)) ^ uniord(substr($a,$d));
- }
- $a = array("0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "E", "F");
- $s = "";
- for ($d = 0; $d < count($j); $d++)
- {
- $s .= $a[$j[$d] >> 4 & 15];
- $s .= $a[$j[$d] & 15];
- }
- return $s;
- }
- /**
- * 模拟 JavaScript charCodeAt函数
- *
- * protected
- * @param string $str
- * @return int
- */
- function uniord($str)
- {
- list(, $ord) = unpack('N', mb_convert_encoding($str, 'UCS-4BE', 'UTF-8'));
- return
- $ord;
- }
- /* End of file commons.php */
Tags: WebQQ hash加密算法
相关文章
- ·WebQQ最新登陆协议的例子(2014-09-22)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)