TR069协议编程基础知识Word文档下载推荐.docx
- 文档编号:19618796
- 上传时间:2023-01-08
- 格式:DOCX
- 页数:19
- 大小:23.07KB
TR069协议编程基础知识Word文档下载推荐.docx
《TR069协议编程基础知识Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《TR069协议编程基础知识Word文档下载推荐.docx(19页珍藏版)》请在冰豆网上搜索。
〔3〕CPE接到GET请求后与ACS建立连接,并在成功建立连接后发送一条INFORM报文.
连接建立示意图
ACS与CPE之间结束会话:
ACS与CPE之间的会话如果要正常结束需要以下条件:
〔1〕CPE不再有请求发给ACS
〔2〕ACS也没有请求发给CPE
〔3〕CPE已经发送完毕ACS的请求响应
〔4〕ACS已经发送完毕CPE的请求响应
RPC方法
方法列表
方法介绍
1、Inform信息:
由CPE传送到网管,CPE事件通过绑定Inform信息进行上报;
事件的EVENT_CODE有
〔1〕"
表示会话发起的原因是CPE首次安装或者是ACS的URL发生变化.网管接收到后要执行注册流程
〔2〕"
表示会话发起的原因是CPE通电启动或者是重置,包括系统首次启动,以与任何原因引起的重启,或者是事件"
MReboot"
引起的;
〔3〕"
表示会话发起的原因是因为定时Inform策略引起的.
〔4〕"
表示会话发起的原因是因为CPE定时调用了ScheduleInform方法引起的.该EVENT_CODE必须位于"
MScheduleInform"
中.
〔5〕"
表示会话发起的原因是CPE的一个或者多个参数值发生变化.
〔6〕"
5KICKED"
表示会话发起的原因是为了Web标识管理〔?
〕
〔7〕"
表示会话发起的原因是源自ACS的ConnectionRequestNotification
〔8〕"
7TRANSFERCOMPLETE"
表示会话发起的原因是上传或者下载成功〔不管是否真的成功〕
〔9〕"
8DIAGNOSTICSCOMPLETE"
当完成由ACS要求的诊断测试后,重新与ACS建立连接时用
〔10〕"
9REQUESTDOWNLOAD"
表示会话发起的原因是CPE要求调用RequestDownload方法
〔11〕"
10AUTONOMOUSTRANSFERCOMPLETE"
表示会话发起的原因是由CPE主动的上传或者下载成功,而不是ACS的请求
〔11〕"
"
MDownload"
"
MUpload"
带有"
M"
字符说明这个是执行ACS请求方法的结果,里面一般含有其它的EVENT_CODE;
如:
"
含有"
〔12〕"
X_CU_ALARM"
X_DISCOVER"
厂商自定以规范前者表示告警信息,后者表示发现信息
2、GetParameterNames:
由ACS发起,用于发现CPE上的可访问参数.
涉与到的数据表有
命令请求操作处理:
CO_RTU,CO_PROTOCOL,CO_CHANEL;
回应信息处理:
CO_PARAM_LIST,CO_NE_PARAM,CO_CWMP_PARAM_LIST
3、GetParameterValues:
由ACS发起,用于查找CPE上一个或者多个参数的值.
4、SetParameterAttributes:
由ACS发起,用于修改CPE上一个或者多个参数的属性.
5、SetParameterValues:
由ACS发起,用于修改CPE上一个或者多个参数的值.
6、AddObject:
由ACS发起,用于对一个特定的多实例对象创建一个新的实例.
7、DeleteObject:
由ACS发起,用于删除一个对象的特定实例
8、Reboot:
由ACS发起,用于重启指定的CPE终端
9、DownLoad:
由ACS发起,用于要求CPE终端在指定的位置下载指定的文件
10、Upload:
由ACS发起,用于要求CPE终端向指定位置上传某一特定文件
11、FactoryReset:
由ACS发起,用于要求特定的CPE终端恢复出厂设置.
12、GetRpcMethods由CPE或者是ACS发起,用于发现另一方所支持的方法集.
方法参数详解
1INFORM参数
内容见下表:
参数
类型
描述
DeviceID
DeviceIdStruct
Manufactucer,OUI,ProductClass<
用于标识产品或者产品类型>
SerialNumber
Event
EventStruct
说明引发会话建立的一个或者多个事件
MaxEnvelope
Unsignedint
CPE能够从ACS接受的一个回复中的最大SOAP信包数目.若为0则说明没有限制
CurrentTime
dateTime
CPE当前日期时间
RetryCount
在完成对inform方法的调用前,进行进行了多少次调用尝试,在每次非成功的尝试后增加1.非成功的尝试包括发送Inform报文以与与ACS建立连接,或每次对Inform的报文的不成功调用,如:
接收到错误应答或没有接收应答.在已经发送了Inform报文并成功得到应答后该值被重置为0
ParameterList
ParameterValueStruct
CPE在Inform请求中包含的参数信息表,每次上报必须包含一些参数:
硬件版本、软件版本、ManagementServer.ConnectionRequestURL、CommandKey等
2GetRpcMethods参数
内容见下表
该方法没有调用参数
3GetRpcMethodsResponse参数
MethodList
String<
>
[]
字符串数组,包含支持的每一个RPC名称.例如:
CPE返回方法列表给ACS:
GetRPCMethods"
SetParameterValues"
GetParameterValues"
SetParameterNames"
GetParameterNames"
AddObject"
DeleteObject"
Reboot"
4SetParameterValues参数
ParamterValueStruct[]
一个Name-Value的键值对数组.对每个Name-ValueCPE会将对应参数到的值设为指定值
ParameterKey
32>
设置ParameterKey的参数值.该值可以用于acs,来识别参数更新,或者让其为空
5SetParameterValuesResponse参数
Status
int[0:
1]
对该方法的成功应答返回一个整数型的枚举值定义如下:
0=参数的改动已经验证并应用.
1=参数的改动已经验证并提交,只是尚未应用〔比如,在新的参数值应用前需要进行重新启动〕.
6ParameterValueStruct定义
Name
string<
256>
参数的名称.
Value
任意类型
需要设置的值
7GetParameterNames参数
ParameterPath
包括一个完整参数名或部分路径名的字符串,代表名称层次的一个子集.空字符串代表名称空间的顶层.部分路径名必须在层次中的最后一个节点名称后面以"
."
〔点〕结尾.
下面是完整参数名的例子:
下面是部分路径名的一个例子:
InternetGatewayDevice.DeviceInfo.
NextLevel
boolean
如果值为false,则CPE响应将列出所有以ParameterPath参数指定字符串开始的参数的完整路径名.
如果值为true,则CPE响应只列出指定的ParameterPath下一层的部分路径名.例如,如果ParameterPath是"
InternetGatewayDevice.LANDevice."
响应可能列出"
InternetGatewayDevice.LANDevice.1."
和"
InternetGatewayDevice.LANDevice.2."
而不会列出在该层次下面的所有参数.
8GetParameterNamesResponse参数
ParameterInfoStruct[]
结构数组,每个包含一个参数的名称和其它信息,见下表的定义.当NextLevel是false时,这一方法返回所有名称以ParameterPath参数指定的字符串开头的所有可访问的参数与其信息.如果ParameterPath参数是一个空字符串,则将返回该CPE上所有可访问的参数名称.当NextLevel是true时,这一列表包括以ParameterPath指明路径的下一层的所有部分路径名.
9ParameterInfoStruct参数
Name
这是参数的名称或部分路径名.
Writable
是否该参数值能够用SetParameterValues方法来覆盖.
如果因NextLevel值为true,该名称是一个部分路径名,则表明是否AddObject和DeleteObject可以被用于该层次来移除该实例或增加其它的实例.
10SetParameterAttributes参数
SetParameterAttributesStruct[]
列出用于更改一组参数的属性改动值.该数组中的每项条目是一个SetParameterAttributesStruct结构,在下表中定义.
11SetParameterAttributesStruct参数
这是应用新属性的参数的名称.另一种方式是,该名称可以是一个部分路径名,表明新的属性应当应用于命名层次中该节点下的所有参数.部分路径名必须在层次中的最后一个节点名称后面以"
〔点〕结尾.空字符串代表名称空间的顶层.
NotificationChange
如果为true,Notification的值将替换该参数或参数组的当前notification的设置.
如果是false,则不作任何notification设置的改动.
Notification
2]
指定是否CPE应当将指定的该〔或多个〕参数的变化值放到其Inform报文中,以与是否当指定参数的值发生变化时,CPE应当发起一个到ACS的会话.值的定义如下:
0=Notification关闭.CPE不必通过ACS指定参数的变化.
1=被动式Notification.当指定的参数值变化时,CPE必须在下一次建立与ACS的会话时,将这一新值包含在Inform报文的ParameterList中.
2=主动式Notification.一旦指定参数的值发生变化,CPE必须发起与ACS的会话,将新值包含在相应的Inform报文的ParameterList中.
因非零的Notification设置引起发送的Inform报文中参数发生变化,事件代码"
必须包括在事件列表中.
如果试图给一个不适合设置notification值的参数〔比如一个持续变化的统计值〕设置notification值,CPE可以返回一个"
notificationrequestrejected"
错误.
AccessListChange
如果为true,AccessList的值会替换该参数或参数组的当前accesslist值.如果为false,accesslist不作改动.
AccessList
64>
[]
零个或多个实体的数组,该实体对指定的参数有写权限.如果数组中不包含条目,则只允许ACS有写权限.目前,只定义了一类实体可以包含在该列表中:
Subscriber"
指明由LAN上的Subscriber控制的设备拥有写权限.比如通过LAN端的DSLCPE配置协议或通过UPnP.
默认情况下,在ACS对accesslist作改动前,上述的所有实体应当被赋予写访问权.
12SetParameterAttributesResponse参数
-
void
该方法的应答没有参数.
13GetParameterAttributes参数
ParameterNames
字符串数组,每一条对应所请求的参数的名称.
如果参数名是以部分路径名的方式出现,则该请求需被解释为请求返回命名层次中共用相同前缀的该分支的所有参数.部分路径名必须在层次的最后一个节点名称后面以"
〔点〕结尾.空字符串代表整个层次名称的顶部.
下面是完整参数名称的例子:
下面是部分路径名称的例子:
14GetParameterAttributesResponse参数
ParameterAttributeStruct[]
列示指定的参数集的accesscontrol信息.该数组中的每一条目是一个ParameterAcessStruct结构,在下表中定义.
15ParameterAttributesStruct参数
这是给出属性值的参数名称.
16AddObject参数
objectName
要建立新实例的对象集合的路径名称.路径名必须在该对象的层次名称的最后节点后加上"
需要设置的ParameterKey参数的值.该参数由服务器决定,并可以为空.
17AddObjectResponse参数
InstanceNumber
unsignedInt[1:
]
新建对象的实例.在对象建立后,可以在路径名中使用该实例来引用该对象的参数或子对象.由CPE指定的实例是任意的,并且与后续的AddObject调用分配的无需连续.
CPE不应当将曾经分配出去的现已删除的对象使用过的再分配给新的实例.CPE应当在耗尽某指定对象的整个整数值空间后再重用实例.
Status
0=对象已经建立.
1=对象的建立已经验证并提交,只是尚未应用〔比如,增加新对象前需要进行重新启动〕.
18DeleteObject参数
欲删除的对象实例的路径名.路径名必须以对象的实例后加"
〔点〕来结尾.
19DeleteObjectResponse参数
·
20DownLoad参数
CommandKey
CPE用来指向特定下载的字符串.该参数在方法TransferComplete和GetQueuedTransfers中引用.
FileType
一个整数,其后是一个空格,再其后是一个文件类型说明.目前FileType参数仅定义了以下值:
1FirmwareUpgradeImage"
2WebContent"
3VendorConfigurationFile"
下列格式用于定义唯一的厂商自定义文件类型:
X<
OUI>
<
Vendor-specificidentifier>
其中,<
用6位十六进制数字的OUI〔组织唯一标识〕代替,其中所有字母用大写,包括所有前置零.
URL
URL说明源文件的位置.必须支持传输.可以支持其它可选的传输方式,如节的定义.
Username
CPE用于认证文件服务器的用户名.如果不需要认证,则该字符串设置为空串.
Password
CPE用于认证文件服务器的密码.如果不需要认证,则该字符串设置为空串.
FileSize
unsignedInt
以字节为单位的要传输文件的大小.
TargetFileName
在目标文件系统中应使用的文件名.
DelaySeconds
从本方法被调用到CPE被要求开始下载之间的时间间隔.如果值为零表明不需要延迟.如果是非零值,则下载不应当使用与该请求相同的事务会话.
SuccessURL
在能应用的情况下,本参数包含在下载成功完成后,CPE应当将用户的浏览器重定向到哪一URL.在不需要这样的URL的情况下,这一参数应当为空.
FailureURL
在能应用的情况下,本参数包含在下载未成功完成后,CPE应当将用户的浏览器重定向到哪一URL.在不需要这样的URL的情况下,这一参数应当为空.
Staus
0=下载已结束并已应用.
1=下载还没有结束〔比如,CPE需要重新启动后才能执行文件的下载〕.
如果该参数的值非零,则CPE必须在本会话的后续时间,或者在其后的会话中,调用TransferComplete方法来说明本次下载的完成状态〔成功或者失败〕.
StartTime
下载开始的日期和时间〔UTC〕.只有在下载结束后该值才需要填写.
CompleteTime
下载完全结束并应用时的日期和时间〔UTC〕.只有在下载结束后该值才需要填写.
21Reboot参数
当CPE重新启动并调用Inform方法时,将在InfromStruct的CommandKey元素中返回该元素值.
22RebootResponse参数
该响应方法无参数.
23CPE的错误码
9000
方法不支持
9001
拒绝请求〔未说明原因〕
9002
内部错误
9003
无效参数
9004
资源超限〔当用于SetParameterValues的关联时,它不得用来指示参数错误〕
9005
无效参数名〔与Set/GetParameterValues,GetParameterNames,Set/GetParameterAttributes相关〕
9006
无效参数类型〔与SetParameterValues相关〕
9007
无效参数值〔与SetParameterValues相关〕
9008
试图设置不可写的参数〔与SetParameterValues相关〕
9009
Notification请求被拒〔与SetParameterAttributes方法相关〕
9
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- TR069 协议 编程 基础知识