在没有自己的音乐搜索引擎的时候,却又想让用户可以较为方便的在自己的网站上搜索网络歌曲,在这里使用的是百度的MP3~

换成以前也许很简单,直接抓取网页就可以获取了网络音乐的实际URL。而现在不行了,搜索出来结果后,需要再次点击请求后台生成一个地址,然后那个页面才有真实MP3的URL地址。我使用的方法可能较为被动,如果百度MP3一些规则一旦改动,下面的代码就跑不起来了(在保持现在规则不变的情况下,看上去还是很完美的)

目前我做的是,只搜索第一页的音乐,如果你想实现与百度一致的翻页,可能还需要再花点时间了(不过应该会很简单了)

首先,我使用的开发环境:

操作系统:xp sp3

web服务器:nginx

flash开发IDE:flashDevelop

网页开发工具:Editplus

思路:

网页获取keyword -->传递给flash –> flash通过nginx反向代理请求百度mp3首页的网页内容 –> 回传给javascript

用户点击“试听”听 –> 将百度MP3首页的临时地址传给flash重新再请求一次(也采用nginx的反向代理) –> 获取最终真实地址的网页内容-->回传给javascript -->脚本通过解码函数再得真实的播放地址。

需要注意项:

1、百度的MP3请求地址,做了防盗链,在flash的http请求头里面需要设置host <ip地址>、清空referer、设置不缓存页面(每次重新请求),nginx代码大致如下:

proxy_set_header host '220.181.38.82';
proxy_set_header referer '';

add_header Cache-Control 'no-store, no-cache, must-revalidate, post-check=0, pre-check=0';

add_header Pragma no-cache;

proxy_pass http://220.181.38.82;

2、需要在服务器(本地)放置crossdomain.xml文件(因为flash的安全策略,请求资源时它会请求当前根目录下的crossdomain.xml文件,不符合规则将报安全沙箱错误)

下面测试一下,到底下面的方法得到的真实的URL是否正确:

注意它百度跳到指定的一个IP上,而不是域名,如果nginx里设置域名也是不行的,一定要用IP。

从两张图的对比来看,试验的页面是可以获得百度MP3的真实的网络地址, 项目测试成功。

nginx配置:

 #VHOST: meteoric.comserver {listen 80;server_name meteoric.comcharset utf-8;access_log off;ssi on;ssi_silent_errors on;location / {root C:\phpApp;          index index.html index.php;}location /crossdomain.xml {alias C:/phpApp/searchMusic/crossdomain.xml;}location ~ ^/baidu(/?) {rewrite .* http://www.baidu.com/ redirect;}location ~ ^/m$ {proxy_set_header host '220.181.43.121';proxy_set_header referer '';proxy_pass  http://mp3.baidu.com;}location ~ ^(.+\.php)(.*)$ {root C:\phpApp;fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;include php.conf;}}#VHOST: meteoric2.comserver {listen       80;server_name  meteoric2.com;charset       utf-8;location /crossdomain.xml {alias C:/phpApp/searchMusic/crossdomain.xml;}location ~ ^/m$ {proxy_set_header host '220.181.38.82';proxy_set_header referer '';add_header Cache-Control 'no-store, no-cache, must-revalidate, post-check=0, pre-check=0';add_header Pragma no-cache;proxy_pass http://220.181.38.82;}}

解析百度MP3首页音乐列表脚本:

if (/<div(?:\s+)id=\"songResults\"[^>]+\>[\n\s]*(<table[\S\s]*?\<\/table\>)/.test(_data)) {var table_str = RegExp['$1'];var tr_reg = /(<tr[^>]*>[\S\s]+?<\/tr>)/;var tr_str = "";musicList = [];while (tr_reg.test(table_str)) {tr_str = RegExp['$1'];table_str = table_str.replace(tr_str, "");if (/<td/.test(tr_str)) {musicList.push({'tmpurl' : /<td(?:\s+)class=\"second\">[^<]*<a(?:\s+)href=\"([^\"]+)/.test(tr_str) ? RegExp['$1'] : "",'name' : /<td(?:\s+)class=\"second\">[^>]+>([^<]+)/.test(tr_str) ? RegExp['$1'] : "",'singer' : /<td(?:\s+)class=\"third\">[^>]+>[^>]+>([^<]+)/.test(tr_str) ? RegExp['$1'] : "",'relurl' : null,'size' : /<td(?:\s+)class=\"seventh\">([^<]+)/.test(tr_str) ? RegExp['$1'] : "",'speed' : /<td(?:\s+)class=\"ninth\">[^>]+>(\d)</.test(tr_str) ? RegExp['$1']*1+1 : ""});                }}          }

解析网络音乐真实URL的核心方法:

parseMusicURL : function(data) {if(data) {/var encurl\s*=\s*\"([^\"]*)\"\s*\|\|\s+\"([^\"]*)\"/.test(data);var encurl = RegExp['$1'] || RegExp['$2'];/var song_(\d+)/.test(data);var sertim = RegExp['$1'];if(sertim && encurl) {return this.decodeMusicURL(sertim, encurl);} else {return null;}} else {return null;}},decodeMusicURL : function(_rId, _url) {var sertim = parseInt(_rId, 10);var url = _url;var len = url.length;var decurl = "";var asc_arr1 = [], asc_arr2 = [];var key = sertim % 26;key = key ? key : 1;function init(head, bottom, middle){for (var i = head; i <= bottom; i++) {asc_arr1[i] = i + middle;asc_arr2[i + middle] = i;}}init(0, 9, 48);init(10, 35, 55);init(36, 61, 61);for (var i = 0; i < len; i++) {var word = url.charAt(i);if (/[A-Za-z0-9]/.test(word)) {var pos = asc_arr2[url.charCodeAt(i)] - key;if (pos < 0)pos += 62;word = String.fromCharCode(asc_arr1[pos]);}decurl += word;}return decurl;        }

代理请求的Flash代码:

package
{import flash.display.Sprite;import flash.events.Event;import flash.events.IOErrorEvent;import flash.external.ExternalInterface;import flash.net.URLLoader;import flash.net.URLRequest;import flash.net.URLRequestMethod;import flash.system.System;/*** ...* @author ZhangYi*/public class Main extends Sprite {private static var CallBack_Fun:String;public function Main():void {if (stage) {init();} else {addEventListener(Event.ADDED_TO_STAGE, init);}}private function init(e:Event = null):void {removeEventListener(Event.ADDED_TO_STAGE, init);inited();}private function inited():void {if (ExternalInterface.available) {ExternalInterface.addCallback("loadURL", loadURL);}  System.useCodePage = true;var params:Object = root.loaderInfo.parameters;if (params.initCallback) {ExternalInterface.call(params.initCallback);}}/*** 请求指定的地址,获取数据后返回* * @param   _url* @param   _callback* @param  method*/public function loadURL(_url:String, _callback:String = "", method:String = "get"):void {var req:URLRequest = new URLRequest(_url);req.method = method == "get" ? URLRequestMethod.GET : "POST";var loader:URLLoader = new URLLoader();loader.addEventListener(Event.COMPLETE, onCompleteHandler);loader.addEventListener(IOErrorEvent.IO_ERROR, ioErrorHandler);CallBack_Fun = _callback;loader.load(req);}/*** 数据加载完成* @param    evt*/private function onCompleteHandler(evt:Event):void {var loader:URLLoader = evt.target as URLLoader;ExternalInterface.call(CallBack_Fun, loader.data);}/*** 请求时发生IO错误* @param evt*/private function ioErrorHandler(evt:IOErrorEvent):void {ExternalInterface.call(CallBack_Fun, null, evt.text);}}}

实际运行请求的效果示意图:

获取音乐列表的请求<也就是百度MP3首页的字符--网页源代码>:

请求网络音乐的真实URL时,网页内有一个javascript解码函数:

除nginx外,其它源码(html、css、flash)都将上传打包。不一定非得用nginx,你也可以使用apache,只是我的开发环境中经常用。

↓下载示例

使用nginx反向代理获取百度MP3的真实网址相关推荐

  1. nginx反向代理获取用户真实ip

    nginx做反向代理时,默认的配置后端获取到的ip都是来自于nginx,如何转发用户的真实ip到后端程序呢?如是是java后端,用request.getRemoteAddr();获取到的是nginx的 ...

  2. JAVA中经过nginx反向代理获取客户端ip并获取相关坐标等信息

    关于搜狐新浪ip库查询接口的使用 直接输出访客ip及所在城市: <script src="http://pv.sohu.com/cityjson?ie=utf-8" > ...

  3. nginx多层反向代理获取客户端真实ip

    访问路径: 用户 --> www.chinasoft.cn(nginx反向代理) --> www.chinasoft.com(nginx反向代理) --> python服务端程序经过 ...

  4. uni-app——一种通过Nginx反向代理处理302重定向请求解决网络请求中无法获取Cookie的解决方案

    问题描述 小程序中不会自动保存和发送Cookie 使用插件(https://uniapp.dcloud.io/api/request/request)方法不能解决302重定向情况下获取Cookie 小 ...

  5. nginx反向代理下thinkphp、php获取不到正确的外网ip

    nginx反向代理下thinkphp.php获取不到正确的外网ip 在记录用户发送短信需要获取用户ip时,tp一直获取的是内网ip:10.10.10.10 tp框架获取ip方法:get_client_ ...

  6. [转]nginx反向代理网站(网易、百度之类的)

    使用nginx反向代理百度之类的网站和反向代理自己发布的服务设置上有点差别,因为此差别费时良久,故记录在此. 使用include 配置文件方式, 首先在 nginx.conf文件的 http 中 加入 ...

  7. Nginx反向代理导致PHP获取不到正确的HTTP_HOST,SERVER_NAME,客户端IP的解决方法

    Nginx反向代理导致PHP获取不到正确的HTTP_HOST,SERVER_NAME,客户端IP的解决方法 参考文章: (1)Nginx反向代理导致PHP获取不到正确的HTTP_HOST,SERVER ...

  8. nginx - 反向代理百度 403

    nginx - 反向代理百度 403 location /bd/ {port_in_redirect on;proxy_pass http://www.baidu.com/;proxy_redirec ...

  9. Nginx反向代理,负载均衡,redis session共享,keepalived高可用

    本站点停止更新,请访问:blog.coocap.com 相关知识自行搜索,直接上干货... 使用的资源: nginx主服务器一台,nginx备服务器一台,使用keepalived进行宕机切换. tom ...

  10. Nginx反向代理相关事宜

    第一章:Nginx概述 1.1.Nginx概述 Nginx("engine x")是一个高性能的HTTP和反向代理服务器,特点是占有内存少,并发能力强,事实上Nginx的并发能力确 ...

最新文章

  1. 狄利克雷卷积莫比乌斯反演证明
  2. 在IBatisNet中使用存储过程
  3. 解决webpack打包vue项目后,部署完成后,刷新页面页面404
  4. 【移动通信】移动通信基础
  5. 不好意思,我真的不知道MySQL的窗口函数...
  6. 薛老师软考高项学员:2016年4月6日作业
  7. 小强的HTML5移动开发之路(51)——jquerymobile中改善页面访问速度
  8. 大学计算机实验vfp,Visual FoxPro程序设计上机实验(第2版)
  9. Android Studio Gradle下载慢解决方法
  10. PHP基础PPT课件,《php基础》PPT课件.ppt
  11. 《未来行业前景必看》大数据未来的发展趋势!
  12. matlab f检验 f值,excel检验【Excel回归分析中的F检验】
  13. 三种常见的建筑企业并购方案
  14. 【技术】SQL动态排序?
  15. H263H264MPEG4
  16. Matlab绘图-很详细,很全面
  17. Apollo简单介绍
  18. 项目管理软件之争,禅道和JIRA大对比
  19. Discuz去掉标题上的powered by discuz!
  20. 一款非常好用的图片无损放大工具:Topaz Gigapixel AI

热门文章

  1. Ubuntu 16.04的k8s安装配置
  2. idea中 Application Server not specified
  3. mysql 优化 (1)
  4. BootStrap 模态框禁用空白处点击关闭,手动显示隐藏,垂直居中
  5. php5.3 appache phpstudy win7win8win10下 运行速度慢
  6. mysql 1067
  7. jQuery左侧图片右侧文字滑动切换代码
  8. NOIP201103瑞士轮【B002】
  9. @retention注解作用_前端初学SpringBoot系列(三)自定义注解的学习与练习
  10. Hindex--华为Hbase二级索引