首页
社区
课程
招聘
[原创]QQ号申请工具 编写原理
2011-8-29 13:46 76941

[原创]QQ号申请工具 编写原理

2011-8-29 13:46
76941
大家都知道现在有很多申请QQ号的软件,只要填写软件上的验证码,就可以帮你自动申请一个QQ,并保存下来。 它简化了 注册的流程。


通常这类软件有两种,一个编程时用了IE的控件,直接向这些表单填写数据,另一种就是今天要讲的,用封包的方法来实现自动申请QQ。

想一下,我们面临的难题有:
1.验证码的gif图片在哪,如何让程序获取图片,并显示出来。
2.http请求中包的分析和构建。
当然第二个是重点。

先完成第一项任务。
我们打开 www.reg.qq.com ,会有这个http请求

用文字就是:
GET: http://captcha.qq.com/getimage?aid=1007901&0.3621022082160978
Accept: */*
Referer: http://reg.qq.com/
Accept-Language: zh-CN
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.1; Trident/4.0; User-agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; http://bsalsa.com) ; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0E; .NET4.0C)
Host: captcha.qq.com
Connection: Keep-Alive
---------------------------------------------
http://captcha.qq.com/getimage?aid=1007901&0.3621022082160978
看这个url,有两个数据,是否是定值呢。
再重新登陆 reg.qq.com,会发现 aid=后面的数字没有变,但第二个数据变化了。
这个很容易理解,因为每次登陆会有不同的验证码嘛。

但第一个数据,仔细看看之前发的包,就会知道 1007901,是GetDay产生的,过一天可能就加1了。呵呵!但今天无论怎么换验证码,都不会改变的。

OK。 gif图片已经获取。
char	szAccept[]	 = "Accept: */gif";
    char	szReferer[]	 = "Referer:  http://reg.qq.com/\r\n\r\n";
	CString strBuffer	 = _T("");
	CString	strRecv		 = _T("");

	HINTERNET	hSession;   
	HINTERNET   hConnect;   
	HINTERNET   hRequest;   
	BOOL		bReturn	 = FALSE;
	CString str=_T("/getimage?aid=1007901&0.0022421072022002497");
	// 之前使用Socket,现在使用Wininet相关API建立链接
	hSession = InternetOpen("InetAll",INTERNET_OPEN_TYPE_PRECONFIG,NULL,NULL,0);
	hConnect = InternetConnect(hSession,"captcha.qq.com",INTERNET_DEFAULT_HTTP_PORT,NULL,NULL,INTERNET_SERVICE_HTTP,0,1);
	hRequest = HttpOpenRequest(hConnect,"GET",str,NULL,"http://reg.qq.com/",(PCSTR*)szAccept,INTERNET_FLAG_RELOAD,1);

	// 提交数据表单
	
	bReturn = HttpSendRequest(hRequest,NULL,-1,NULL,0);
	if(!bReturn)
	{
		MessageBox("发送Http请求失败!","提示",MB_ICONERROR | MB_OK);
		return FALSE;
	}

        //之后就是生成图片了。
	hFile.Open("temp.dat",CFile::modeWrite | CFile::modeCreate,NULL);
		
         InternetReadFile(hRequest,szRecvBuf,1024,&dwNumberOfBytesRead);
 
		}

1.2  怎么在VC的对话框窗口上显示出这个图片呢。
 在此结出了一种借助于COM接口的OLE方法来实现上述功能
 要使用IPicture 的COM接口,其主要的接口是IPicture和IPictureDisp,后者是由IDispatch接口派生以便通过自动化对图像的属性进行访问。图像对象也支持外部接口IPropertyNotifySink,以便用户能在图像属性发生改变时作出决定。图像对象也支持IPersistStream接口,所以它能从一个IStream接口的实例对象保存、装载自己,而IStream接口也支持对流对象的数据读写。

  我们可以用函数OleLoadPicture从包含有图像数据的流中装载图像。该函数简化了基于流的图像对象的创建过程,可以创建一个新的图像对象并且用流中的内容对它进行初始化。其函数原型为:

