Skype протоколы - Skype protocol - Wikipedia

The Skype протоколы Бұл меншіктік Қолданатын Интернет-телефония желісі Skype. Хаттаманың сипаттамалары Skype арқылы көпшілікке жария етілмеген және хаттаманы қолданатын ресми қосымшалар жабық көз.

Skype желісі жоқ өзара үйлесімді басқаларымен IP арқылы дауыс беру (VoIP) желілері Skype-тан тиісті лицензиясыз. Оқуға және / немесе көптеген талпыныстар кері инженер хаттама протоколды ашу, қауіпсіздікті тергеу немесе бейресми клиенттерге рұқсат беру үшін қабылданды.

2014 жылдың 20 маусымында Microsoft ескі Skype протоколының күшін жою туралы жариялады. Осы күннен бастап бірнеше ай ішінде Skype қызметін пайдалануды жалғастыру үшін Skype қолданушылары 2014 жылы шыққан Skype қосымшаларына жаңаруы керек болды, ал пайдаланушылар ескі Skype нұсқаларына (клиенттеріне) кіре алмады.[1][2] SmartTV және кіріктірілген Skype функциясы бар аппараттық телефондардың жұмысын тоқтаусыз жалғастыратындығы туралы ешқандай хабарлама жасалмады. Жаңа Skype хаттамасы—Microsoft хабарлама хаттамасы 24 - Skype құрылғыларында оффлайн хабар алмасу және хабарларды синхрондау жақсы болады. Амортизация 2014 жылдың тамыз айының екінші аптасында күшіне енді.[3]

Peer-to-peer архитектурасы

Skype бірінші болды пиринг жүйесі IP телефония желісі.[4] Желі үш типті нысандарды қамтиды: супернодтар, қарапайым түйіндер және кіру сервері. Әрбір клиент а хост кэші бірге IP мекен-жайы және қол жетімді супернодтардың порт нөмірлері. Skype пайдаланушы каталогы орталықтандырылмаған және желідегі супернодтар арасында таратылған. Супернодтар топтастырылған слоттар (9-10 супернод) және слоттар топтастырылған блоктар (8 слот).

Бұрын кез-келген клиент өткізу қабілеттілігі жақсы, шектеулер жоқ брандмауэр немесе желі мекенжайын аудару (NAT) және жеткілікті өңдеу қуаты супернодқа айналуы мүмкін. Бұл Интернетке NAT қосылмаған адамдарға қосымша салмақ түсірді, өйткені Skype өз компьютерлері мен Интернет байланыстарын үшінші тарап ретінде пайдаланды UDP саңылауын тесу (NAT-тің артында екі клиентті тікелей қосу үшін) немесе басқа пайдаланушылардың қоңырауларын толығымен жіберу үшін. 2012 жылы Майкрософт желінің дизайнын өзгертті және барлық супернодтарды олардың басқаруында деректер орталықтарында орналастырылған серверлер ретінде қосты.[5] Майкрософт сол кезде бұл қадамды қорғап, «бұл тәсілдің Skype қауымдастығын құрайтын жүздеген миллион пайдаланушылар үшін жылдамдығы, масштабталуы және қол жетімділігі пайдасы бар» деп мәлімдеді.[6] Сол кезде өзгерістің құпиялылық салдары туралы біраз алаңдаушылық болды,[7] ашылуымен дәлелденген сияқты PRISM 2013 жылғы маусымда бақылау бағдарламасы.[8][9]

Skype бағдарламасын пайдалануды қолдамайды IPv6 хаттама,[10] бұл жоғарыда аталған IPv4 байланыс құрылымымен байланысты күрделілікті айтарлықтай төмендетеді.

Супернодтар екі басқа клиенттің атынан байланыс жібереді, олардың екеуі де брандмауэрдің артында немесе «біреуден көп» желі мекен-жайын аударуға арналған. Супернодтар жібермей, брандмауэр немесе NAT қиындықтары бар екі клиент қоңырау шала немесе қабылдай алмайтын болады. бір-біріне. Skype қосылым туралы егжей-тегжейлі келіссөздер жүргізуге тырысады, бірақ кейде екі жақтағы мәселелердің жиынтығы тікелей сөйлесуге жол бермейді.

Брандмауэр мен NAT проблемалары келесідей болуы мүмкін:

  • Сыртқы порт нөмірлері немесе IP мекен-жайы туынды болып табылмайды, өйткені NAT оларды қайта жазады
  • Қолданылып жатқан брандмауэр және NAT сеанстың қабылдануына жол бермейді
  • UDP уақытты күту сияқты NAT мәселелеріне байланысты қолданылмайды
  • Брандмауэр көптеген порттарды жауып тастайды
  • Бірнеше NAT арқылы TCP әрдайым әдепкі бойынша «тек сыртқа» шығады - порт бағыттау параметрлерін NAT маршрутизаторына қосу TCP сеанстарын қабылдауға мүмкіндік береді

