具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(Personal Digital Assistant,PDA)、便捷式媒体播放器(Portable Media Player,PMP)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字TV、台式计算机等固定终端。
后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:RF(Radio Frequency,射频)单元101、WiFi模块102、音频输出单元103、A/V(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图1对移动终端的各个部件进行具体的介绍:
射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯系统)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA2000(CodeDivision Multiple Access 2000,码分多址2000)、WCDMA(Wideband Code DivisionMultiple Access,宽带码分多址)、TD-SCDMA(Time Division Synchronous CodeDivision Multiple Access,时分同步码分多址)、FDD-LTE(Frequency DivisionDuplexing-Long Term Evolution,频分双工长期演进)和TDD-LTE(Time DivisionDuplexing-Long Term Evolution,分时双工长期演进)等。
WiFi属于短距离无线传输技术,移动终端通过WiFi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了WiFi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或WiFi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。
A/V输入单元104用于接收音频或视频信号。A/V输入单元104可以包括图形处理器(Graphics Processing Unit,GPU)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或WiFi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板1061。
用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。
进一步的,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。
接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络系统进行描述。
请参阅图2,图2为本发明实施例提供的一种通信网络系统架构图,该通信网络系统为通用移动通信技术的LTE系统,该LTE系统包括依次通讯连接的UE(User Equipment,用户设备)201,E-UTRAN(Evolved UMTS Terrestrial Radio Access Network,演进式UMTS陆地无线接入网)202,EPC(Evolved Packet Core,演进式分组核心网)203和运营商的IP业务204。
具体地,UE201可以是上述终端100,此处不再赘述。
E-UTRAN202包括eNodeB2021和其它eNodeB2022等。其中,eNodeB2021可以通过回程(backhaul)(例如X2接口)与其它eNodeB2022连接,eNodeB2021连接到EPC203,eNodeB2021可以提供UE201到EPC203的接入。
EPC203可以包括MME(Mobility Management Entity,移动性管理实体)2031,HSS(Home Subscriber Server,归属用户服务器)2032,其它MME2033,SGW(Serving Gate Way,服务网关)2034,PGW(PDN Gate Way,分组数据网络网关)2035和PCRF(Policy andCharging Rules Function,政策和资费功能实体)2036等。其中,MME2031是处理UE201和EPC203之间信令的控制节点,提供承载和连接管理。HSS2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过SGW2034进行发送,PGW2035可以提供UE 201的IP地址分配以及其它功能,PCRF2036是业务数据流和IP承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。
IP业务204可以包括因特网、内联网、IMS(IP Multimedia Subsystem,IP多媒体子系统)或其它IP业务等。
虽然上述以LTE系统为例进行了介绍,但本领域技术人员应当知晓,本发明不仅仅适用于LTE系统,也可以适用于其他无线通信系统,例如GSM、CDMA2000、WCDMA、TD-SCDMA以及未来新的网络系统等,此处不做限定。
此外,还应当理解,现有的信息流转码方式虽然包括服务端转码和本地转码两种方式,但是服务端转码会牵扯到资讯的版权问题,而本地转码就不会牵扯到版权问题,因此,一般采用本地转码的方式进行信息流转码。
现有的本地转码方式,不仅信息流转码的效率较低,还存在以下几点缺陷:
1、在信息流转码成功,就直接返回一个成功后的网页okURL;如果转码失败,就直接返回原始网页srcURL,这种情况下,就会导致同一个资讯,在浏览器上会有两种表现形式,用户查看时难以区分,从而降低用户的体验。
2、本地转码不能重复性转码,一旦浏览器加载了一个资讯的okURL1,如果再次加载另外一个资讯的okURL2,那么之前转码的okURL1的内容就会被清除掉,并且用户难以通过刷新按钮来重新加载该网页,若是想要加载之前的网页,需要重新获取信息流,并对网页解析,再根据本地模板将网页内容重组成一个本地的网页。显然,这种信息流的加载方式不仅花费时间长,还耗费资源。
基于上述终端硬件结构以及通信网络系统,以及现有技术存在的问题,提出本发明信息流转码装置的各个实施例。
参照图3,图3为本发明信息流转码装置第一实施例的模块示意图。
本实施例中的所述终端即图1中所述的移动终端。
需要强调的是,对本领域的技术人员来说,图3所示模块图仅仅是一个较佳实施例的示例图,本领域的技术人员围绕图3所示的信息流转码装置的模块,可轻易进行新的模块的补充;各模块的名称是自定义名称,仅用于辅助理解该信息流转码装置的各个程序功能块,不用于限定本发明的技术方案,本发明技术方案的核心是,各自定义名称的模块所要达成的功能。
在本实施例中,所述信息流转码装置应用于终端,所述终端设置有转码中间件,所述信息流转码装置包括:
获取模块10,用于获取信息流;
转码模块20,用于采用转码中间件对获取的所述信息流进行转码,以得到转码统一资源定位符URL;
传送跳转模块30,用于将转码URL传给浏览器的网页视图以加载空网页,并在所述浏览器跳转至空网页界面;
调用加载模块40,用于调用所述转码中间件解析所述转码URL以进行网页转码,并加载相应的网页转码结果至浏览器的空网页界面。
在本实施例中,所述信息流转码装置应用于终端,所述终端的浏览器中设置有转码中间件,所述转码中间件可以是以程序的形式加载至所述终端的浏览器中;也可以是以芯片的形式嵌入到所述终端中,以供终端在浏览器中调用所述芯片中的转码中间件。
在本实施例中,需要说明的是,所述转码中间件是整个信息流转码过程的核心,所述转码中间件包含有转码协议转码器和内嵌框架Iframe。其中,所述转码协议代码器用于把信息流转换成transcode(转码)URL(Uniform Resource Locator,统一资源定位符),并且,还可用于从transcodeURL中解析出信息流的相关参数。
本实施例中,所述transcodeURL映射的是一个本地的空网页,所述空网页的具体格式如下:
其中,子网页是指位于网页的预设区域的网页,例如,在浏览器中打开百度,百度的页面就是网页,而在百度所在页面的预设区域,如左上角区域显示的网页如新浪的广告网页,就是子网页。
本实施例中,所述transcodeURL中包含量转码所需要的所有参数,如信息流的抓取时间、信息流的名称name等等。所述浏览器的网页包含有Iframe标签(该标签支持加载子网页,满足html规范)。所述内嵌框架Iframe用于加载“转码引擎”转码后的网页,可能是okURL(转码成功的网页),也可能是srcURL(转码失败的网页),需要注意的是,虽然Iframe加载的网页可能是okURL或是srcURL,但是这两种表现形式仅仅对终端内部而言,对外的表现形式统一为transcodeURL。
以下介绍本实施例中实现信息流转码的各个模块的具体功能:
其中,所述获取模块10,用于获取信息流;
所述转码模块20,用于采用转码中间件对获取的所述信息流进行转码,以得到转码统一资源定位符URL;
在本实施例中,获取模块10在浏览器中获取服务端传输的信息流,在获取信息流之后,转码模块20采用预置的转码中间件,对获取的所述信息流进行转码,以得到转码URL。
前面已经提到,所述转码中间件包含转码协议转码器,因此所述转码模块20,还用于采用所述转码中间件的转码协议转码器,对获取的所述信息流进行转码,以得到转码URL。
即本实施例中,在进行信息流转码之前,转码模块20采用所述转码中间件的转码协议转码器,对获取的所述信息流进行转码,具体地,提取所述信息流中的参数信息,然后将提取的参数信息转码成转码URL,即transcodeURL,本发明实施例中的转码URL与transcodeURL是同一个对象,下文不再强调。应当理解,在后续的本地信息流转码过程中,都是基于该transcodeURL进行转码。
其中,所述传送跳转模块30,用于将转码URL传给浏览器的网页视图以加载空网页,并在所述浏览器跳转至空网页界面;
在转码模块20采用转码中间件中的转码协议转码器对信息流转码,并得到转码URL之后,传送跳转模块30将所述转码URL传给浏览器的网页视图(WebView)以加载空网页,也就是说,在浏览器中,网页的加载都是由WebView来渲染。
需要说明的是,在WebView渲染一个网页时会触发一系列的网页生命周期,该网页生命周期从网页开始加载到网页完成加载,其中,onPageStart表示网页开始加载,onPageEnd表示网页完成加载。
当网页视图加载空网页的时候,传送跳转模块30在浏览器中跳转至空网页界面。
其中,所述调用加载模块40,用于调用所述转码中间件解析所述转码URL以进行网页转码,并加载相应的网页转码结果至浏览器的空网页界面。
在本实施例中,当WebView加载转码URL的时候,为了保证尽早触发转码过程,在网页开始加载的时候,调用加载模块40就会立刻触发网页转码,然后调用转码中间件进行转码URL的解析,以进行网页的转码。
需要说明的是,不管是刷新网页还是加载新的网页,都会走onPageStart至onPageEnd的周期,由于transcodeURL中包含了转码所需要的参数,因此在转码过程中,只要从transcodeURL中解析出所需要的参数即可,实现了转码可以重复进行。
本实施例提出的技术方案,对信息流的转码,是由终端先获取信息流,然后采用转码中间件对获取的所述信息流进行转码,以得到转码统一资源定位符URL,再将转码URL传给浏览器的网页视图以加载空网页,并在所述浏览器跳转至空网页界面,最终调用所述转码中间件解析所述转码URL以进行网页转码,并加载相应的网页转码结果至浏览器的空网页界面。本发明对空网页的加载,是在转码中间件对信息流进行转码的过程就已经加载完成,后续直接将转码结果加载至空网页界面即可,无需再花费时间等待页面的加载,提高了信息流转码的效率。
进一步地,提出本发明信息流转码装置的第二实施例。
信息流转码装置的第二实施例与信息流转码装置的第一实施例的区别在于,参照图4,所述调用加载模块40包括:
调用单元41,用于调用所述转码中间件对所述转码URL进行解析,解析出转码需要的参数;
转码单元42,用于根据解析出的参数进行网页转码;
加载单元43,用于将网页转码结果加载至浏览器的空网页界面。
本发明实施例中,将转码URL传给浏览器的网页视图以加载空网页,并在所述浏览器跳转至空网页界面之后,调用单元41先调用转码中间件对转码URL进行解析,以解析出转码需要的参数,也就是说,由转码中间件对WebView加载的URL进行解析处理,解析出相关的参数param。之后,转码单元42再根据转码中间件解析出的参数进行网页的转码,具体地:
所述转码单元42,还用于调用转码引擎,并将解析出的参数发送至所述转码引擎,由所述解码引擎基于所述参数进行网页转码,其中,所述转码引擎使用第三方框架对所述参数进行转码。
即,在本发明实施例中,调用单元41调用转码中间件对转码URL进行解析,得到转码需要的参数之后,再调用转码引擎,然后转码单元42将转码中间件解析出的参数发送至所述转码引擎,具体地,通过转码中间件发送解码需要的参数给所述转码引擎,再由所述转码引擎基于所述参数进行网页转码。即,本发明实施例的转码引擎具有网页转码的功能。
本实施例中,转码引擎基于参数进行网页转码的方式优选为:采用第三方框架对所述参数进行转码,以得到信息流对应的网页转码结果,其中,所述转码结果包括两种:当转码成功后返回okURL;当转码失败后返回原始网页srcURL。
本实施例中,信息流转码失败的情况包括以下几种:信息流不在本地清单中、网页结构发生变化等情况,在转码引擎获取到转码需要的参数时,对参数进行分析查看,以确定参数是否满足上述几种情况,若满足,则认为转码失败,此时返回原始网页srcURL,若参数不满足上述几种情况,则认为转码成功,并返回okURL。
当转码引擎基于参数对网页进行转码,得到转码结果时,所述转码引擎可以将转码结果反馈至终端的转码中间件。最终,加载单元43将网页转码结果加载至浏览器的空网页界面。
在本实施例中,采用转码中间件对转码URL进行转码,实际上是调用转码引擎对转码URL中的参数进行转码,最终得到相应的转码结果。
进一步地,提出本发明信息流转码装置的第三实施例。
信息流转码装置的第三实施例与信息流转码装置的第二实施例的区别在于,所述转码中间件还包含内嵌框架,所述加载单元43,还用于采用所述转码中间件的内嵌框架加载所述转码引擎转码后的网页转码结果,以将所述网页转码结果加载至浏览器的空网页界面。
在本实施例中,所述转码中间件还包含有内嵌框架Iframe,在调用所述转码中间件解析所述转码URL以进行网页转码之后,所述加载单元43再采用所述转码中间件的内嵌框架加载所述转码引擎转码后的网页转码结果,并将所述网页转码结果加载至浏览器的空网页界面。
此处需要说的是,传统的信息流解码方式,是对网页进行解析,然后根据本地模板将网页内容重组一个本地的网页,如果转码成功,就返回一个成功后的网页okURL;如果转码失败,就返回原始网页srcURL,这种情况下,就会导致同一个资讯,在浏览器上会有两种表现形式,用户查看时难以区分,从而降低用户的体验。
而本发明实施例中,在设置的转码中间件还设置了内嵌框架,该内嵌框架用于将网页转码结果加载至浏览器的空网页界面,虽然转码引擎的网页转码结果包括两种:转码成功的okURL,转码失败的原始网页srcURL。但是不管转码引擎输出的是okURL还是srcURL,都交由“转码中间件的内嵌框架”进行网页的加载工作。转码中间件会通过内嵌框架IFrame来渲染转码后的网页,这样在整个转码过程中,把转码后的网页用IFrame的方式来加载,对外表现的URL只有transcodeURL,实现了URL的统一性,保证了同一条资讯,在浏览器上只会有一种体现形式,避免了网页转码结果有不同的表现形式,便于用户查看使用。
此外,还需要说明的是,由于传统的信息流解码方式,是对网页进行解析,然后根据本地模板将网页内容重组一个本地的网页,因此,本地转码不能重复性转码,一旦浏览器加载了一个资讯的okURL1,如果再次加载另外一个资讯的okURL2,那么之前转码的okURL1的内容就会被清除掉,因此无法通过刷新按钮来重新加载之前的网页,若是想要加载之前的网页,需要重新获取信息流,并对网页解析,再根据本地模板将网页内容重组成一个本地的网页。
例如,在浏览器的主页面中点开新闻资讯,点击新闻资讯后,终端进入新闻资讯所在界面,此时,若是想要回退,则无法直接快速加载主界面的内容,终端需要重新获取主界面的信息流,并重新进行主界面对应的网页的加载,显然,这种信息流的加载方式不仅花费时间长,还耗费资源。
而本发明实施例中,在获取到信息流之后,由转码中间件对信息流进行转码之后,得到转码URL,然后由WebView加载网页,并由转码中间件解析出transcodeURL的参数之后,由转码引擎基于参数进行转码,以得到转码结果如转码成功后的网页okURL,此时可以发现,transcodeURL仍然保留,由于该transcodeURL中包含有参数信息,当用户想要回退时,只要从transcodeURL中提取出参数,即可进行重复转码,以快速回退到之前的网页,无须重新获取信息流,提高了信息流转码的高可用性。
因此,综上所述,本发明实施例中的信息流转码方式,具有以下三个优点:
A、解决浏览器跳转页面问题,屏蔽了转码的耗时等待过程,提高信息流转码的效率;
B、统一了转码URL的表现,使得外部只感知transcodeURL,便于用户查看,提高用户体验;
C、解决了浏览器刷新或加载新网页不能快速刷新转码问题,本方案可以重复进行网页刷新转码。
为更好理解本实施例,举例应用场景如下:
如图5所示,当终端从服务器端获取到新闻资讯的信息流后,采用转码中间件中的转码协议转换器将新闻资讯的信息流转化成transcodeURL,然后将transcodeURL发送至网页视图WebView,由WebView进行空白网页的加载,然后所述终端再调用转码中间件对transcodeURL进行解析,以解析出网页转码需要的参数,然后将网页转码需要的参数传给转码引擎,由转码引擎进行转码,得到网页转码结果,最终所述终端再调用内嵌框架Iframe对网页转码结果进行加载,以将所述网页转码结果加载至浏览器的空网页界面,从而实现信息流的转码过程。
本发明还提供一种信息流转码方法。
参照图6,图6为本发明信息流转码方法第一实施例的流程示意图。
在本实施例中,所述信息流转码方法应用于终端,所述终端设置有转码中间件,所述信息流转码方法包括:
获取信息流,并采用转码中间件对获取的所述信息流进行转码,以得到转码统一资源定位符URL;
将转码URL传给浏览器的网页视图以加载空网页,并在所述浏览器跳转至空网页界面;
调用所述转码中间件解析所述转码URL以进行网页转码,并加载相应的网页转码结果至浏览器的空网页界面。
在本实施例中,所述信息流转码方法应用于终端,所述终端的浏览器中设置有转码中间件,所述转码中间件可以是以程序的形式加载至所述终端的浏览器中;也可以是以芯片的形式嵌入到所述终端中,以供终端在浏览器中调用所述芯片中的转码中间件。
在本实施例中,需要说明的是,所述转码中间件是整个信息流转码过程的核心,所述转码中间件包含有转码协议转码器和内嵌框架Iframe。其中,所述转码协议代码器用于把信息流转换成transcode(转码)URL(Uniform Resource Locator,统一资源定位符),并且,还可用于从transcodeURL中解析出信息流的相关参数。
本实施例中,所述transcodeURL映射的是一个本地的空网页,所述空网页的具体格式如下:
其中,子网页是指位于网页的预设区域的网页,例如,在浏览器中打开百度,百度的页面就是网页,而在百度所在页面的预设区域,如左下角区域显示的网页如新浪的广告网页,就是子网页。
本实施例中,所述transcodeURL中包含量转码所需要的所有参数,如信息流的抓取时间、信息流的名称name等等。所述浏览器的网页包含有Iframe标签(该标签支持加载子网页,满足html规范)。所述内嵌框架Iframe用于加载“转码引擎”转码后的网页,可能是okURL(转码成功的网页),也可能是srcURL(转码失败的网页),需要注意的是,虽然Iframe加载的网页可能是okURL或是srcURL,但是这两种表现形式仅仅对终端内部而言,对外的表现形式统一为transcodeURL。
以下是本实施例中实现信息流转码的具体步骤:
步骤S10,获取信息流,并采用转码中间件对获取的所述信息流进行转码,以得到转码统一资源定位符URL;
在本实施例中,所述终端在浏览器中获取服务端传输的信息流,在获取信息流之后,所述终端采用预置的转码中间件,对获取的所述信息流进行转码,以得到转码URL。
前面已经提到,所述转码中间件包含转码协议转码器,因此所述“采用转码中间件对获取的所述信息流进行转码,以得到转码统一资源定位符URL”的步骤实际上是:
采用所述转码中间件的转码协议转码器,对获取的所述信息流进行转码,以得到转码URL。
即本实施例中,在进行信息流转码之前,所述终端采用所述转码中间件的转码协议转码器,对获取的所述信息流进行转码,具体地,提取所述信息流中的参数信息,然后将提取的参数信息转码成转码URL,即transcodeURL,本发明实施例中的转码URL与transcodeURL是同一个对象,下文不再强调。应当理解,在后续的本地信息流转码过程中,都是基于该transcodeURL进行转码。
步骤S20,将转码URL传给浏览器的网页视图以加载空网页,并在所述浏览器跳转至空网页界面;
在采用转码中间件中的转码协议转码器对信息流转码,并得到转码URL之后,所述终端将所述转码URL传给浏览器的网页视图(WebView)以加载空网页,也就是说,在浏览器中,网页的加载都是由WebView来渲染。
需要说明的是,在WebView渲染一个网页时会触发一系列的网页生命周期,该网页生命周期从网页开始加载到网页完成加载,其中,onPageStart表示网页开始加载,onPageEnd表示网页完成加载。
当网页视图加载空网页的时候,所述终端在浏览器中跳转至空网页界面。
步骤S30,调用所述转码中间件解析所述转码URL以进行网页转码,并加载相应的网页转码结果至浏览器的空网页界面。
在本实施例中,当WebView加载转码URL的时候,为了保证尽早触发转码过程,在网页开始加载的时候,就会立刻触发网页转码,然后调用转码中间件进行转码URL的解析,以进行网页的转码。
需要说明的是,不管是刷新网页还是加载新的网页,都会走onPageStart至onPageEnd的周期,由于transcodeURL中包含了转码所需要的参数,因此在转码过程中,只要从transcodeURL中解析出所需要的参数即可,实现了转码可以重复进行。
本实施例提出的技术方案,对信息流的转码,是由终端先获取信息流,然后采用转码中间件对获取的所述信息流进行转码,以得到转码统一资源定位符URL,再将转码URL传给浏览器的网页视图以加载空网页,并在所述浏览器跳转至空网页界面,最终调用所述转码中间件解析所述转码URL以进行网页转码,并加载相应的网页转码结果至浏览器的空网页界面。本发明对空网页的加载,是在转码中间件对信息流进行转码的过程就已经加载完成,后续直接将转码结果加载至空网页界面即可,无需再花费时间等待页面的加载,提高了信息流转码的效率。
进一步地,提出本发明信息流转码方法的第二实施例。
信息流转码方法的第二实施例与信息流转码方法的第一实施例的区别在于,参照图7,所述步骤S30包括:
步骤S31,调用所述转码中间件对所述转码URL进行解析,解析出转码需要的参数;
步骤S32,根据解析出的参数进行网页转码;
步骤S33,将网页转码结果加载至浏览器的空网页界面。
本发明实施例中,终端将转码URL传给浏览器的网页视图以加载空网页,并在所述浏览器跳转至空网页界面之后,所述终端先调用转码中间件对转码URL进行解析,以解析出转码需要的参数,也就是说,由转码中间件对WebView加载的URL进行解析处理,解析出相关的参数param。之后,再根据转码中间件解析出的参数进行网页的转码,具体地,所述步骤S32包括:
调用转码引擎,并将解析出的参数发送至所述转码引擎,由所述解码引擎基于所述参数进行网页转码,其中,所述转码引擎使用第三方框架对所述参数进行转码。
即,在本发明实施例中,终端调用转码中间件对转码URL进行解析,得到转码需要的参数之后,再调用转码引擎,然后将转码中间件解析出的参数发送至所述转码引擎,具体地,所述终端通过转码中间件发送解码需要的参数给所述转码引擎,再由所述转码引擎基于所述参数进行网页转码。即,本发明实施例的转码引擎具有网页转码的功能。
本实施例中,转码引擎基于参数进行网页转码的方式优选为:采用第三方框架对所述参数进行转码,以得到信息流对应的网页转码结果,其中,所述转码结果包括两种:当转码成功后返回okURL;当转码失败后返回原始网页srcURL。
本实施例中,信息流转码失败的情况包括以下几种:信息流不在本地清单中、网页结构发生变化等情况,在转码引擎获取到转码需要的参数时,对参数进行分析查看,以确定参数是否满足上述几种情况,若满足,则认为转码失败,此时返回原始网页srcURL,若参数不满足上述几种情况,则认为转码成功,并返回okURL。
当转码引擎基于参数对网页进行转码,得到转码结果时,所述转码引擎可以将转码结果反馈至终端的转码中间件。最终,所述终端将网页转码结果加载至浏览器的空网页界面。
在本实施例中,采用转码中间件对转码URL进行转码,实际上是调用转码引擎对转码URL中的参数进行转码,最终得到相应的转码结果。
进一步地,提出本发明信息流转码方法的第三实施例。
信息流转码方法的第三实施例与信息流转码方法的第二实施例的区别在于,所述转码中间件还包含内嵌框架,所述“将网页转码结果加载至浏览器的空网页界面”的步骤包括:
采用所述转码中间件的内嵌框架加载所述转码引擎转码后的网页转码结果,以将所述网页转码结果加载至浏览器的空网页界面。
在本实施例中,所述转码中间件还包含有内嵌框架Iframe,在终端调用所述转码中间件解析所述转码URL以进行网页转码之后,所述终端再采用所述转码中间件的内嵌框架加载所述转码引擎转码后的网页转码结果,并将所述网页转码结果加载至浏览器的空网页界面。
此处需要说的是,传统的信息流解码方式,是对网页进行解析,然后根据本地模板将网页内容重组一个本地的网页,如果转码成功,就返回一个成功后的网页okURL;如果转码失败,就返回原始网页srcURL,这种情况下,就会导致同一个资讯,在浏览器上会有两种表现形式,用户查看时难以区分,从而降低用户的体验。
而本发明实施例中,在设置的转码中间件还设置了内嵌框架,该内嵌框架用于将网页转码结果加载至浏览器的空网页界面,虽然转码引擎的网页转码结果包括两种:转码成功的okURL,转码失败的原始网页srcURL。但是不管转码引擎输出的是okURL还是srcURL,都交由“转码中间件的内嵌框架”进行网页的加载工作。转码中间件会通过内嵌框架IFrame来渲染转码后的网页,这样在整个转码过程中,把转码后的网页用IFrame的方式来加载,对外表现的URL只有transcodeURL,实现了URL的统一性,保证了同一条资讯,在浏览器上只会有一种体现形式,避免了网页转码结果有不同的表现形式,便于用户查看使用。
此外,还需要说明的是,由于传统的信息流解码方式,是对网页进行解析,然后根据本地模板将网页内容重组一个本地的网页,因此,本地转码不能重复性转码,一旦浏览器加载了一个资讯的okURL1,如果再次加载另外一个资讯的okURL2,那么之前转码的okURL1的内容就会被清除掉,因此无法通过刷新按钮来重新加载之前的网页,若是想要加载之前的网页,需要重新获取信息流,并对网页解析,再根据本地模板将网页内容重组成一个本地的网页。
例如,在浏览器的主页面中点开新闻资讯,点击新闻资讯后,终端进入新闻资讯所在界面,此时,若是想要回退,则无法直接快速加载主界面的内容,终端需要重新获取主界面的信息流,并重新进行主界面对应的网页的加载,显然,这种信息流的加载方式不仅花费时间长,还耗费资源。
而本发明实施例中,在获取到信息流之后,由转码中间件对信息流进行转码之后,得到转码URL,然后由WebView加载网页,并由转码中间件解析出transcodeURL的参数之后,由转码引擎基于参数进行转码,以得到转码结果如转码成功后的网页okURL,此时可以发现,transcodeURL仍然保留,由于该transcodeURL中包含有参数信息,当用户想要回退时,只要从transcodeURL中提取出参数,即可进行重复转码,以快速回退到之前的网页,无须重新获取信息流,提高了信息流转码的高可用性。
因此,综上所述,本发明实施例中的信息流转码方式,具有以下三个优点:
A、解决浏览器跳转页面问题,屏蔽了转码的耗时等待过程,提高信息流转码的效率;
B、统一了转码URL的表现,使得外部只感知transcodeURL,便于用户查看,提高用户体验;
C、解决了浏览器刷新或加载新网页不能快速刷新转码问题,本方案可以重复进行网页刷新转码。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其它变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者系统不仅包括那些要素,而且还包括没有明确列出的其它要素,或者是还包括为这种过程、方法、物品或者系统所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者系统中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其它相关的技术领域,均同理包括在本发明的专利保护范围内。