最近做网站的时候遇到一个需求:给定一个视频地址,获取它的swf地址。例如,给一个优酷的视频地址:http://v.youku.com /v_show/id_XNDg4MzY5ODU2.html,想获取它的swf文件的地址,通常情况我们是通过爬取网页的方式来获取相关标签内的值,可 是这种方法有很多不便,效率不高,准确度不能得到保证,不同的网站筛选的方法也不一样,有的网站的flash地址是用js动态生成的(例如爱奇艺),这时 候通过爬取网页就得不到想要的结果了。
今天突然想到新浪微博支持在发微博的时候直接插入视频地址,就想看看新浪是怎么做的。于是试着发一条带视频的微博,此时页面上并没有视频的真实地址,而是一张与视频相关的图片
点击图片,出现了视频播放器。
使用谷歌浏览器的开发人员工具查看,原来新浪是通过它自己的api来实现这一功能的。
我们只需要关心short_url这个参数就行了,它就是视频的长网址转换后的短网址。
这里给个长网址转短网址的api:http://weibo.com/aj/mblog/video?_wv=5&url=http%3A%2F%2Fv.youku.com%2Fv_show%2Fid_XNDg1MDkzODcy.html
url参数换成你需要转换的网址就行了。
返回结果:
{"code":"100000","msg":"","data":{"url":"http:\/\/t.cn\/zjxngLP","title":null}} |
另外加上jsonp=STK这个参数,返回的结果是html,不加这个参数返回的是json格式的数据。
来看看结果吧
<!-- 加jsonp=STK参数 --> <html>
<head></head>
<body>
try{STK({"result":"
<div>
<div>
<embed id="\"STK\"" height="\"356\"" allowscriptaccess="\"never\"" style="\"visibility:" visible;\"="" pluginspage="\"http://get.adobe.com/cn/flashplayer/\"" flashvars="\"playMovie=true&auto=1\"" width="\"440\"" allowfullscreen="\"true\"" quality="\"high\"" src="\"http://player.ku6.com/refer/uLsWSvMRa4YaFaeNBlo04Q../v.swf\"" type="\"application/x-shockwave-flash\"" wmode="\"transparent\"/" />
</div>
</div>"});}catch(e){}
</body>
</html>
<!-- 不加参数,返回的是json格式 {"result":"<div><div><embed id=\"\" height=\"356\" allowscriptaccess=\"never\" style=\"visibility: visible;\" pluginspage=\"http://get.adobe.com/cn/flashplayer/\" flashvars=\"playMovie=true&auto=1\" width=\"440\" allowfullscreen=\"true\" quality=\"high\" src=\"http://player.ku6.com/refer/uLsWSvMRa4YaFaeNBlo04Q../v.swf\" type=\"application/x-shockwave-flash\" wmode=\"transparent\"/></div></div>"}
可以看到返回结果中的src正是我们想要的内容。