Так что я хочу просто -Я люблю openSSL api. Я нашел simple code to begin with для изучения этого. Я совершенно новичок в создании сервера. Интересно, как заставить OpenSSL работать с простым http вместо https? Я имею в виду, что я хочу предоставить тот же сервис, быть в состоянии прыгать в https, когда мне нужно, но не имеет защиты от http.Как заставить OpenSSL использовать http вместо https?
Я имею в виду это так тереть просто сказать
SSLServer server("cert", "pkey", 1420);
// Set the thread function.
server.SetPthread_F(conn_thread);
Я хотел бы сделать то же самое для не защищенного создания службы HTTP.
После некоторых решетчатых ответов я понял, я буду редактировать главный вопрос:
Как сохранить/использовать только неблокируемому TCP серверную часть библиотеки OpenSSL? Основной целью было бы кроссплатформенная небольшой и простой в использовании TCP сервера, на вершине которой он будет Eazy реализовать HTTP и HTTP costumized аналоги
Таким образом, если мы посмотрим на пример:
#include <openssl/ssl.h>
#include <openssl/err.h>
#include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
#include "sslserver.h"
#define REPLY "<html><body>Metalshell.com OpenSSL Server</body></html>"
#define MAX_PACKET_SIZE 1024
// Called when a new connection is made.
void *conn_thread(void *ssl) {
int fd = SSL_get_fd((SSL *)ssl);
if(SSL_accept((SSL *)ssl) == -1) {
ERR_print_errors_fp(stderr);
} else {
char cipdesc[128];
SSL_CIPHER *sslciph = SSL_get_current_cipher((SSL *)ssl);
cout << "Encryption Description:\n";
cout << SSL_CIPHER_description(sslciph, cipdesc, sizeof(cipdesc)) << endl;
char buff[MAX_PACKET_SIZE];
// Wait for data to be sent.
int bytes = SSL_read((SSL *)ssl, buff, sizeof(buff));
buff[bytes] = '\0';
// Show the browser request.
cout << "Recieved: \n" << buff << endl;
// Send the html reply.
SSL_write((SSL *)ssl, REPLY, strlen(REPLY));
}
// Tell the client we are closing the connection.
SSL_shutdown((SSL *)ssl);
// We do not wait for a reply, just clear everything.
SSL_free((SSL *)ssl);
close(fd);
cout << "Connection Closed\n";
cout << "---------------------------------------------\n";
pthread_exit(NULL);
}
int main() {
SSLServer server("cert", "pkey", 1420);
// Set the thread function.
server.SetPthread_F(conn_thread);
while(1) {
/* Wait for 10 seconds, and if no one trys
* to connect return back. This allows us to do
* other things while waiting.
*/
server.CheckClients(10);
}
return 0;
}
Что должно быть изменено на наш сервер принимают все подключения не только ssl (cout полный запрос, если это возможно) и отправить их REPLY?
Это звучит как вопрос для ServerFault. – robert