微信服务开发——读取百度音乐接口返回音乐

简介:                         最近用了很多网上的坑爹接口,都泪奔了,不说了,都是泪啊~             前两天做了个微信返回音乐的接口,先来看下效果:                          出来之后在手机微信里面就可以实现音乐播放了。



            
           最近用了很多网上的坑爹接口,都泪奔了,不说了,都是泪啊~


            前两天做了个微信返回音乐的接口,先来看下效果:



            


            出来之后在手机微信里面就可以实现音乐播放了。


            技术很简单,首先访问百度音乐接口,传入音乐名称和歌手名称,然后百度会返回一个XML格式给你,里面包括音乐的链接地址等信息。但是比较坑爹的是,这里的链接地址是写在两个node里面的,我要先从一个encode里面拿到前半段,然后再从deconde里面拿到后半段,然后拼起来,拿到URL之后,就要把这个信息放到返回给用户的音乐信息里面。


          先来看下微信里面返回给用户的音乐消息的XML的格式:


         



          其中,MusicUrl跟HQMusicUrl都写成从百度拿到的音乐地址就ok了。对于一般公众号,缩略图是不需要的。

           其实返回给用户的信息是比较坑爹的,除了音乐链接地址是真的,音乐名称和歌手都是根据用户输入的东西显示的。

           当@歌手的时候,上述XML的描述里面写的是就是被@的歌手。


           下面是具体代码:


            先来看看调用百度音乐接口返回的XML里是什么


         如下,红字的部分,为歌曲名称和歌手名称:


            http://box.zhangmen.baidu.com/x?op=12&count=1&title=东风破$$周杰伦$$$$


          调用完成之后,返回XML为:


          

<result><count>1</count><url><encode>http://zhangmenshiting.baidu.com/data2/music/120892918/YmRjbG5ocGlpYKCkaHWvm6CWmHFub5qbaJeWlWponG9lmGVkmWppcGZiaGpomphrYWZqlmhuam9la2uWbG6acWpklJZbo6CcbmJhbGxubm5ha2xka2dpcGcy</encode><decode>120892918.mp3?xcode=99cc7eca52e74f20d42850563da3047b3837498b78c992ab&mid=0.87876099061286</decode><type>8</type><lrcid>29026</lrcid><flag>1</flag></url><durl><encode>http://zhangmenshiting2.baidu.com/data2/music/120892919/YmRjbG5ocGlqYKCkaHWvm6CWmHFub5qbaJeWlWponG9lmGVkmWppcGZiaGpomphrYWZqlm6bb5xhlWiXZ2ybbJJkY5Zbo6CcbmJhbGxubm5ha2xka2dpcGcy</encode><decode>120892919.mp3?xcode=99cc7eca52e74f20d42850563da3047b9e8d0c5c26d4a20b&mid=0.87876099061286</decode><type>8</type><lrcid>29026</lrcid><flag>1</flag></durl><p2p><hash>acf1ed82375d608f50d630248cf3d04a72ec6699</hash><url></url><type>mp3</type><size>7674555</size><bitrate>192</bitrate></p2p></result>

           之后,拿到拼接地址:http://zhangmenshiting.baidu.com/data2/music/120892918/120892918.mp3?xcode=99cc7eca52e74f20d42850563da3047b3837498b78c992ab

           注意,这里要去掉:&mid=0.87876099061286

          

            代码如下:(c#版):

 

 private string strSonger = null; //歌手
        private string strSongName = null; //歌曲名称

        /// <summary>
        /// 获取音乐
        /// </summary>
        /// <param name="strType">服务类型</param>
        /// <param name="strOpenId">用户OpenId</param>
        /// <param name="strWxAccount">公众号</param>
        /// <param name="strParams">传入参数:查询歌曲所用</param>
        /// <param name="strXML">返回的XML</param>
        public void GetMusic(string strType, string strOpenId, string strWxAccount, string strParams, out string strXML)
        {
            strXML = null;

            try
            {
                ComponentServiceMessge comServiceMessage = ComponentServiceMessgeAdapter.Instance.GetUrlByComType(strType);

                if (comServiceMessage == null)  //未找到服务
                {
                    return;
                }
                else //找到服务
                {
                    //发给微信用户
                    strXML = this.ReturnWxMusic(strOpenId, strWxAccount, this.GetMusicFromBaiDu(comServiceMessage.ComponentURL, strParams));
                }

            }
            catch
            {

                strXML = null;
            }

        }

        /// <summary>
        /// 从百度接口拿到音乐信息
        /// </summary>
        /// <param name="strParams">传入的参数</param>
        /// <returns></returns>
        public string GetMusicFromBaiDu(string strUrl, string strParams)
        {
            string strMusicXml = null;

            //拆参数
            int posOne = strParams.IndexOf("@");
            if (posOne >= 0)  //有歌手
            {
                strSongName = strParams.Substring(0, posOne);//歌曲名称
                strSonger = strParams.Substring(posOne + 1, strParams.Length - posOne - 1);//歌手
                strUrl = strUrl + strSongName + "$$" + strSonger + "$$$$";
                strMusicXml = base.RequestMyWebClient(EnumSubmitMethod.Get, "", strUrl);
            }
            else//只有歌曲的名称
            {
                strSongName = strParams;
                strUrl = strUrl + strParams + "$$";
                strMusicXml = base.RequestMyWebClient(EnumSubmitMethod.Get, "", strUrl);
            }

            return strMusicXml;

        }

        /// <summary>
        /// 得到发给微信的XML
        /// </summary>
        /// <param name="strXml">传入从百度拿到的XML</param>
        /// <returns></returns>
        private string ReturnWxMusic(string strOpenId, string strWxAccount, string strXml)
        {
           string strWxMusicXml = null;
            //拼入,返回给微信用户
            strWxMusicXml = string.Format(@"<xml>
                        <ToUserName><![CDATA[{0}]]></ToUserName>
                        <FromUserName><![CDATA[{1}]]></FromUserName>
                        <CreateTime>{2}</CreateTime>
                        <MsgType><![CDATA[music]]></MsgType>
                        <Music>
                        <Title><![CDATA[{3}]]></Title>
                        <Description><![CDATA[{4}]]></Description>
                        <MusicUrl><![CDATA[{5}]]></MusicUrl>
                        <HQMusicUrl><![CDATA[{6}]]></HQMusicUrl>
                        </Music>
                        </xml>", strOpenId, strWxAccount, this.DateTimeToStamp(DateTime.Now).ToString(), strSongName, strSonger, this.GetMusicUrl(strXml), this.GetMusicUrl(strXml));

            return strWxMusicXml;
        }

        /// <summary>
        /// 获取百度音乐链接的URL地址
        /// </summary>
        /// <param name="strXml">访问百度音乐得到的XML</param>
        /// <returns></returns>
        private string GetMusicUrl(string strXml)
        {
            
            string strMusicUrl = null;
            //读取xml
            XDocument doc = XDocument.Parse(strXml);
            XElement RootEle = doc.Root;          
            List<XElement> XEleColl = RootEle.Elements().ToList();
            strMusicUrl = HttpUtility.UrlDecode(XEleColl.ElementAt(1).Element("encode").Value);

            //拼接地址:取前面的一段地址+decode节点地址
            int posFlag = strMusicUrl.LastIndexOf("/");
            strMusicUrl = strMusicUrl.Substring(0, posFlag + 1);
            string strValue = XEleColl.ElementAt(1).Element("decode").Value;
            strValue = strValue.Substring(0, strValue.IndexOf("&"));
            strMusicUrl += strValue;//加上后一段地址
            return strMusicUrl;
        }


        /// <summary>
        /// DateTime时间格式转换为Unix时间戳格式
        /// </summary>
        /// <param name="time"></param>
        /// <returns></returns>
        private int DateTimeToStamp(System.DateTime time)
        {
            System.DateTime startTime = TimeZone.CurrentTimeZone.ToLocalTime(new System.DateTime(1970, 1, 1));
            return (int)(time - startTime).TotalSeconds;
        }

           

            

             接着,在配置的服务器地址

     

            

                 中的处理用户消息页面做出对音乐消息的处理,然后服务器处理后将音乐消息返给用户。



               






         

        

目录
相关文章
|
3月前
|
人工智能 JavaScript 定位技术
微信的接口都有哪些?
【10月更文挑战第17天】微信的接口都有哪些?
236 43
|
3月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
771 7
|
3月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
783 1
|
3月前
|
JSON 小程序 应用服务中间件
微信的接口wxLogin()的返回值都有什么?
【10月更文挑战第4天】微信的接口wxLogin()的返回值都有什么?
348 1
|
3月前
|
JSON 前端开发 API
使用微信JS-SDK调用发票接口的完整开发指南
本文介绍了如何使用微信JS-SDK的`chooseInvoiceTitle`接口来调用微信的发票功能。通过微信发票接口,用户可以选择开具个人或单位发票,并获取相关发票信息,如抬头、税号、公司地址等。在文中,详细描述了JS-SDK的初始化、发票接口的调用方式,并提供了完整的代码示例。文章还介绍了如何处理返回的发票信息,帮助开发者快速集成微信发票功能。
99 2
|
3月前
|
缓存 小程序 索引
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
267 1
|
3月前
|
小程序 前端开发 数据安全/隐私保护
微信小程序全栈开发中的身份认证与授权机制
【10月更文挑战第3天】随着移动互联网的发展,微信小程序凭借便捷的用户体验和强大的社交传播能力,成为企业拓展业务的新渠道。本文探讨了小程序全栈开发中的身份认证与授权机制,包括手机号码验证、微信登录、第三方登录及角色权限控制等方法,并强调了安全性、用户体验和合规性的重要性,帮助开发者更好地理解和应用这一关键技术。
99 5
|
3月前
|
小程序 前端开发 JavaScript
微信小程序全栈开发中的PWA技术应用
【10月更文挑战第3天】微信小程序作为新兴应用形态,凭借便捷体验与社交传播能力,成为企业拓展业务的新渠道。本文探讨了微信小程序全栈开发中的PWA技术应用,包括离线访问、后台运行、桌面图标及原生体验等方面,助力开发者提升小程序性能与用户体验。PWA技术在不同平台的兼容性、性能优化及用户体验是实践中需注意的关键点。
78 5
|
3月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
1228 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
|
3月前
|
存储 小程序 安全
微信的开发管理都需要配置什么?
【10月更文挑战第17天】微信的开发管理都需要配置什么?
40 0