TA的每日心情 | 奋斗 2020-6-5 22:18 |
---|
签到天数: 22 天 [LV.4]偶尔看看III
|
我们先打开HttpWatch所保存的数据如下图所示:
上次分析了第一条数据,现在我们把第二条数据复制出来(选中后右键选择 Copy Row):
从图中不难看出所截取的第二条数据用得是GET方法,根据网络数据交换方面的知识应该会想起这么一点:本机客户端所发送到服务器的数据中多少都有上次服务器返回来的数据的一部分,当然如果是第一次和服务器交互时的数据一定没有了(如果不理解的朋友,你只要记住这好了,接触多了慢慢得会知道是怎么回事了)。
那现在我们就找找易语言+HttpWatch分析并编写Discuz! X1.51论坛管理器第一课中那些返回的数据和下面这段数据有关:
http://wgbcwsoft.web-108.com/1.51/member.php?mod=logging&action=login&auth=55dem%2BRgn7mTn3h10XIfc9Q9xRiV8s8qwbRn2rdfIS0Uj4NxoqZr1k82ZrQ&referer=http%3A%2F%2Fwgbcwsoft.web-108.com%2F1.51%2Fforum.php&infloat=yes&handlekey=login&inajax=1&ajaxtarget=fwin_content_login
不难发现我们在第一课中发现下面三段相关数据:
第一、在第一课中用所分析到的数据编写了一段易语言代码,测试中分析所返回的数据如下图所示:
第二、第一课中的"Content"数据:
<?xml version="1.0" encoding="gbk"?>
<root><![CDATA[location_login<script type="text/javascript" reload="1">if(typeof errorhandle_ls=='function') {errorhandle_ls('location_login', {'type':'1'});}</script><script type="text/javascript">showWindow('login', 'member.php?mod=logging&action=login&auth=55dem%2BRgn7mTn3h10XIfc9Q9xRiV8s8qwbRn2rdfIS0Uj4NxoqZr1k82ZrQ&referer=http%3A%2F%2Fwgbcwsoft.web-108.com%2F1.51%2Fforum.php')</script>]]></root>
或者第三、第一课中的"Stream"的第二部分数据:
<?xml version="1.0" encoding="gbk"?>
<root><![CDATA[location_login<script type="text/javascript" reload="1">if(typeof errorhandle_ls=='function') {errorhandle_ls('location_login', {'type':'1'});}</script><script type="text/javascript">showWindow('login', 'member.php?mod=logging&action=login&auth=55dem%2BRgn7mTn3h10XIfc9Q9xRiV8s8qwbRn2rdfIS0Uj4NxoqZr1k82ZrQ&referer=http%3A%2F%2Fwgbcwsoft.web-108.com%2F1.51%2Fforum.php')</script>]]></root>
稍微有点JavaScript知识的朋友应该看出在上面三段代码中有"showWindow",这函数应该就是登陆时所弹出的验证码窗口数据。经比较后发现都有共同的部分:
第二条GET方法的数据:
member.php?mod=logging&action=login&auth=55dem%2BRgn7mTn3h10XIfc9Q9xRiV8s8qwbRn2rdfIS0Uj4NxoqZr1k82ZrQ&referer=http%3A%2F%2Fwgbcwsoft.web-108.com%2F1.51%2Fforum.php
"Content"数据:
member.php?mod=logging&action=login&auth=55dem%2BRgn7mTn3h10XIfc9Q9xRiV8s8qwbRn2rdfIS0Uj4NxoqZr1k82ZrQ&referer=http%3A%2F%2Fwgbcwsoft.web-108.com%2F1.51%2Fforum.php
"Stream"数据:
member.php?mod=logging&action=login&auth=55dem%2BRgn7mTn3h10XIfc9Q9xRiV8s8qwbRn2rdfIS0Uj4NxoqZr1k82ZrQ&referer=http%3A%2F%2Fwgbcwsoft.web-108.com%2F1.51%2Fforum.php
易语言编程测试后返回的数据略,可参考上面的图。
上面三条数据及上面示图所示的数据中不难发现除了"auth="之后及"&referer"之前的数据不一样外,其它都相同,经多次截取数据后发现这地方不同,有兴趣的朋友可以试下,毕竟在这写这么多不动手也是空谈。
根据上面所分析表明:在HttpWatch中的第二条数据就是第一条数据返回数据中的一部分,那这样我们可用易语言工具接着写第二条数据所执行的GET方法了,首先要取得第一条数据中返回的数据,我们必须要用到系统核心库中的"文本操作"里的几个命令,另外在易语言工具默认的支持库中也只有"HTTP读文件"这个命令,我们就用它来编写代码好了,写代码中……稍后继续
好了测试代码写好了,如下:- .版本 2
- .支持库 internet
- .子程序 _按钮1_被单击
- .局部变量 返回的数据, 字节集, , , 第一课定义
- .局部变量 RequestLine, 文本型, , , 第一课定义
- .局部变量 PostData, 文本型, , , 第一课定义
- .局部变量 Host, 文本型, , , 第一课定义
- .局部变量 RequestLine2, 文本型, , , 第二课定义showWindow里的重要数据
- .局部变量 member位置, 整数型, , , 第二课定义member文本位置
- .局部变量 referer位置, 整数型
- .局部变量 referer, 文本型
- ' 第一课代码开始=====================
- Host = “http://wgbcwsoft.web-108.com”
- RequestLine = Host + “/1.51/member.php?mod=logging&action=login&loginsubmit=yes&infloat=yes&lssubmit=yes&inajax=1”
- PostData = “username=” + 编辑框1.内容 + “&password=” + 编辑框2.内容 + “&quickforward=yes&handlekey=ls”
- 返回的数据 = HTTP读文件 (RequestLine + “&” + PostData)
- 调试窗口.编辑框1.加入文本 (到文本 (返回的数据)) ' 第二课改
- ' 第二课代码开始
- .如果 (到文本 (返回的数据) ≠ “”)
- member位置 = 寻找文本 (到文本 (返回的数据), “member”, , 假)
- referer位置 = 寻找文本 (到文本 (返回的数据), “referer”, , 假)
- RequestLine2 = 取文本中间 (到文本 (返回的数据), member位置, referer位置 - member位置 - 1)
- 调试窗口.编辑框1.加入文本 (“第一条数据返回:===========” + RequestLine2 + “===========”)
- .如果 (RequestLine2 ≠ “”)
- referer = Host + “/1.51/”
- 返回的数据 = HTTP读文件 (referer + RequestLine2 + “&referer=” + referer + “forum.php&infloat=yes&handlekey=login&inajax=1&ajaxtarget=fwin_content_login”)
- 调试窗口.编辑框1.加入文本 (到文本 (返回的数据))
- .否则
- .如果结束
- .否则
- 调试窗口.编辑框1.加入文本 (“服务器没返回数据,请检查……”)
- .如果结束
复制代码 经测试后返回如下数据:好了这次课就到这里,下次课我们祥细讲讲
referer + RequestLine2 + “&referer=” + referer + “forum.php&infloat=yes&handlekey=login&inajax=1&ajaxtarget=fwin_content_login”)
这段数据怎么分析出来的。
|
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?注册
x
|