GB28181设备目录查询采用RFC3428中的MESSAGE方法实现, 需要走有应答命令流程。
完整的定义请参考GB28181标准,这里只列举代码实现中要留意的一些细节.
1.Message消息头中的Content-type必须是"Application/MANSCDP+xml".
2.设备目录查询/应答命令采用 MANSCDP 协议格式定义.
3.XML字符编码一般是GB2312, 安卓默认可能是UTF8(某些SIP库), 具体要看服务端,有些服务端只支持GB2312,设备信息中的中文字符显示可能就是乱码, 安卓端的字符编码较为简单,代码如下:
catalogResponse.getBytes("GB2312");
4.RFC3428规定MESSAGE请求不要超过1300个字节,原文如下(来自于RFC3428):
The size of MESSAGE requests outside of a media session MUST NOT exceed 1300 bytes, unless .....
媒体会话一般是指INVITE Dialog加媒体传输(RTP传输音视频), 详细定义请看RFC3261。所以保守实现还是确保目录响应请求不要大于1300个字节,如果有多个的话设备的, 有可能就超过1300个字节,对于这个情况请参考"GB28181附录N(规范性附录)多响应消息",关键一点就是要拆成多条MESSAGE请求消息,必须串行发送,就是收到前一条响应200OK,再发下一个拆分好的请求消息;不过GB28181也提及到一点,SIP协议栈实现要支持TCP方式,TCP情况超过1300字应该节问题不大(所有中间的SIP Proxy节点也要能支持TCP才是).
5.给出一个简单的查询/响应例子:
<!---查询命令---->
<Query>
<CmdType>Catalog</CmdType>
<SN>12337</SN>
<DeviceID>31011500991320000177</DeviceID>
</Query>
<!---响应---->
<Response>
<CmdType>Catalog</CmdType>
<SN>12337</SN>
<DeviceID>31011500991320000177</DeviceID>
<SumNum>1</SumNum>
<DeviceList Num="1">
<Item>
<DeviceID>34020000001380000037</DeviceID>
<Name>设备11111</Name>
<Manufacturer>设备厂家111</Manufacturer>
<Model>设备型号1111</Model>
<Owner>Owner111</Owner>
<CivilCodeCivilCode1111</CivilCode>
<Address>地址111222</Address>
<Parental>0</Parental>
<ParentID>31011500991320000177</ParentID>
<SafetyWay>0</SafetyWay>
<RegisterWay>1</RegisterWay>
<Secrecy>0</Secrecy>
<Status>ON</Status>
<Longitude>143.507222</Longitude>
<Latitude>33.99011311</Latitude>
</Item>
</DeviceList>
</Response>
6. 安卓GB28181 SDK添加设备方法:
// 创建设备
com.gb28181.ntsignalling.Device gb_device = new com.gb28181.ntsignalling.Device("34020000001380000007", "安卓Test设备", Build.MANUFACTURER, Build.MODEL,"宇宙","某星系","某行星", true);
// 设置经纬度
gb_device.setLongitude(mLongitude);
gb_device.setLatitude(mLatitude);
// 添加设备
gb28181_agent_.addDevice(gb_device);
从协议到代码实现,细节问题还是比较多的.