dastapov: (Default)
Dmitry Astapov ([personal profile] dastapov) wrote2006-11-10 04:35 pm
Entry tags:

GSM: Почему у белого медведя нос черный или Почему в смс влазит 160 символов, а не 255?

Заказной пост на тему: "А про sms можно рассказать? какой там протокол, и почему сообщение ограничено 160 символами?"

Учитывая, что про SMS материалов в сети масса, ответ будет коротким.

В процессе "придумывания" SMS (а его именно "придумывали", т.к. в отличие от голоса/факса у SMS не было аналога в "проводном" мире) перед авторами спецификации встал вопрос - как передавать SMS-ы между коммутаторами? Было принято решение использовать механизмы, доступные в рамках стека протоколов SS7 (Signalling System #7). Протокол MAP (используемый MSC для передачи "сигнальной" информации о звонке в процессе коммутации - кто звонит, кому звонит, и т.п.) был расширен специальным сообщением forward_short_message, содержимое которого, собственно, и является телом SMS.

Именно отсюда ростут ноги у известного ограничения. Протокол MAP основан на протоколе TCAP, который по своей природе предусматривал работу в режиме real-time, в стиле "короткий request - короткий responce". Естественно, что ни о какой фрагментации/сессиях в стиле TCP в рамках TCAP речь не шла. MAP унаследовал эту особенность.

Вот и получилось, что 1 SMS должен был обязательно влазить в одно MAP-сообщение. Максимальный размер payload в MAP - 140 байт или (140 * 8 = 1120 бит). В такое кол-во бит можно засунуть либо 160 7-битных символов, либо 140 8-битных, либо 70 16-битных. И только сравнительно недавно мобильные терминалы научились делать SMS concatenation и обходить это ограничение.

Литература:

[identity profile] jerom.livejournal.com 2006-11-25 10:05 pm (UTC)(link)
Мне однажды (в 1999 году) выдали в качестве интерфейса для обмена короткими сообщениями логин-пароль на ftp сервер и текстовый формат с комментарием: "Любая опечатка в имени тега, любой пробел после тега, вызывает падение нашего сервера и сообщения вообще перестают ходить. Кроме того, если номер не существует, генерируется текстовый файл, который вы обязаны забрать до следующего прохода нашего робота, иначе он упадёт. Пожалуйста, будьте осторожны!"

Это был пейджинговый оператор...

[identity profile] http://users.livejournal.com/_adept_/ 2006-11-26 03:25 pm (UTC)(link)
Возможно, кто-то написал им систему "задешево" и исчез с радара. А отлаживать-чинить в самой конторе ее было некому. Вот и жили, как могли :)