程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> WebQQ網頁hash加密算法PHP版

WebQQ網頁hash加密算法PHP版

編輯:關於PHP編程

我們在QQ網上找到的一個hash加密算法是js版本的,下面我們根據js版的hash加密算法改成php版的加密算法,希望方法對各位有幫。

由於最近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 */

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved