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.给出一个简单的查询/响应例子:

<!---查询命令---->  
<?xml version="1.0" encoding="GB2312" ?>
<Query>
<CmdType>Catalog</CmdType>
<SN>12337</SN>
<DeviceID>31011500991320000177</DeviceID>
</Query>


<!---响应---->
<?xml version="1.0" encoding="GB2312"?>
<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);

 从协议到代码实现,细节问题还是比较多的.