用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

WebQQ网页hash加密算法PHP版

时间:2015-01-23  来源:西部数据  作者:西部数据

由于最近QQ垃圾信息群发严重,官方选择将WebQQ部分功能实现细节方面做了点手脚,其中获取好友的POST值多了一个hash参数,这个hash是在js里加密完成的,以下是js源码:

  1. <script type="text/javascript"
  2. function getHash(b, i) { 
  3.     for (var a = i + "password error"
  4.     s = "",  
  5.     j = [];;) if (s.length <= a.length) {                                                                                                        
  6.         if (s += b, s.length == a.length) break 
  7.     } else { 
  8.         s = s.slice(0, a.length); 
  9.         break 
  10.     }    
  11.     for (var d = 0; d < s.length; d++) j[d] = s.charCodeAt(d) ^ a.charCodeAt(d); 
  12.     a = ["0""1""2""3""4""5""6""7""8""9""A""B""C""D""E""F"]; 
  13.     s = "";  
  14.     for (d = 0; d < j.length; d++) s += a[j[d] >> 4 & 15], 
  15.     s += a[j[d] & 15]; 
  16.     return s; 
  17. </script> 

转成PHP版本处理,源码如下:

  1. <?php 
  2. /** 
  3.  * 获取好友时的POST参数Hash算法 
  4.  *  
  5.  * public  
  6.  * @param string $qq qq号 
  7.  * @param string $ptwebqq cookies中的ptwebqq 
  8.  * @return string 
  9.  */ 
  10. function get_hash($qq$ptwebqq
  11.  for ($a = $ptwebqq . "password error"$s = ""$j = array();;) 
  12.  { 
  13.   if (strlen($s) <= strlen($a)) 
  14.   { 
  15.    $s .= $qq
  16.    if ($s == strlen($a)) break
  17.   } 
  18.   else 
  19.   { 
  20.    $s = substr($s, 0, strlen($a)); 
  21.    break
  22.   } 
  23.  } 
  24.  
  25.  for ($d = 0; $d < strlen($s); $d++) 
  26.  { 
  27.   $j[$d] = uniord(substr($s,$d)) ^ uniord(substr($a,$d)); 
  28.  } 
  29.  
  30.  $a = array("0""1""2""3""4""5""6""7""8""9""A""B""C""D""E""F"); 
  31.  $s = ""
  32.  for ($d = 0; $d < count($j); $d++) 
  33.  { 
  34.   $s .= $a[$j[$d] >> 4 & 15]; 
  35.   $s .= $a[$j[$d] & 15]; 
  36.  } 
  37.  
  38.  return $s
  39.  
  40. /** 
  41.  * 模拟 JavaScript charCodeAt函数  
  42.  *  
  43.  * protected 
  44.  * @param string $str 
  45.  * @return int 
  46.  */ 
  47. function uniord($str
  48.  list(, $ord) = unpack('N', mb_convert_encoding($str'UCS-4BE''UTF-8')); 
  49.  
  50.  return   
  51.  
  52. $ord
  53. /* End of file commons.php */ 
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门