基于微信的【点歌台】功能开发

2014-08-05 19:42:09

微网站,微社区,微店铺……现在是实打实的微时代啊。据我观测,随着移动互联时代的推进,web app将会走红,人们习惯于APP的操作界面,又不喜欢安装各种APP,所以基于云端的web app势必要走红,而微信的火热恰好为微网站提供了大显身手的舞台~废话太多了,进入主题吧,好久没写时间写博客了。

思路是用户提交关键字后,利用百度音乐API取出音乐地址,然后以音乐的格式返回。

百度API:http://box.zhangmen.baidu.com/x?op=12&count=1&title=小苹果$$筷子兄弟$$$$

可见API中需要提交音乐名称和歌手名字,而且歌手名字需要准确。像我这种只听歌,不记歌手的人来说,这接口基本算是废了。怎么办?easy,我的思路是先到比较大的音乐站点,提交歌名,然后抓取到返回结果中第一首歌的歌手名,其实一般大家熟知的歌,在搜索结果中排名都是第一位的。所以这样返回的歌手基本上90%就是你所需要的。

既然有了思路就开工呗,先喵一个音乐网站被,我就选酷我了,登陆酷我首页,提交关键字“小苹果”,得到返回结果,用chrome工具分析post数据,可以看到提交的url为:

http://sou.kuwo.cn/ws/NSearch?type=all&key=%E5%B0%8F%E8%8B%B9%E6%9E%9C

用urldecode反编码即为:http://sou.kuwo.cn/ws/NSearch?type=all&key=小苹果

可以看到搜索结果的前五首都是筷子兄弟,所以准确率还是可以的,然后就是抓取这个搜索页面,分析网页,正则匹配出我们所需的第一首歌的歌手,这个我就不多说了,正则是个耐心活,自己慢慢匹吧~

现在我们已经内容那个通过歌名获取到歌手名字了,接下来解释post百度API了,返回XML形式的数据:

[php]



1








  
 [/php]

这里第一个encode返回的url并不是MP3的真实地址,而是encode的url去掉最后一串字符串然后加上decode的url,就是他的低品质MP3地址,本例就是http://zhangmenshiting.baidu.com/data2/music/121184680/121184680.mp3?xcode=b654da32ccc419077410c7bfda5a20a010eb0c361f219299&mid=0.69760662308426

第二个encode和decode合并出来的是高品质的MP3地址。

XML中还包含歌词信息,取出25467标签中的数字,歌词地址就是http://box.zhangmen.baidu.com/bdlrc/254/25467.lrc,相信聪明的大家已经明白了算法,就是http://box.zhangmen.baidu.com/bdlrc/【数字/100取整】/数字,然当然这个是额为的话题了。

知道了真实链接的获取方法,剩下的就是用正则匹配处理了,然后与微信返回音乐的格式相结合就OK了。

微信返回音乐的格式:

[php]

  
   
   
 12345678  
   
   
 <![CDATA[TITLE]]>  
   
   
   
   
   
 

[/php]

最后将整个流程封装成一个类(最经发现有点强迫症心里,写的方法不封装就心里不爽= =),截个图供参考,想要代码自己照着敲吧~鄙视伸手党,哈哈~

QQ图片20140805232940调用方法很简单,实例化后直接传入参数:

[php]

$music = new MusicUrl();
$key = strreplace("音乐","",$key);
$contents = $music -> get
musicurl($key);
$content = array();
$content[] = array(
"Title"=>$contents[‘Title’]."—".$contents[‘Description’],
"Description"=>$contents[‘Description’],
"PicUrl"=>"http://attach.bbs.miui.com/forum/201106/23/2102102z5ajpqgd2hwjn20.jpg",
"Url" =>"http://1.wesae.sinaapp.com/play.php?title=".$contents[‘Title’]."&description=".$contents[‘Description’]."&musicurl=".$contents[‘MusicUrl’]
);

[/php]

如果想用微信自带浏览器播放的话,介绍一款js播放器:audio.js,方便调用,可以试试。

最终效果图如下:

QQ图片20140805233748大家可以关注服务号【bistu】查看,有问题欢迎留言探讨~

qrcode<em>for</em>gh<em>0098f95b28a8</em>430 (2)

Undefined property: Index::$load

I just started to develop a new site with CI.  For now, I only have three view files loaded on my index pages which are made strictly with HTML.  When I visit the index page, I get the following error: *A PHP Error was encountered * *Severity: Notice * *Message: Undefined property:

Bistu Library API

北京信息科技大学图书馆API。(PHP语言实现) 思路: 1.post数据,分析网页url。 2.加壳。 说说大概过程,首先登陆图书馆主页,进入图书检索页面: http://211.68.37.131/book/queryIn.jsp 提交查询数据,用chrome或Firefox等开发工具抓取到post数据包,分析之,如本校图书检索,提交检索词之后跳到新页面(http://211.68.37.131/book/queryOut.jsp)。表面上看不出post地址,抓包也看不出提交地址: 但区区方正系统怎么能难倒聪明的大家呢,对搜索结果的页面: (http://211.68.37.131/book/queryOut.jsp)分析,不难发现,search result实则是iframe框架: iframe src=