STDAPI OleLoadPicture( IStream * pStream, //指向包含有图像数据的流的指针
LONG lSize, //从流中读取的字节数
BOOL fRunmode, //图像属性对应的初值
REFIID riid, //涉及到的接口标识,描述要返回的接口指针的类型
VOID ppvObj // 在rrid中用到的接口指针变量的地址) ;

先将图片数据放入内存
bool CQQ号申请工具Dlg::LoadPic(CString m_path)
{
	IStream *pStm;
	CFileStatus fstatus;
	CFile file;
	LONG cb; 
	if (file.Open(m_path,CFile::modeRead)&&file.GetStatus(m_path,fstatus)&& ((cb = fstatus.m_size) != -1))
	{
		HGLOBAL hGlobal = GlobalAlloc(GMEM_MOVEABLE, cb);
		 LPVOID pvData = NULL;
		 if (hGlobal != NULL)
		   {
				if ((pvData = GlobalLock(hGlobal)) != NULL)
				  {
						file.Read(pvData, cb);
						GlobalUnlock(hGlobal);
					CreateStreamOnHGlobal(hGlobal, TRUE, &pStm);
				  }
		   }
	}
	return TRUE;
}

[培训]内核驱动高级班,冲击BAT一流互联网大厂工 作,每周日13:00-18:00直播授课

上传的附件:
  • 1.gif (15.48kb,3749次下载)
  • 2.gif (18.70kb,3742次下载)
收藏
点赞5
打赏
分享
最新回复 (80)
雪    币: 544
活跃值: (55)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
ddsoft 2011-8-29 13:47
2
0
为工程加一个IPicture *pPic 变量。
直接调用OleLoadPicture函数从流中装载图像:

OleLoadPicture(pStm,fstatus.m_size,TRUE,IID_IPicture,(LPVOID*)&pPic));

  由于该函数有时会导致失败,所以应当用SUCCEEDED宏来做一些适当的保护工作,只有在数据装载成功的前提下才能继续下面的图像显示工作:
int CQQ号申请工具Dlg::DrawPic(int x, int y, CDC* pDC)
{
	if(SUCCEEDED(OleLoadPicture(pStm,fstatus.m_size,TRUE,IID_IPicture,(LPVOID*)&pPic)))
	{
		OLE_XSIZE_HIMETRIC hmWidth;
		OLE_YSIZE_HIMETRIC hmHeight;
		 pPic->get_Width(&hmWidth);
		 pPic->get_Height(&hmHeight);
		double fX,fY;
		fX = (double)pDC->GetDeviceCaps(HORZRES)*(double)hmWidth/((double)pDC->GetDeviceCaps(HORZSIZE)*100.0);
		fY = (double)pDC->GetDeviceCaps(VERTRES)*(double)hmHeight/((double)pDC->GetDeviceCaps(VERTSIZE)*100.0);
		if(FAILED(pPic->Render(*pDC,0,0,(DWORD)fX,(DWORD)fY,0,hmHeight,hmWidth,-hmHeight,NULL))) {
			AfxMessageBox(_T("渲染图像失败!"));
			pPic->Release();
	}
		
	} 
	return 0;
}


OK。测试下没有问题。第一步已经完全完成。

2.现在开始进入http协议的处理。
这里有一个非常 重要的http请求。。。之后的加密就靠它了。。

GET:  http://reg.qq.com/cgi-bin/checkconn?seed0.9770701186312112

Accept: */*
Accept-Language: zh-cn
Referer: http://reg.qq.com/
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.1; Trident/4.0; User-agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; http://bsalsa.com) ; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0E; .NET4.0C)
Host: reg.qq.com
Connection: Keep-Alive

seed这个单词一看就知道是随机数。这个http请求,每次它会更新两个数组。
包含13个值。 对应于网页上的所有内容。
如密码,年,月,日,验证码 等等。

我们看下这个http请求的返回内容。
g_dataArray=new Array(new Array("77201a3173562c7715387d451b6a","44440b376f4f2c4b52216a561e54","62391830754f3d775e185d653b4a","13750a2a65523d6c482238520e71","7f79093a50403a7650237a572d50","14750a2a65523d6c4822395a0679","7137083a784f6c75563e7b471964","56211a3173562c771620655d0362","44750b2d6f57206b442951695d20","77771a3865442f624f256258007f","7121083a784f2675563e7b471964","1d791a3173562c7717286d550b7a","7775183e7245076a6e06437f215c"),
new Array(9759,9745,9748,9758,9752,9747,9755,9744,9754,9750,9749,9751,9753),"/cgi-bin/getnum");

这里可能看不明白。
我将这些数据逆序,并整理下
"7775183e7245076a6e06437f215c"
"1d791a3173562c7717286d550b7a",
"7121083a784f2675563e7b471964",
"77771a3865442f624f256258007f",
"44750b2d6f57206b442951695d20",
"56211a3173562c771620655d0362",
"7137083a784f6c75563e7b471964",
"14750a2a65523d6c4822395a0679",
"7f79093a50403a7650237a572d50",
"13750a2a65523d6c482238520e71",
"62391830754f3d775e185d653b4a",
"44440b376f4f2c4b52216a561e54",
"77201a3173562c7715387d451b6a",

看看我们在网页上申请后,所提交的http请求。

上传的附件:
  • 4.gif (9.48kb,3703次下载)
  • 5.gif (24.35kb,3710次下载)
雪    币: 544
活跃值: (55)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
ddsoft 2011-8-29 14:12
3
0
数据太长,我列出来。

POST : http://reg.qq.com/cgi-bin/getnum

Accept: */*
Content-Type: application/x-www-form-urlencoded
Referer: http://reg.qq.com/#
Accept-Language: zh-cn
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.1; Trident/4.0; User-agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; http://bsalsa.com) ; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0E; .NET4.0C)
Host: reg.qq.com
Content-Length: 462
Connection: Keep-Alive