Хаттама

Сигнал көмегімен шифрланады RC4; дегенмен, әдіс тек трафикті бұзады, өйткені кілт пакеттен қалпына келтірілуі мүмкін. Дауыстық деректер шифрланған AES.[11]

Skype клиенті қолданбалы бағдарламалау интерфейсі (API) бағдарламалық жасақтама жасаушыларға желіні ашады. Skype API басқа бағдарламаларға Skype желісін алуға мүмкіндік береді «ақ беттер «ақпарат және қоңырауларды басқару.

Skype коды - жабық көз және хаттама стандартталмаған.[12] Клиенттің пайдалану бөліктері Internet Direct (Үндістан), ашық көзі бар ұялы байланыс кітапханасы.[дәйексөз қажет ]

2012 жылдың 8 шілдесінде Бениннен келген зерттеуші Уанило Медеган мақалалар мен тұжырымдама кодының дәлелі, Skype клиентін кері жобалау нәтижелері туралы жариялады.[13]

Хаттаманы анықтау

Көптеген желілік және қауіпсіздік компаниялары Skype протоколының корпоративті және тасымалдаушы қосымшаларына арналғандығын анықтайды және басқарады дейді. Бұл компаниялар қолданатын нақты анықтау әдістері көбіне меншікті болғанымен, Пирсонның хи-квадрат сынағы және стохастикалық сипаттама Бейбіт Бейс классификаторлары 2007 жылы жарияланған екі тәсіл.[14]

Обфускациялық қабат

The RC4 шифрлау алгоритмі датаграммалардың пайдалы жүктемесін бұзу үшін қолданылады.

  1. The CRC32 жалпыға қол жетімді көзі мен тағайындалған IP, Skype пакетінің идентификаторы алынады
  2. Скайптың обфусация қабаты инициализация векторы (IV).

Осы 32-биттік екі мәннің XOR белгісіз кілт қозғалтқышы көмегімен 80 байтты RC4 кілтіне айналады.

Skype-та RC4-ті айтарлықтай дұрыс қолданбауды TCP ағындарынан табуға болады (UDP әсер етпейді). Алғашқы 14 байт (оның 10-ы пайдаланушыға белгілі, өйткені олар пайдаланушы аты мен парольдің хэшінен тұрады) RC4 ағынымен XOR-редакцияланған. Содан кейін, TCP ағынының қалған бөлігін шифрлау үшін шифр инициализацияланады.[15]

TCP

TCP пакеттері:

TCPSkype Init TCP пакеті

Skype Init TCP пакеті бар

  • тұқым (4 байт)
  • init_str жол 00 01 00 00 01 00 00 00 01/03

Төмен деңгейдегі диаграммалар

Трафиктің барлығы дерлік шифрланған. Әр команданың параметрлері объектілер тізіміне енгізілген. Нысандар тізімін қысуға болады.

                                 / Объектілер тізімі ... - | Enc -> Cmd -> Encod ^  Қысылған тізім ... - | Фраг | | | ------------------ <--------------- | Ак
        Жоқ
        Алға -> Алға ... Хабарлама

Нысандар тізімдері

Нысан сан, жол, IP: порт немесе басқа объектілер тізімі болуы мүмкін. Әр объектінің жеке куәлігі болады. Бұл идентификатор объектінің қандай командалық параметр екенін анықтайды.

 Нысан: IP нөмірі: Порт Сандар тізімі RSA кілті
 Нысандар тізімі тізімінің өлшемі (n) 1-нысан. . N нысаны

Пакетті қысу

Пакеттерді қысуға болады. Алгоритм дегеніміз - арифметикалық қысу биттердің орнына реалдарды қолданады.

Құқықтық мәселелер

Кері инженерия екілік файлдарды тексеру / бөлшектеу арқылы Skype протоколының жасалуына Skype лицензиялық келісімінің шарттары тыйым салынады. Алайда, Еуропалық Одақтың заңдары компьютерлер бағдарламасын өзара жұмыс жасау мақсатында автордан рұқсатынсыз кері жобалауға мүмкіндік береді.[16] Америка Құрама Штаттарында Сандық мыңжылдыққа арналған авторлық құқық туралы заң басқа бағдарламалық жасақтамамен өзара әрекеттесу мақсатында кері инженерлік бағдарламалық қамтамасыздандыруды қамтамасыз етеді.[17][18] Сондай-ақ, АҚШ-та кері инжиниринг файл форматтары мен протоколдарының өзара әрекеттесуіне бағытталған заңды прецеденттер бар.[19][20][21]

Сонымен қатар, кейбір елдер кері инженерия мақсатында бағдарламаны көшіруге арнайы рұқсат береді.[22]

