我在运行 Ubuntu 16.04.2 LTS 的 Azure 虚拟机上运行 coturn 服务器。我正在用 c# 实现一个 TURN 客户端,我正在努力解决我假设的问题,或者是我的服务器配置中的问题、服务器软件中的错误,或者我的客户端中的编码问题。
当我REALM
从服务器收到消息时,我首先注意到了这个问题。领域名称是 9 个字符,但我不断NULL
从服务器获得 3 个额外字符。在尝试更改我发送的软件版本时,我的怀疑得到了证实。如果长度不能被 4 整除,则服务器不会发回任何内容(我现在相信它会按照相应的STUN / TURN规范默默地丢弃消息,该规范规定丢弃未知属性)。
根据规范,我将字符串编码为UTF-8
(存储字符串类型 TLV 属性的示例)
private void StoreString(AttributeType key, string v, byte[] msg, ref int offset)
{
byte[] stringBytes = Encoding.UTF8.GetBytes(v);
// Attribute header
StoreAttributeType(key, msg, ref offset);
msg[offset++] = (byte)(stringBytes.Length >> 8);
msg[offset++] = (byte)(stringBytes.Length & 0xFF);
Array.Copy(stringBytes, 0, msg, offset, stringBytes.Length);
offset += stringBytes.Length;
}
原始字节:
01-13-00-40-21-12-A4-42-57-9E-20-40-86-81-34-F9-B0-64-C1-E4-00-09-00-10-00-00-04-01-55-6E-61-75-74-68-6F-72-69-7A-65-64-00-15-00-10-39-64-38-35-62-66-61-66-62-63-34-36-30-62-31-66-00-14-00-09-74-65-73-74-72-65-61-6C-6D-00-00-00-80-22-00-04-4E-6F-6E-65
我使用规范解析并得到
Type: AllocateErrorResponse, Length: 64, ID: 42a41221-9e57-4020-8681-34f9b064c1e4
Attributes:
- Type: ErrorCode, Value: Code: Unauthorized, Reason: Unauthorized
- Type: Nonce, Value: 9d85bfafbc460b1f
- Type: Realm, Value: testrealm
Attribute parsing not implemented for 0
- Length: 128, Value: 22-00-04-4E-6F-6E-65
它尝试解析的值type=0
实际上length=128
是消息的结尾和服务器软件名称
80-22-00-04-4E-6F-6E-65
属性8022
定义为属性SOFTWARE
,长度为0x0004
,值为4E-6F-6E-65
文本None
所以服务器正在返回所有正确的值和所有正确的长度,但似乎字符串被填充为 UTF-16 可分割长度。所以这似乎是一个编码问题,但我不知道它是服务器中的软件错误、服务器上的配置问题还是我的客户端中的问题。我知道这都是开源的,我可以深入研究源代码,但我希望在我必须走那么远之前有人能有所了解。