提交的数据:
7775183e7245076a6e06437f215c=ddsoft&1d791a3173562c7717286d550b7a=42&7121083a784f2675563e7b471964=pediytest&77771a3865442f624f256258007f=0&44750b2d6f57206b442951695d20=6&56211a3173562c771620655d0362=nfxnys&7137083a784f6c75563e7b471964=23&14750a2a65523d6c4822395a0679=1&7f79093a50403a7650237a572d50=1&13750a2a65523d6c482238520e71=1&62391830754f3d775e185d653b4a=2&44440b376f4f2c4b52216a561e54=pediytest&77201a3173562c7715387d451b6a=2009&qzone_flag=1&alskdjf=fjdksla
列成表格形式一目了然。


主要是发包时加密字串是固定顺序,但表单中的value 顺序与 产生的第二个数组有关。
因为第二个数据全部为数字,猜测与数字大小有关。我这里没有继续研究,有兴趣的朋友发表下你的成果。
最后,感谢你的支持!

不知能不能骗个精华。呵呵!
上传的附件:
  • 6.gif (11.58kb,3707次下载)
雪    币: 166
活跃值: (25)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
地精锁匠 2011-8-29 14:38
4
0
好东西!学习下!好像是沙发呢!
雪    币: 6
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
ylsh 2011-8-29 14:42
5
0
好什么呢?没有实质的东西啊。你发一个啊
雪    币: 2362
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
zapline 2011-8-29 14:44
6
0
很有营养的文章,不过估计不合版主口味就木有精华啦
雪    币: 414
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
孟贤 2011-8-29 14:49
7
0
比用IE控件直接填写表单有技术含量;

非常不错;
雪    币: 601
活跃值: (256)
能力值: ( LV11,RANK:190 )
在线值:
发帖
回帖
粉丝
RootSuLe 4 2011-8-29 14:53
8
0
thanks for share
雪    币: 1015
活跃值: (235)
能力值: ( LV12,RANK:440 )
在线值:
发帖
回帖
粉丝
loongzyd 10 2011-8-29 14:57
9
0
thanks 精华应该没有问题吧
雪    币: 1675
活跃值: (594)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
djxh 2011-8-29 14:58
10
0
不错不错,支持楼主
雪    币: 303
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
bluecode 2011-8-29 15:05
11
0
学习了.支持LZ
雪    币: 23
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
小P孩儿 2011-8-29 15:08
12
0
真滴很不错饿饿
雪    币: 38
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
狼丶牙 2011-8-29 16:14
13
0
从对网络协协议的理解到编程都是真才实学
雪    币: 276
活跃值: (709)
能力值: ( LV15,RANK:520 )
在线值:
发帖
回帖
粉丝
邓韬 9 2011-8-29 17:13
14
0
膜拜一下医学界的大牛!
雪    币: 967
活跃值: (1138)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
elianmeng 1 2011-8-29 17:27
15
0
吓我一跳
我已经直接验证了图片啊
这个 你用vb自带的那个web控件 记录一下值貌似就可以了
雪    币: 492
活跃值: (53)
能力值: ( LV6,RANK:80 )
在线值:
发帖
回帖
粉丝
fhurricane 1 2011-8-29 19:27
16
0
不错,学习一下了
雪    币: 1947
活跃值: (1805)
能力值: (RANK:400 )
在线值:
发帖
回帖
粉丝
莫灰灰 9 2011-8-30 18:50
17
0
学习了~~
雪    币: 788
活跃值: (45)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
Nekoxiaoji 2011-8-30 22:38
18
0
顶啊..............................
雪    币: 220
活跃值: (15)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
广海混沌 2011-8-31 09:00
19
0
呵呵 还行   。
雪    币: 108
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
setmefree 2011-8-31 09:01
20
0
很不错的文章,谢谢分享哈
雪    币: 212
活跃值: (25)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
kisbuddy 2011-8-31 10:22
21
0
果断留下~
雪    币: 90
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
慢慢学 2011-8-31 10:22
22
0
顶个....................
雪    币: 149
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
cnlcg 2011-8-31 10:57
23
0
用c#效率会更高些
雪    币: 1
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
金囧菇 2011-8-31 12:28
24
0
楼主很强悍,写的超详细
雪    币: 878
活跃值: (496)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
Rprop 2011-8-31 12:52
25
0
腾讯对表单进行了乱序处理。

QQ靓号申请器v1.2.0.0【源码】
http://blog.csdn.net/rrrfff/article/details/6682902
游客
登录 | 注册 方可回帖
返回