Ескертулер

  1. ^ «Жұмыс үстеліндегі Skype-тың келесі буынына жол ашу». 20 маусым 2014 ж.
  2. ^ Кейзер, Грегг. «Жаңарту: Windows, Mac үшін соңғы басылымдарды шығару үшін Skype; жаңартулар міндетті».
  3. ^ Крис Мерримен (15 тамыз 2014). «Skype ескі Android телефондарында жұмысын тоқтатады, Linux қолданушыларын қараңғыда қалдырады». CNET. Алынған 2 қазан 2014.
  4. ^ Салман А.Басет; Хеннинг Шулцринне (2004). «Интернет-телефония Skype-тен-хаттамаға талдау». б. 11. arXiv:cs / 0412017v1.
  5. ^ Бранском, Мэри (2012 жылғы 27 шілде). «Конспект теорияларын ұмытыңыз: Skype супернодтары бұлтқа жатады». Болашаққа 500 сөз (ZDNet). Алынған 17 маусым 2013.
  6. ^ «Skype P2P супер кодтарын Microsoft орналастыратын Linux қораптарымен ауыстырады (жаңартылған)». Ars Technica. 2 мамыр 2012. Алынған 17 маусым 2013.
  7. ^ Коснер, Энтони (18 шілде 2012). «Microsoft корпорациясының Skype архитектурасына енгізген өзгертулері барлауды жеңілдете ме?». Forbes блогы. Алынған 17 маусым 2013.
  8. ^ Галлахер, Райан (6 маусым 2013). «Жаңа ашылған PRISM тыңдауы Verizon қадағалауын балалар заттарына ұқсайды». Slate блогы. Алынған 17 маусым 2013.
  9. ^ Гринвальд, Гленн (7 маусым 2013). «NSA Prism бағдарламасы Apple, Google және басқаларының пайдаланушы деректерін қолданады». The Guardian. Алынған 17 маусым 2013.
  10. ^ «Skype IPv6-ны қолдамайды». Skype-тің ресми Twitter аккаунты. 1 қараша 2012. Алынған 4 қараша 2012.
  11. ^ Кіріспе Skype анализі Skype-қа қарсы саясатты қолдану, Skype Skype қауіпсіздігін зерттеді, Desclaux Fabrice, 11.07.2005, EADS CCR / STI / C
  12. ^ «Skype қай протоколдарды қолданады?». Көмектесіңдер. Skype. Архивтелген түпнұсқа 2009 жылдың 3 наурызында.
  13. ^ «Skype кері санатындағы хабарламалар». oKLabs.
    «Skype Reverse Engineering: (ұзақ) саяхат;).» oKLabs.
  14. ^ Дарио Бонфильо; т.б. «Skype трафигін анықтау: кездейсоқтық сізбен ойнағанда». ACM SIGCOMM компьютерлік коммуникацияға шолу. 37 (SIGCOMM 2007): 37-48. Архивтелген түпнұсқа 2011-04-30.
  15. ^ Фабрис Декла; Костя Кортчинский (2006-06-17). «Vanilla Skype 2 бөлімі» (PDF). RECON2006.
  16. ^ Еуропалық парламенттің және 2009 жылғы 23 сәуірдегі Кеңестің компьютерлік бағдарламаларды құқықтық қорғау туралы 2009/24 / EC директивасы
  17. ^ 17 АҚШ Сек. 1201 (f).
  18. ^ ДЗМҰ-ның авторлық құқығы, орындалуы және фонограммалары туралы шарттарды жүзеге асыру актісі
  19. ^ Sega vs Accolade, 1992 ж
  20. ^ Sony vs Connectix, 2000 ж
  21. ^ Памела Самуэлсон & Сюзанна Скотчмер (мамыр 2002). «Кері инженерияның заңы және экономикасы» (PDF). Йель заң журналы. 111: 1575–1663. дои:10.2307/797533. JSTOR  797533. Архивтелген түпнұсқа (PDF) 2011-07-16. Алынған 2015-03-17.
  22. ^ Француздық «интеллектуалдық меншік» туралы заңда кез-келген бағдарламалық жасақтама пайдаланушысына оны кері инженериялауға мүмкіндік беретін ерекшелік бар. Қараңыз code de la propriété интеллектуалды (француз тілінде). Бұл заң ЕО заңнамасының бір бөлігі болып табылады: 91/250 / EEC кеңесінің директивасы, содан бері күшін жойды Еуропалық парламенттің және 2009 жылғы 23 сәуірдегі Кеңестің компьютерлік бағдарламаларды құқықтық қорғау туралы 2009/24 / EC директивасы онда сонымен бірге тәуелсіз, бірақ жұмыс аралық бағдарламаларды әзірлеу және сынау мақсатында кері жобалауға / декомпиляциялауға мүмкіндік беретін өте ұқсас ережелер бар).

Әдебиеттер тізімі

Сыртқы сілтемелер