python爬取资料_Python爬取FLASH播放器中的资料

Python爬取FLASH播放器中的资料。

一、首先了解一下AMF协议:AMF(Action Message Format)是Flash与服务端通信的一种常见的二进制编码模式,其传输效率高,可以在HTTP层面上传输。现在很多Flash WebGame都采用这样的消息格式。

AMF协议是基于Http协议的.

它的内容处理过程大致是这样:

1.从客户端获取Http请求(Request)流.

2.对流进行解串行化(Deserialize),得到服务器端程序能够识别的数据,并建立一个响应(Response)消息

3.Debug开始

4.对流进行各种处理(记录、许可、服务)得到返回值

5.对响应流进行串行化

6.发送Http响应给客户端

二、Python与amf进行互通需要用到PyAMF

1、下载pyamf

https://pypi.python.org/pypi/PyAMF

2、安装pyamf

下载完成之后解压出来,打开DOS命令进入pyamf目录,

执行下列命令,安装pyamf框架

python setup.py install --disable-ext

三、获取关键字节伪造访问

首先使用charles抓包工具,抓取AMF包,得到请求/应答的AMF数据,对AMF格式的请求和响应的数据进行分析。

解密的POST DATA如下图所示:

AAffA0nNPuCLAAAAAElFTkSuQmCC

构建flex.messaging.messages.RemotingMessage信息msg= messaging.RemotiongMessage(messageId=str(uuid.uuid1()).upper(),\

clometOd=None,\

operation='playeSource',\

destination='metaDataService',\

timeTolive=0,\

timestamp=0

)

msg.body=['xxx', 'aaaaa', 'ccccc','ddddd', '', 'eeeee', '']

msg.headers['DSEndpoint']='my-amf'msg.headers['DSId']=str(uuid.uuid1()).upper()

......

得到的Response如下图:

AAffA0nNPuCLAAAAAElFTkSuQmCC

四、具体实现代码如下:import urllib2import uuidimport pyamffrom pyamf import remotingfrom pyamf.flex import messaging# 构造flex.messaging.messages.RemotingMessage消息msg= messaging.RemotiongMessage(messageId=str(uuid.uuid1()).upper(),\

clometOd=None,\

operation='playeSource',\

destination='metaDataService',\

timeTolive=0,\

timestamp=0

)

msg.body = ['xxx', 'aaaaa', 'ccccc','ddddd', '', 'eeeee', '']

msg.headers['DSEndpoint'] = 'my-amf'msg.headers['DSId'] = str(uuid.uuid1()).upper()# 按AMF协议编码req = remoting.Request('null', body=(msg,))

env = remoting.Envelope(amfVersion=pyamf.AMF3)

env.bodies = [('/1',req)]

data = bytes(remoting.encode(env).read())# 提交请求url = 'http://xxxx.xx.xx/amf'req = urllib2.Request(url,data,headers={'Content-Type':'application/x-amf'})# 解析返回数据oepner = urllib2.build_opener()# 解码AMF协议返回的数据resp = remoting.decode(opener.open(req).read())print resp.bodies[0][1].body.body['xxxx']

......

作者:迷途老鹰

链接:https://www.jianshu.com/p/0f3009021fd9

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值