CN101783783A - 用于管理客户端的方法、相关的客户端和服务器 - Google Patents
用于管理客户端的方法、相关的客户端和服务器 Download PDFInfo
- Publication number
- CN101783783A CN101783783A CN200910003256A CN200910003256A CN101783783A CN 101783783 A CN101783783 A CN 101783783A CN 200910003256 A CN200910003256 A CN 200910003256A CN 200910003256 A CN200910003256 A CN 200910003256A CN 101783783 A CN101783783 A CN 101783783A
- Authority
- CN
- China
- Prior art keywords
- client
- message
- server
- session
- software
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Images
Landscapes
- Information Transfer Between Computers (AREA)
Abstract
本发明提出了一种在利用SIP的系统中实现标准化软件认证和升级的方法、相关的客户端和服务器,其中,在客户端中预设至少一个服务器的地址,在客户端与服务器之间按照SIP交换信令,该方法包括:客户端当开始在终端上运行时向服务器发送向服务器注册的第一消息;服务器向客户端发送要求认证的第二消息;在客户端收到第二消息之后向服务器发送包含凭证的、向服务器注册的第三消息;服务器向客户端发送包含最新客户端版本信息的第四确认消息;如果客户端本身的版本低于包含于第四消息中的版本并且用户决定升级,则客户端向服务器发送包含最新客户端版本信息的、与服务器发起关于升级的会话的第五消息;以及,服务器向客户端传送升级数据。
Description
技术领域
本发明涉及通信领域,具体地涉及在分组网络中利用会话初始协议(SIP)进行客户端认证和升级。
背景技术
SIP是由IETF于1999年提出的在互联网中实现实时通信应用的信令控制协议。它用于创建、修改和释放一个或多个参与者的会话。这些会话例如是互联网多媒体会议、IP电话或多媒体分发。会话的参与者可以通过组播、单播或二者的组合来进行通信。SIP既不是会话描述协议,也不提供会议控制功能。为了描述消息内容的负载情况和特点,SIP使用互联网的会话描述协议(SDP)来描述终端设备的特点。
在利用SIP的系统中采用互联网常用的客户端/服务器结构,由用户代理和服务器两大部分组成。其中用户代理又分为用户代理客户端(UAC:UserAgentClient)和用户代理服务器(UAS:UserAgent Server)。UAC用来发起会话请求,UAS用来接受并响应会话请求。这二者只是逻辑上的功能,实际上网络终端应同时具备这两种功能,既能发起会话,又能接受并响应会话。
目前,在软件系统中,还未提出一种通过SIP实现软件认证和升级的标准机制。不同的软件使用不同的专用机制来进行认证和升级。这存在以下三个缺点:第一,由于没有标准机制,因此开发者必须设计和实现专用的软件认证和升级机制,这在软件开发过程中需要付出额外的工作和成本;第二,难以在系统级对软件认证和升级进行管理和维护;以及,针对软件认证和升级难以实施第三方应用和服务。
发明内容
为了解决上述现有技术中的问题,根据本发明的一个方面,提出了一种用于在软件系统中通过SIP实现标准的客户端认证和升级的方法,其中,在软件客户端中预设至少一个服务器的地址,在所述客户端与所述服务器之间按照会话初始协议交换信令从而实现对所述客户端的管理,所述方法包括:所述客户端当开始在终端上运行时向所述服务器发送用于向该服务器注册的第一消息;所述服务器向所述客户端发送用于要求认证的第二消息;在所述客户端收到所述第二消息之后向所述服务器发送包含凭证的、用于向所述服务器注册的第三消息;以及,所述服务器向所述客户端发送包含最新客户端版本信息的、用于确认的第四消息。
根据本发明的方法还包括:如果所述客户端本身的版本低于包含于所述第四消息中的最新版本并且用户决定进行升级,则所述客户端向所述服务器发送包含所述最新客户端版本信息的、用于与所述服务器发起关于升级的会话的第五消息;以及,所述服务器向所述客户端传送用于进行升级的数据。
可选地,所述服务器在收到所述第五消息后,还可以向所述客户端发送用于要求认证的第六消息,并且当所述客户端收到所述第六消息之后向所述服务器发送包含凭证和所述最新客户端版本信息的、用于与所述服务器发起关于升级的会话的第七消息。
根据本发明的另一方面,提出了一种在分组网络中与至少一个服务器交换信令的客户端,其中,在所述客户端中预设所述服务器的地址,在所述客户端与所述服务器之间按照会话初始协议交换信令从而实现对所述客户端的管理。所述客户端包括消息修改装置,其用于在用户决定进行升级的情况下将最新客户端版本信息设置在用于与所述服务器发起关于升级的会话的消息中。
根据本发明的又一方面,提出了一种用于在利用SIP的系统中实现标准的客户端认证和升级的服务器,其中,在所述客户端中预设所述服务器的地址,在所述客户端与所述服务器之间按照会话初始协议交换信令从而实现对所述客户端的管理。所述服务器包括消息修改装置,其用于当成功认证客户端之后将最新客户端版本信息设置在用于确认的消息中。
附图说明
通过阅读下面结合附图对本发明具体实施例的说明,本发明的上述及其他特征和优点将变得更加明显。其中:
图1概略地说明了如何利用SIP来实现和标准化客户端认证;
图2概略地说明了如何利用SIP来实现和标准化客户端升级;
图3是根据本发明一个实施例的客户端认证和升级方法的流程图;
图4是根据本发明另一个实施例的客户端认证和升级方法的流程图;
图5是根据本发明一个实施例的客户端的框图;和
图6是根据本发明一个实施例的服务器的框图。
具体实施方式
本发明提出了一种用于在利用SIP的系统中实现和标准化软件管理的方法,所述管理包括例如认证和升级。本发明的基本思想是利用SIP注册来实现和标准化软件认证;以及利用SIP会话发起来实现和标准化软件升级。软件与软件服务器之间的信令流可以例如严格遵循RFC 3261。应当指出,为了经由网络而实现软件认证和升级,软件必须知道至少一个软件服务器的地址,并且软件用作SIP用户代理客户端(UAC)而其服务器用作SIP注册服务器和用户代理服务器(UAS)。图1和图2概略地说明了本发明的基本思想。
注意,下文将提到的软件认证服务器与软件升级服务器从逻辑上来说是两个不同的模块,但是在实际应用中,可以物理上共存于同一服务器内。
图1说明了如何利用SIP来实现和标准化软件认证。如图所示,当软件开始运行时,它首先向软件认证服务器发送REGISTER消息(F1)。在SIP中,用户代理可以通过向软件认证服务器发送REGISTER请求消息来完成注册、注销、刷新、地址映射获取等操作。然后,如果软件认证服务器想要认证该软件,则可以通过返回带“WWW-Auth enticate”的401消息(F2)来要求软件提供凭证。软件收到该401消息后根据该消息中的认证码计算出授权码并重新发出具有授权码的REGISTER消息(F3)(只有授权的软件才能正确计算出授权码)。接着,当软件认证服务器成功处理完具有正确凭证的REGISTER消息后,它将返回200OK消息(F4)。应当指出,在由软件认证服务器返回的这个200OK消息中引入了新的SIP报头“Software-Release”,软件认证服务器通过这个新报头告知软件当前可获得的最新升级版本。该新报头包含软件名称和版本。其形式例如可以是:“Software-Release:software_name 16.6.556.9”,其中software_name是软件名称,而16.6.556.9是版本号。
认证成功之后,软件即获知可用的最新升级版本。如果该软件自身的版本低于最新的升级版本,则例如可以向用户弹出一个对话框以询问用户是否进行升级。如果用户决定进行升级,则该软件可以使用SIP来发起升级会话。
图2说明了如何利用SIP来实现和标准化软件升级。如果用户决定升级,则软件首先向软件升级服务器发送INVITE消息(F1)来发起升级会话。该INVITE消息中引入了新的报头“Software-Release”,该报头用于告知服务器该软件想要升级至哪个软件版本。该INVITE消息例如可以如下:
INVITE sip:updatesvr.xxx.com SIP/2.0
Software-Release:software_name 16.6.556.9
…
其中,新的报头Software-Release用来描述软件名称和版本号,即“software_name”是软件的名称,而“16.6.556.9”是软件的版本号。服务器可以根据这个信息来选择软件升级包。F1消息所携带的SDP1包含客户端升级会话的参数。所述参数包括软件接收升级数据所使用的网络地址、软件接收数据要使用的传输协议,等等。
此时,软件升级服务器例如可以要求软件提供凭证(F3),如针对图1中的REGISTER消息那样。在这种情况下,该软件需要重新发出具有正确凭证的INVITE消息(F5)。软件升级服务器完成认证之后可以返回具有SDP2的200OK消息(F7)。在得到软件的确认消息ACK(F8)之后就可以向软件发送升级数据了。当所有的升级数据被软件接收完毕之后,软件升级服务器就发送BYE(F9)至软件以释放该会话。最后,软件用所收到的升级数据来进行升级。
通过以上描述可知,采用根据本发明的软件认证和升级方法具有以下优点:
-不同的软件可以使用相同的软件认证和升级机制;
-新软件的开发成本和工作可以减少,因为开发者不必设计和实现专业的软件认证和升级机制;
-可以在不同的软件之间重复使用软件认证和升级的代码;
-可以在系统级实现对软件认证和升级的管理和维护;以及
-可以在软件认证和升级上实现第三方服务或应用。
图3是根据本发明一个实施例的客户端认证和升级方法的流程图。下面结合图1和图2来说明图3的方法。
在步骤301中,所述客户端当开始在终端上运行时向所述服务器发送用于向该服务器注册的第一消息。具体地,以图1所示的信令流程图为例,运行于终端上的客户端向服务器发送REGISTER消息。在这里,所述终端可以例如是个人计算机、个人数字助理(PDA)等。
接着,在步骤302中,所述服务器向所述客户端发送用于要求认证的第二消息。在这里,所述第二消息例如是具有WWW-Authenticate的401消息。在步骤303中,在所述客户端收到所述第二消息之后向所述服务器发送包含凭证的、用于向所述服务器注册的第三消息。在这里,所述第三消息例如是包含凭证的REGISTER消息。在步骤304中,所述服务器向所述客户端发送包含最新客户端版本信息的、用于确认的第四消息。在这里,所述第四消息例如是200OK消息,该200OK消息具有如上文所述的新报头“Software-Release”。
然后,在步骤305中,如果所述客户端本身的版本低于包含于所述第四消息中的最新版本并且用户决定进行升级,则所述客户端向所述服务器发送包含所述最新客户端版本信息的、用于与所述服务器发起关于升级的会话的第五消息。具体地,以图2所示的信令流程图为例,在客户端将收到的版本与自身版本比较后发现自身版本较低时,例如可以向用户弹出对话框来询问用户是否进行升级。如果用户决定升级,则向服务器发送INVITE消息,该INVITE消息中包含如上文所述的新报头“Software-Release”用以告知服务器想要升级到哪个版本。最后,在步骤306中,所述服务器向所述客户端传送用于进行升级的数据。在升级数据传送完毕之后,服务器例如可以向客户端发送BYE消息以释放该对话。
图4示出了根据本发明另一个实施例的客户端认证和升级方法的流程图。该图中的步骤401至405与图3中的步骤301至305是相同的。在下面的描述中对于相同的部分将适当地省略说明以避免重复。
在实际的应用当中,服务器在接收到来自客户端的包含版本信息的、用于发起升级会话的INVITE消息后,可能会要求客户端提供凭证。本实施例就是针对这种情况。因此,在步骤406中,所述服务器向所述客户端发送用于要求认证的第六消息。在这里,所述第六消息可以例如是如上文的401消息。接着,在步骤407中,当所述客户端收到所述第六消息之后向所述服务器发送包含凭证和所述最新客户端版本信息的、用于与所述服务器发起关于升级的会话的第七消息。具体地,以图2所示的流程为例,当客户端收到来自服务器的401消息之后,向该服务器重新发出包含凭证以及所述新报头“Software-Release”的INVITE消息。最后,在步骤408中,当所述服务器认证完毕之后,向所述客户端传送用于进行升级的数据。同样,在升级数据传送完毕之后,服务器例如可以向客户端发送BYE消息以释放该对话。
这样,通过根据本发明的方法,可以在利用SIP的系统中实现用于软件认证和升级的统一机制,从而达到如前文所述的那些优点。
在同一发明构思下,根据本发明的另一个方面,提供了一种用于实现根据本发明的软件认证和升级的统一机制的客户端。下面就结合附图对其进行说明。
图5示出了根据本发明一个实施例的客户端500。该客户端500包括消息修改装置501。消息修改装置501用于在用户决定进行升级的情况下将最新客户端版本信息设置在用于与所述服务器发起关于升级的会话的消息中。例如,在用户决定升级的情况下,消息修改装置501将如上文所述的新报头“Software-Release”添加至待发送给服务器的INVITE消息中,从而告知服务器它要升级到哪个版本。
在实施上,本实施例的客户端500以及其包含的消息修改装置501可以以软件、硬件或软件和硬件组合的方式来实现。例如,本领域技术人员熟悉多种可用来实现这些部件的设备,诸如微处理器、微控制器、专用集成电路(ASIC)、可编程逻辑设备(PLD)和/或现场可编程门阵列(FPGA)等。本实施例的消息处理装置501可以和客户端500集成在一起实现,也可以各自独立实现。
在操作上,上述结合图5说明的实施例的客户端,可以实现前面描述的客户端认证和升级方法。通过使用该客户端,可以在利用SIP的系统中实现认证和升级客户端的标准机制。
在同一发明构思下,根据本发明的另一个方面,提供了一种用于在利用SIP的系统中认证和升级客户端的服务器。下面就结合附图对其进行说明。
图6示出了根据本发明一个实施例的服务器600。服务器600包括消息修改装置601。消息修改装置601用于当成功认证客户端之后将最新客户端版本信息设置在用于确认的消息中。例如,在收到来自客户端的包含凭证的REGISTER消息之后,消息修改装置601将如上所述的新报头“Software-Release”添加至待返回给客户端的200OK消息中,该新报头向客户端指示了可用的最新升级版本。
在实施上,本实施例的服务器600以及其包含的消息修改装置601可以以软件、硬件或软件和硬件组合的方式来实现。例如,本领域技术人员熟悉多种可用来实现这些部件的设备,诸如微处理器、微控制器、专用集成电路(ASIC)、可编程逻辑设备(PLD)和/或现场可编程门阵列(FPGA)等。本实施例的消息处理装置601可以和服务器600集成在一起实现,也可以各自独立实现。
在操作上,上述结合图6说明的实施例的服务器,可以实现前面描述的客户端认证和升级方法。通过使用该服务器,可以在利用SIP的系统中实现认证和升级客户端的标准机制。
以上虽然通过一些示例性的实施例对本发明的用于在利用SIP的系统中实现标准的客户端认证和升级的方法、相应的客户端以及服务器进行了详细的描述,但是以上这些实施例并不是穷举的,本领域技术人员可以在本发明的精神和范围内实现各种变化和修改。因此,本发明并不限于这些实施例,本发明的范围仅由所附权利要求为准。
Claims (14)
1.一种用于在分组网络中进行客户端管理的方法,其中,在客户端中预设至少一个服务器的地址,在所述客户端与所述服务器之间按照会话初始协议交换信令从而实现对所述客户端的管理,其特征在于,所述方法包括:
所述客户端当开始在终端上运行时向所述服务器发送用于向该服务器注册的第一消息;
所述服务器向所述客户端发送用于要求认证的第二消息;
在所述客户端收到所述第二消息之后向所述服务器发送包含凭证的、用于向所述服务器注册的第三消息;以及
所述服务器向所述客户端发送包含最新客户端版本信息的、用于确认的第四消息。
2.根据权利要求1所述的方法,还包括下列步骤:
如果所述客户端本身的版本低于包含于所述第四消息中的最新版本并且用户决定进行升级,则所述客户端向所述服务器发送包含所述最新客户端版本信息的、用于与所述服务器发起关于升级的会话的第五消息;以及
所述服务器向所述客户端传送用于进行升级的数据。
3.根据权利要求2所述的方法,其中,所述服务器在收到所述第五消息后,向所述客户端发送用于要求认证的第六消息,并且当所述客户端收到所述第六消息之后向所述服务器发送包含凭证和所述最新客户端版本信息的、用于与所述服务器发起关于升级的会话的第七消息。
4.根据权利要求1-3中任一项所述的方法,其中,所述最新客户端版本信息被设置在所述第四消息、所述第五消息和所述第七消息的报头中,并且包括相应的客户端名称和版本号。
5.根据权利要求1-4中任一项所述的方法,其中,所述第一消息和第三消息是按照会话初始协议的REGISTER消息。
6.根据权利要求1-5中任一项所述的方法,其中,所述第二消息和所述第六消息是按照会话初始协议的401消息。
7.根据权利要求1-6中任一项所述的方法,其中,所述第四消息是按照会话初始协议的200OK消息。
8.根据权利要求1-7中任一项所述的方法,其中,所述第五消息和所述第七消息是按照会话初始协议的INVITE消息。
9.一种在分组网络中与至少一个服务器交换信令的客户端,其中,在所述客户端中预设所述服务器的地址,在所述客户端与所述服务器之间按照会话初始协议交换信令从而实现对所述客户端的管理,其特征在于,所述客户端包括:
消息修改装置,用于在用户决定进行升级的情况下将最新客户端版本信息设置在用于与所述服务器发起关于升级的会话的消息中。
10.根据权利要求9所述的客户端,其中,所述用于与所述服务器发起关于升级的会话的消息是按照会话初始协议的INVITE消息。
11.根据权利要求9或10所述的客户端,其中,所述最新客户端版本信息被设置在所述用于与所述服务器发起关于升级的会话的消息的报头中,并且包括相应的客户端名称和版本号。
12.一种用于在分组网络中管理客户端的服务器,其中,在所述客户端中预设所述服务器的地址,在所述客户端与所述服务器之间按照会话初始协议交换信令从而实现对所述客户端的管理,其特征在于,所述服务器包括:
消息修改装置,用于当成功认证客户端之后将最新客户端版本信息设置在用于确认的消息中。
13.根据权利要求12所述的服务器,其中,所述用于确认的消息是按照会话起始协议的200OK消息。
14.根据权利要求12或13所述的服务器,其中,所述最新客户端版本信息被设置在所述用于确认的消息的报头中,并且包括相应的客户端名称和版本号。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN200910003256A CN101783783A (zh) | 2009-01-21 | 2009-01-21 | 用于管理客户端的方法、相关的客户端和服务器 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN200910003256A CN101783783A (zh) | 2009-01-21 | 2009-01-21 | 用于管理客户端的方法、相关的客户端和服务器 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN101783783A true CN101783783A (zh) | 2010-07-21 |
Family
ID=42523603
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN200910003256A Pending CN101783783A (zh) | 2009-01-21 | 2009-01-21 | 用于管理客户端的方法、相关的客户端和服务器 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN101783783A (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109194694A (zh) * | 2018-10-30 | 2019-01-11 | 浙江理工大学 | 一种基于互联网的针织设备会话管理方法及系统 |
CN112702409A (zh) * | 2020-12-21 | 2021-04-23 | 中电福富信息科技有限公司 | 一种基于国标信令的设备远程升级方法 |
-
2009
- 2009-01-21 CN CN200910003256A patent/CN101783783A/zh active Pending
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109194694A (zh) * | 2018-10-30 | 2019-01-11 | 浙江理工大学 | 一种基于互联网的针织设备会话管理方法及系统 |
CN112702409A (zh) * | 2020-12-21 | 2021-04-23 | 中电福富信息科技有限公司 | 一种基于国标信令的设备远程升级方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10470103B2 (en) | System and method for authentication of a communication device | |
KR101430442B1 (ko) | 네트워크 기반의 능력 관리를 통한 세션 업데이트 방법 및단말 | |
US7480254B2 (en) | System, apparatus, and method for providing multi-application support using a single protocol stack | |
CN101185304B (zh) | 用于标识ims业务的方法和装置 | |
US20050220039A1 (en) | Information service communication network system and session management server | |
CN101252581A (zh) | 数据通信系统及会话管理服务器 | |
EP2168353B1 (en) | Ip link establishment across a data network | |
CN100574474C (zh) | 一种通讯系统中建立通讯业务连接的方法 | |
Ludwig et al. | Jingle | |
US8315247B2 (en) | System and method for providing registration-coupled subscriptions in a session initiation protocol (SIP) environment | |
CN101917526A (zh) | 一种sip电话网络中的号码配置方法和设备 | |
EP2869527B1 (en) | Method for extending application interface for future applications | |
CN101951381A (zh) | 数字电视接收终端及其实现多媒体即时通讯的方法 | |
JP2007233803A (ja) | Http対応端末をsip対応サーバに接続する代理接続方法、プロキシサーバ及びプログラム | |
CN101783783A (zh) | 用于管理客户端的方法、相关的客户端和服务器 | |
KR101773183B1 (ko) | 통신 시스템에서 세션 히스토리 송수신 방법 | |
EP2418913B1 (en) | Methods and system for joining group session with pre-defined joining | |
CN101155336A (zh) | 实现消息系统用户漫游的方法及其系统 | |
KR100922726B1 (ko) | Sip 기반 통신망을 이용한 멀티미디어 스트리밍 서비스제공 방법 | |
US20100135190A1 (en) | Method and system for establishing a group messaging session in a communication system | |
CN101425967B (zh) | 内容提供系统、监视服务器和sip代理服务器 | |
US20100185763A1 (en) | Method for exchanging user information in a telecommunication network | |
KR101689196B1 (ko) | 통신 시스템에서 세션 히스토리 송수신 방법 | |
Švoňavský | Interconnection between SIP and XMPP | |
WO2013123995A1 (en) | Method and application for controlling application server invocation in an ims |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C02 | Deemed withdrawal of patent application after publication (patent law 2001) | ||
WD01 | Invention patent application deemed withdrawn after publication |
Application publication date: 20100721 |