0 / 1 / 0
Регистрация: 14.12.2015
Сообщений: 14
|
||||||
1 | ||||||
Сокеты. Отправка GET-запроса по HTTPS и получение ответа от сервера26.12.2015, 12:00. Показов 8602. Ответов 20
Метки нет (Все метки)
Использую сокеты для отправки GET-запроса и получения HTML-кода запрашиваемой страницы. Все красиво и быстро работает ! С HTTPS у меня возникли проблемы. Отправляю стандартный GET-запрос на порт 443 - в ответ:
Код
HTTP/1.1 400 Bad Request Server: nginx/1.9.4 Date: Fri, 25 Dec 2015 22:16:08 GMT Content-Type: text/html Content-Length: 270 Connection: close
0
|
26.12.2015, 12:00 | |
Ответы с готовыми решениями:
20
Сокеты(отправка байтов серверу и получение ответа) Отправка POST запроса и получение ответа Отправка POST запроса в ВК и получение ответа Отправка http запроса и получение ответа |
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
|
||||||
26.12.2015, 21:38 | 2 | |||||
Сообщение было отмечено freeollo как решение
Решение
SSL реализован через сокеты. Пишете SSL_write, читаете SSL_read, шифрует библиотека.
В сети достаточно примеров. В упрощенном виде что-то такого типа (использовалась openssl):
PS. Тег [URL] в 33 строке добавлен здешним веб-редактором. Его в тексте не было.
1
|
0 / 1 / 0
Регистрация: 14.12.2015
Сообщений: 14
|
|
29.12.2015, 09:11 [ТС] | 3 |
создал файл https.c
подключил библиотеку openssl Результат: gcc -I/root/openssl/openssl-1.0.2e/include -o https https.c /tmp/cczA3MJJ.o: In function `main': https.c.text+0x20): undefined reference to `SSL_library_init' https.c.text+0x25): undefined reference to `OPENSSL_add_all_algorithms_noconf' https.c.text+0x2a): undefined reference to `SSL_load_error_strings' https.c.text+0x2f): undefined reference to `SSLv23_client_method' https.c.text+0x3f): undefined reference to `SSL_CTX_new' https.c.text+0xf5): undefined reference to `SSL_new' https.c.text+0x10a): undefined reference to `SSL_set_fd' https.c.text+0x116): undefined reference to `SSL_connect' https.c.text+0x190): undefined reference to `SSL_write' https.c.text+0x1d5): undefined reference to `SSL_read' https.c.text+0x1f8): undefined reference to `SSL_free' https.c.text+0x20e): undefined reference to `SSL_CTX_free'
0
|
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
|
||||||
29.12.2015, 11:24 | 4 | |||||
freeollo, Линкер не находит библиотеку. Если openssl установлена стандартным способом
0
|
0 / 1 / 0
Регистрация: 14.12.2015
Сообщений: 14
|
|
29.12.2015, 16:47 [ТС] | 5 |
а как можно поставит нестандартным способом? Переместить папку openssl в user/include? Можно поставить openssl на Mас os. На сервере не совсем удобно писать скрипты
0
|
612 / 373 / 69
Регистрация: 21.09.2008
Сообщений: 1,277
|
|
29.12.2015, 20:25 | 6 |
freeollo, Вы попытались создать исполняемый файл без компоновки библиотеки libopenssl.a опцией -lopenssl и компоновщик ld не смог разрешить внешние ссылки на используемые функции.
Команда вида gcc -I/root/openssl/openssl-1.0.2e/include -lopenssl -o https https.c будет иметь смысл только при собранной библиотеке openssl. Если не секрет, сервер под управлением какой ОС работает?
1
|
0 / 1 / 0
Регистрация: 14.12.2015
Сообщений: 14
|
|
30.12.2015, 00:02 [ТС] | 7 |
Библиотеку собирал запуском на сервере /.config , oн создал include/openssl
Версия OS: Linux version 2.6.32-504.12.2.el6.x86_64 Добавлено через 38 минут /usr/bin/ld: cannot find -lopenssl
0
|
612 / 373 / 69
Регистрация: 21.09.2008
Сообщений: 1,277
|
|
30.12.2015, 04:51 | 8 |
Это отработал скрипт-конфигуратор, создающий Makefile. После его запуска запускали утилиту make?
Это ядро. Мне бы точнее узнать дистрибутив Linux: OpenSUSE, Ubuntu, Arch или ещё какой. А в /usr/lib есть libssl.a? Компоновщик не нашёл библиотеку libopenssl.a. Попробуйте указать опцию -Lpath-to-lib где расположен файл libopenssl.a.
0
|
0 / 1 / 0
Регистрация: 14.12.2015
Сообщений: 14
|
|
30.12.2015, 11:20 [ТС] | 9 |
запустил - не помогло
# cat /etc/issue CentOS release 6.6 (Final) и # uname -r 2.6.32-504.12.2.el6.x86_64 там такого файла не оказалось, нашел я его в "/root/openssl/openssl-1.0.2e/libssl.a" файл libopenssl.a команда find не нашла
0
|
612 / 373 / 69
Регистрация: 21.09.2008
Сообщений: 1,277
|
|
30.12.2015, 11:59 | 10 |
Попытайтесь теперь так:
gcc -Iroot/openssl/openssl-1.0.2e/include -L/root/openssl/openssl-1.0.2e/ -lssl -o https https.c
0
|
0 / 1 / 0
Регистрация: 14.12.2015
Сообщений: 14
|
|
30.12.2015, 14:54 [ТС] | 11 |
без изменений
# gcc -I/root/openssl/openssl-1.0.2e/include -L/root/openssl/openssl-1.0.2e/ -lssl -o https https.c /tmp/ccDBzgGT.o: In function `main': https.c.text+0x20): undefined reference to `SSL_library_init' https.c.text+0x25): undefined reference to `OPENSSL_add_all_algorithms_noconf' https.c.text+0x2a): undefined reference to `SSL_load_error_strings' https.c.text+0x2f): undefined reference to `SSLv23_client_method' https.c.text+0x3f): undefined reference to `SSL_CTX_new' https.c.text+0xf5): undefined reference to `SSL_new' https.c.text+0x10a): undefined reference to `SSL_set_fd' https.c.text+0x116): undefined reference to `SSL_connect' https.c.text+0x190): undefined reference to `SSL_write' https.c.text+0x1d5): undefined reference to `SSL_read' https.c.text+0x1f8): undefined reference to `SSL_free' https.c.text+0x20e): undefined reference to `SSL_CTX_free' collect2: ld returned 1 exit status
0
|
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
|
|
30.12.2015, 18:02 | 12 |
Не хочешь pkg-config, так посмотри, перед тем как строку вбивать, где у тебя реально находится библиотека и как называется.
0
|
612 / 373 / 69
Регистрация: 21.09.2008
Сообщений: 1,277
|
||||||
30.12.2015, 20:03 | 13 | |||||
Сообщение было отмечено freeollo как решение
Решение
Приведённый пример собрался под FreeBSD 10 после включения заголовка <netinet/in.h>
cc -Wall -o https -lssl -lcrypto https.c Как видите, компонуются два библиотечных модуля libssl.a и libcrypto.a. Подозреваю, что libcrypto.a собирается вместе с libssl.a.
2
|
0 / 1 / 0
Регистрация: 14.12.2015
Сообщений: 14
|
|
31.12.2015, 11:50 [ТС] | 14 |
через pkg-config не получается
# gcc `pkg-config --cflags --libs openssl` -o https https.c /tmp/ccR2apBI.o: In function `main': https.c.text+0x20): undefined reference to `SSL_library_init' https.c.text+0x25): undefined reference to `OPENSSL_add_all_algorithms_noconf' https.c.text+0x2a): undefined reference to `SSL_load_error_strings' https.c.text+0x2f): undefined reference to `SSLv23_client_method' https.c.text+0x3f): undefined reference to `SSL_CTX_new' https.c.text+0xf5): undefined reference to `SSL_new' https.c.text+0x10a): undefined reference to `SSL_set_fd' https.c.text+0x116): undefined reference to `SSL_connect' https.c.text+0x190): undefined reference to `SSL_write' https.c.text+0x1d5): undefined reference to `SSL_read' https.c.text+0x1f8): undefined reference to `SSL_free' https.c.text+0x20e): undefined reference to `SSL_CTX_free' Добавлено через 14 часов 8 минут Eсли я подключу или перемещу в нужные папки все необходимые файлы *.h и *.a поставляемые openssl, то проект будет компилироваться не зависимо от того какая у меня стоит OS? Или мне нужно пройти процедуру установки openssl и наличие файлов *.h и *.a, в нужном месте, недостаточно для компиляции?
0
|
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
|
|
31.12.2015, 12:14 | 15 |
Давайте по порядку.
1. Для сборки вашей программы нужна библиотека libopenssl вместе с заголочными файлами (или, как вариант две библиотеки libssl и libcrypto). 2. Стандартный способ установки библиотек - менеджер пакетов (apt-get, yum ....). Версии библиотек для разработчиков также включают заголовочные файлы и статические либы. Они обычто имеют суффикс -dev в Дебиане и -devel в РедХэте. Напр. у меня в Дебиане достаточно установить libssl-dev. 3. При таким образом установленной библиотеке для ее подключения компилятору достаточно дать опции, которые выводит команда pkg-config --cflags --libs openssl. 4. По умолчанию сборка динамическая - т.е. статические библиотеки (с расширением *.a) вовсе не нужны. Используются динамические (*.so). 5. Если вы где-то скачали библиотеку и не через пакет, и не в виде исходников, а в виде набора заголовочных файлов и статических библиотек, то, во-первых нужно проверить соответствие версий этих библиотек вашей архитектуре, потом проверить и разрешить их зависимости (напр. какую версию libc они требуют), затем указать их в строке компилятора либо через -L -l, либо прямым перечислением *.a файлов наряду с *.c файлами. Но этот путь, ИМХО, самый сложный и самый бестолковый. Обычно либо устанавливают библиотеку пакетом, либо компилируют из исходников.
0
|
0 / 1 / 0
Регистрация: 14.12.2015
Сообщений: 14
|
|
03.01.2016, 12:19 [ТС] | 16 |
Получилось откомпилировать код Скрипт отправляет GET-запрос через https и получает HTML-код запрашиваемый страницы. Большое спасибо gng и sharpey
0
|
07.02.2019, 11:37 | 17 | ||||||||||
У меня вот так установилась:
"Permission denied Обрыв терминальной линии". Т.е. почему-то не работает.
0
|
724 / 224 / 72
Регистрация: 01.03.2011
Сообщений: 629
|
|
09.02.2019, 11:54 | 18 |
Складывается впечатление, что вы библиотеку руками ставили, что-то поломав при этом.
Выхлоп ldd для этой программы и любой системной использующей openssl (например /usr/bin/wget) для libcrypo и libssl отличается?
0
|
09.02.2019, 14:51 | 19 | |||||
Да, руками, в итоге. Т.к. она, похоже, была изначально установлена (при предыдущей установке Ubuntu) неправильно. Или поломалась в процессе, как говорится. Поэтому нарушения связей не устранялись и при компиляции ошибки были. И в конце концов, видимо, я ее доломал окончательно.
Переустановил Ubuntu, вместо apt-get использовал aptitude - проблема решилась, все скомпилировалось. Да, и вместо -rpath=usr/local/ использую теперь -L/usr/lib.
Не по теме: Правда, именно Яндекс выдает ошибку 406, не желает контент отдавать. По всей видимости (я еще не проверял), ему требуется полный набор заголовков, а в стр.38 только 1 заголовок присутствует. А вот, скажем, Google вполне отдает контент главной страницы. А вот интересно, если сделать этим кодом запрос на какой-нибудь зараженный вирусами сайт - по идее, код вируса ведь должен прийти на ТСР-соединение вместе с html-кодом?
0
|
724 / 224 / 72
Регистрация: 01.03.2011
Сообщений: 629
|
|
09.02.2019, 15:23 | 20 |
Попробуйте поменять url на / и добавить Host: еще возможно оно хочет HTTP/1.1 тогда не помешает Connection: close
Да. Но скорее с каким-нибудь скриптом или картинкой.
1
|
09.02.2019, 15:23 | |
09.02.2019, 15:23 | |
Помогаю со студенческими работами здесь
20
Отправка запроса на сервер, и получение ответа Отправка POST запроса и получение ответа Отправка Post запроса на сайт и получение ответа Отправка запроса на сервер - получение ответа в xml и обработка Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |