摘 要 首先介绍了IPTV系统中EPG模块的功能与工作过程;分析了EPG模块开发过程中的菜单状态保持问题。然后针对一个实际的IPTV系统的EPG模块进行分析,参考操作系统中的参数传递机制,提出一种构造状态信息栈来保存EPG菜单状态信息的机制,这个机制能够在一定程度上提高EPG开发速度、降低代码维护代价。
关键词 IPTV; EPG; 参数传递; 状态保持 0 引言 IPTV系统是近几年发展起来的一种基于流媒体技术的网络多媒体服务,使得运营商可以利用宽带IP网向用户提供在线观看影视节目的业务,而IPTV用户通过与机顶盒进行交互即可观看到数量众多、画质清晰的电视节目或电影。1999年英国的Video Networks公司首先向用户提供 IPTV 服务,随后IPTV在世界范围内受到电信运营商的重视。随着 Internet 的普及与技术发展,IPTV业务也在迅速发展,截至到2004年底全球已有超过50家电信运营商推出了IPTV业务,IPTV用户超过100万,中国国家广电总局也于2005年5月向上海文广新闻传媒集团颁发了我国首张IPTV牌照。 EPG系统在实现过程中首要考虑到是否便于用户操作,从这点出发,EPG的设计通常会采用功能模块化与菜单层次化相结合的原则,功能模块化是指相近的功能统一集中在同一个入口处;菜单层次化是指从一个功能入口进入EPG之后进一步向用户展示详细一些的功能选单。例如IPTV系统提供电影、电视和自定义设置三项功能,每个功能下又有细分的功能,那么我们就在EPG首页上提供三个入口:电影、电视、设置,当用户选择电影按钮后EPG又会向用户展示战争片、动画片、喜剧片、影片搜索等详细功能分类,用户可以根据EPG的指示一层一层的选择下去直到找到用户需要的功能。正如用计算机访问网站一样,计算机上的浏览器保存了最近访问过的页面,为我们实现了后退的功能,我们会经常使用这个功能返回到前一个页面以选择相近的功能,但是IPTV系统却不能像计算机上浏览器那样简单的返回到直接的上级菜单,运营商会根据业务需求定义较复杂的返回逻辑,如触发某个事件后返回上n级菜单;理想的EPG系统要实现从某级菜单返回到上一级菜单后仍然恢复成上一级菜单离开时的状态,如光棒位置、用户输入的数据等。但机顶盒不如计算机功能强大,其存储能力有限,浏览器也相对简单,这就要求菜单返回机制与状态保持机制由EPG来实现。下面以某大型IPTV系统为例说明具有状态保持机制的EPG设计思路与实现。1 EPG工作模式 EPG(Electronic Program Guide)是运营商根据业务需求定义的一组与用户交互界面的集合,考虑到 HTML 页面擅长表现文本、静态图片和动画内容,易于制作等特点,目前多数的IPTV工程中都使用 B/S 架构实现EPG功能。EPG工作过程如图1所示,所有的界面都是由 Web 服务器调用 Web 程序动态生成的 HTML 页面,而机顶盒(Set Top Box,简称 STB)充当了浏览器的角色。首先 Web 服务器向用户展示主界面,①用户通过 STB 的遥控器移动EPG界面上的光棒选择界面上的某功能选项,STB将用户的动作反馈给 Web 服务器;②Web 服务器将用户的动作反馈给EPG模块,EPG根据用户的动作进行必要的数据处理(查询数据库、和IPTV系统的其它模块进行沟通等)生成新的EPG页面;③ Web服务器将新EPG页面传送给STB。这样就完成了用户与EPG之间的一次交互。图1 EPG架构图 2 状态保持机制设计2.1 状态保持的必要条件分析 展示给用户的 EPG 菜单实际上是根据运营商业务的需求制作的 web 页面,在实际工程中我们采用 PHP 作为 web 页面开发工具,在最终 HTML 页面中使用 JavaScript 进行动态数据处理和用户动作处理。 用户进入某个 EPG 菜单时首先会向 EPG 系统提供必要的参数,如显示指定电视台的节目单时需要提供电视台的id,按关键词搜索电影需要输入关键词,可能存在翻页的菜单需要提供当前页号等。EPG 根据接收到的参数可以生成基本的EPG菜单了,STB把 web 服务器发送来的 EPG 菜单显示给用户,这时用户有一些行为会影响 EPG 菜单,如通过遥控器移动光棒选择一个选项,然后进入下级菜单,或在输入框中输入一些字符等,如果从当前菜单进入到下一级菜单时,这些状态都是需要保留的,而这些状态都处于 JavaScript 的控制之下。 基于以上分析,我们可以把影响构造菜单的因素分为 PHP 的参数与 JavaScript 动态数据两部分,由于 PHP 的参数解析动作在服务器端完成,我们称 PHP 的参数为 server 端状态;JavaScript的执行动作由 STB 完成,我们称这部分状态为 client 端状态。如果能在进入下一级菜单之前将本级菜单的 server 端状态和 client 端状态都保存起来,待下级菜单返回到本级菜单时再恢复回来就可以达到状态保持的目的了。2.2 状态保持机制的设计 在汇编语言程序设计中,通常函数被调用后首先做的工作是保存一些重要的寄存器的值并保护好调用者使用的堆空间,以便函数结束时能够正确的返回到调用者。当函数调用有多层嵌套时,程序堆空间的使用情况如图2所示,函数1被调用时首先分配一定的空间保存寄存器及其他变量的值;接下来函数2被调用,函数2也分配一定的空间保存环境数据;嵌套函数依次分配属于自己的一段空间,彼此互不干扰。 图2 程序堆空间使用方式示意图 菜单状态保持也可以认为是程序对当前运行时环境的保持,受到汇编语言中函数保存现场机制的启发,EPG各级菜单也可将自己的所有状态信息保存到类似的堆空间里,当各级菜单返回时从堆空间中取出属于自己的那部分数据,这样就实现了状态恢复的功能。3 状态保持机制实现与应用3.1 状态信息堆栈的构造与实现 Web应用程序的开发与运行环境与汇编语言程序的开发与运行有着根本的区别,web程序无法像汇编程序那样操纵自己运行时的内存空间,为了实现菜单状态保持的功能,我们有必要自行构造一个类似的堆栈空间用来保存各级菜单的运行状态。在web开发中有三种数据保存形式:①保存到服务器端的SESSION中;②保存在HTML表单/URL中;③保存在客户端的Cookie中。三种方式各有优劣, 论文检测天使-免费论文检测软件http://www.jiancetianshi.com第一种方式依靠服务器的存储空间,部分无需让客户端知晓的数据就可以不必在网络中传输了;第二种方式会把所有的数据在网络中传来传去,不占用任何一方的存储空间;第三种方式利用客户端的存储空间,服务器端程序对Cookie实施有效管理。考虑到IPTV系统多采用分布式服务器的结构, 论文检测天使-免费论文检测软件http://www.jiancetianshi.com
第一种方式将数据保存在SESSION中会对分布式结构造成一定的障碍,所以尽量不会考虑这种方式。在实际工程中,我们使用HTML表单元素当作堆栈空间用来保存状态信息,形如图3所示:
[8]电大学习网.免费论文网[EB/OL]. /d/file/p/2024/0424/fontbr />多个参数值,参数值也具有很多种类型,其中有可能存在栈分割符“*”或其他一些影响JavaScript正常工作的字符,所以在具体实现时各状态信息需要经过一定编码处理。常见的编码方式有base64编码、QP(Quote-Printable)编码、URL编码方式等,经过分析,对状态信息的编码方式应满足以下条件:①编码之后的结果不会影响到JavaScript正常工作;②编码之后的结果长度尽量短,减轻网络负担;③算法易于服务器端程序和客户端程序实现。在工程中我们使用base64对状态信息进行编码,假设menu1中的状态信息(state1)为: tv_channel_id=20&display_date=20051001,经过base64编码之后状态信息就变成了dHZfY2hhbm5lbF9pZD0yMCZkaXNwbGF5X2RhdGU9MjAwNTEwMDE=。有了状态信息堆栈,我们就可以利用它构造比较复杂的菜单流程了。
[8]电大学习网.免费论文网[EB/OL]. /d/file/p/2024/0424/fontbr />
相关文章:
数字经济时代企业边界突破的逻辑与路径04-26
金融论文:新股发行制度改革对A股上市公司IPO抑价现象04-26
计算机论文:基于深度学习的特定目标情感分类模型探讨04-26
农村基础设施投资是拉动还是挤出了居民消费04-26