Протокол SyncML в WP8-клиент перестает отвечать
Я пытаюсь заставить мою систему Windows Phone 8 MDM работать. В настоящее время устройство регистрируется и правильно выполняет первоначальный запрос SyncML. Он также отвечает на запросы в первоначальном ответе сервера, но я предполагаю, что ему что-то не нравится. Причина в том, что он использует интервалы повторных попыток для создания дополнительных подключений к серверу, а затем больше не подключается.
Когда я инициирую соединение вручную, оно работает, но автоматические соединения не выполняются. Странно то, что внутренне счетчик SyncML SessionID увеличивается с заданными интервалами, но устройство даже не пытается подключиться к серверу.
Вот мой протокол SyncML
Клиент запускается:
<SyncML xmlns="SYNCML:SYNCML1.2">
<SyncHdr>
<VerDTD>1.2</VerDTD>
<VerProto>DM/1.2</VerProto>
<SessionID>E</SessionID>
<MsgID>1</MsgID>
<Target>
<LocURI>https://ssl.../enrollment/omadmservice.php</LocURI>
</Target>
<Source>
<LocURI>IMEI:35...64</LocURI>
<LocName>riho</LocName>
</Source>
<Cred>
<Meta>
<Format xmlns="syncml:metinf">b64</Format>
<Type xmlns="syncml:metinf">syncml:auth-md5</Type>
</Meta>
<Data>SoFh6khg4awLYXn2PQOOwQ==</Data>
</Cred>
</SyncHdr>
<SyncBody>
<Alert>
<CmdID>2</CmdID>
<Data>1201</Data>
</Alert>
<Replace>
<CmdID>3</CmdID>
<Item>
<Source>
<LocURI>./DevInfo/DevId</LocURI>
</Source>
<Data>IMEI:35...64</Data>
</Item>
...
</Replace>
<Final/>
</SyncBody>
</SyncML>
Сервер отвечает:
<SyncML xmlns="SYNCML:SYNCML1.2">
<SyncHdr>
<VerDTD>1.2</VerDTD>
<VerProto>DM/1.2</VerProto>
<SessionID>E</SessionID>
<MsgID>1</MsgID>
<Target>
<LocURI>IMEI:35...64</LocURI>
</Target>
<Source>
<LocURI>https://ssl.../enrollment/omadmservice.php</LocURI>
<LocName>MDMServer</LocName>
</Source>
<Cred>
<Meta>
<Format xmlns="syncml:metinf">b64</Format>
<Type xmlns="syncml:metinf">syncml:auth-md5</Type>
</Meta>
<Data>ryJ+boSmdCoO8BzxXcYSxg==</Data>
</Cred>
</SyncHdr>
<SyncBody>
<Status>
<CmdID>1</CmdID>
<MsgRef>1</MsgRef>
<CmdRef>0</CmdRef>
<Cmd>SyncHdr</Cmd>
<Data>212</Data>
</Status>
<Status>
<MsgRef>1</MsgRef>
<CmdRef>2</CmdRef>
<CmdID>2</CmdID>
<Cmd>Alert</Cmd>
<Data>200</Data>
</Status>
<Status>
<CmdID>3</CmdID>
<MsgRef>1</MsgRef>
<CmdRef>3</CmdRef>
<Cmd>Replace</Cmd>
<Data>200</Data>
</Status>
<Get>
<CmdID>4</CmdID>
<Item>
<Target>
<LocURI>./Vendor/MSFT/Registry/HKLM/Software/Microsoft/DeviceEncryption/Enabled</LocURI>
</Target>
</Item>
</Get>
</SyncBody>
</SyncML>
Клиент отправляет свой ответ:
<SyncML xmlns="SYNCML:SYNCML1.2">
<SyncHdr>
<VerDTD>1.2</VerDTD>
<VerProto>DM/1.2</VerProto>
<SessionID>E</SessionID>
<MsgID>2</MsgID>
<Target>
<LocURI>https://ssl.../enrollment/omadmservice.php</LocURI>
</Target>
<Source>
<LocURI>IMEI:35...64</LocURI>
</Source>
</SyncHdr>
<SyncBody>
<Status>
<CmdID>1</CmdID>
<MsgRef>1</MsgRef>
<CmdRef>0</CmdRef>
<Cmd>SyncHdr</Cmd>
<Chal>
<Meta>
<Format xmlns="syncml:metinf">b64</Format>
<Type xmlns="syncml:metinf">syncml:auth-md5</Type>
<NextNonce xmlns="syncml:metinf">kjjz6FyCYuYm9VUsSaHfKmj98GGfh9yeLvv8hlMNZak=</NextNonce>
</Meta>
</Chal>
<Data>212</Data>
</Status>
<Status>
<CmdID>2</CmdID>
<MsgRef>1</MsgRef>
<CmdRef>4</CmdRef>
<Cmd>Get</Cmd>
<Data>200</Data>
</Status>
<Results>
<CmdID>3</CmdID>
<MsgRef>1</MsgRef>
<CmdRef>4</CmdRef>
<Item>
<Source>
<LocURI>./Vendor/MSFT/Registry/HKLM/Software/Microsoft/DeviceEncryption/Enabled</LocURI>
</Source>
<Meta>
<Format xmlns="syncml:metinf">int</Format>
</Meta>
<Data>1</Data>
</Item>
</Results>
<Final/>
</SyncBody>
</SyncML>
И сервер хранит данные и сбрасывает соединение.
Может кто-нибудь найти ошибку в моей реализации? Что еще ожидает клиент от сервера?
1 ответ
Как я выяснил, проблема была не в моей реализации, а в глючной документации Microsoft. В своем "WP8 Enterprise Management Protocol 1.2" они исправили несколько опечаток и ошибок в своем протоколе, и теперь соединения работают как положено.