海运的博客

PHP版本QQ密码及g_tk算法

发布时间:November 7, 2014 // 分类:PHP // No Comments

<?php
   function hexchar2bin($str)
   {
      $arr = '';
      $temp = null;
      for ($i = 0; $i < strlen($str); $i = $i + 2) {
         $arr .= "\\x" . substr($str, $i, 2);
      }
      eval('$temp="' . $arr . '";');
      return $temp;
   }

   function getUid($uid)
   {
      $temp = null;
      eval('$temp="' . $uid . '";');
      return $temp;
   }
   function getEncryption($password, $uin, $vcode)
   {
      $uin = getUid($uin);
      $str1 = hexchar2bin(strtoupper(md5($password)));
      $str2 = strtoupper(md5($str1 . $uin));
      return strtoupper(md5($str2 . strtoupper($vcode)));
   }
   //print_r(getEncryption('chen123','\x00\x00\x00\x00\xba\xaf\x34\x87','!GMO'));

   function utf8_unicode($c)
   {
      switch (strlen($c)) {
         case 1:
         return ord($c);
         case 2:
         $n = (ord($c[0]) & 0x3f) << 6;
         $n += ord($c[1]) & 0x3f;
         return $n;
         case 3:
         $n = (ord($c[0]) & 0x1f) << 12;
         $n += (ord($c[1]) & 0x3f) << 6;
         $n += ord($c[2]) & 0x3f;
         return $n;
         case 4:
         $n = (ord($c[0]) & 0x0f) << 18;
         $n += (ord($c[1]) & 0x3f) << 12;
         $n += (ord($c[2]) & 0x3f) << 6;
         $n += ord($c[3]) & 0x3f;
         return $n;
      }
   }

   function getGTK($str)
   {
      $hash = 5381;
      for ($i = 0, $len = strlen($str); $i < $len; ++$i) {
         $hash += ($hash << 5) + utf8_unicode($str[$i]);
      }
      return $hash & 2147483647;
   }
   print_r(getGTK('@LNKTSNI0F'));

另一种g_tk的算法:

<?php

function charCodeAt($str, $index)
{
  $char = mb_substr($str, $index, 1, 'UTF-8');

  if (mb_check_encoding($char, 'UTF-8'))
  {
    $ret = mb_convert_encoding($char, 'UTF-32BE', 'UTF-8');
    return hexdec(bin2hex($ret));
  }
  else
  {
    return null;
  }
}

function getGTK($str)
{
  $md5key = 'tencentQQVIP123443safde&!%^%1282';
  $salt = 5381;
  $hash = $salt << 5;
  for ($i = 0, $len = strlen($str); $i < $len; ++$i) 
  {
    $asciicode = charCodeAt($str[$i], 0);
    $hash = $hash . (($salt << 5) + $asciicode);
    $salt = $asciicode;
  }
  return md5($hash . $md5key);
}
echo getGTK('AYg8iSVJL58F4X2EHBbIT5BS');

标签:none

评论已关闭

分类
最新文章
最近回复
  • : linux系统上单个网卡多条宽带拨号获取公网IP,外网可以访问这些IP,有偿! Q:25299...
  • 硅谷少年: 非常有用,感谢分享
  • spartan2: https://dashboard.hcaptcha.com/welcome_accessib...
  • 海运: 应该能,在购买页面先手工跳过cf机器验证,后续一定时间内不更换ip应该不会再次验证。
  • spartan: 大佬斯巴达开启了CF的机器识别验证,请问插件能自动跳过吗? 另外这个脚本有没有简单使用说明,新...
  • vincent: 膜拜大佬
  • 海运: proxy-header或proxy_protocol
  • liangjw: 如果是 内部调用 或者 中间存在 代理 而上一个代理又在内网 ,那怎么处理来自代理私有IP?
  • chainofhonor: 感谢,用dnsmasq设置自动判断BIOS和UEFI成功了
  • 海运: 不好意思,这个是很多年前的,现在也许已经不适用,我现在也不用多线了。