Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-09-2014, 18:30   #1
Nagashi890
Junior Member
 
Iscritto dal: Nov 2010
Messaggi: 11
[C] Aiuto librerie OpenSSL

Ciao a tutti..
devo usare le librerie OpenSSL in C per proteggere la comunicazione tra un client e un server
utilizzando l'algoritmo RSA, ma il programma non funziona e non so più dove sbattere la testa..

questo è il codice del client che cripta una stringa con la funzione encryptString()

Codice:
#include <openssl/rsa.h>
#include <openssl/rand.h>
#include <openssl/pem.h>
#include <openssl/evp.h>

int encryptString(char* string, char* dataout, char* filename, RSA* rsa) {

	int size;
	char file_pem_pub[36];
	strcpy(file_pem_pub, filename);
	FILE* fp;

	fp = fopen(file_pem_pub, "r");    //file che contiene la chiave creata in precedenza

	rsa = PEM_read_RSAPublicKey(fp, &rsa, NULL, NULL);
	
	RSA_public_encrypt(strlen(string), string, dataout, rsa, RSA_PKCS1_PADDING);
	
	size = strlen(dataout);
	
	fclose(fp);
	
	return size;
}

int main() {
	
	int rsa_size;
	int ret;
	char* dataout;     //buffer che deve contenere il messaggio criptato
        //char* message = <stringa da criptare>

	OpenSSL_add_all_algorithms();
	RSA* rsa = RSA_new();

	rsa_size = RSA_size(rsa);

	dataout = malloc(rsa_size);

	memset(dataout, 0, sizeof(dataout));
	ret = encryptString(message, dataout, "spub.pem", rsa);
	RSA_free(rsa);
}
Il programma dà errore di segmentazione quando esegue la funzione RSA_size()
non so più che correzioni fare.. spero che qualcuno mi possa aiutare.

Grazie!
Nagashi890 è offline   Rispondi citando il messaggio o parte di esso
Old 06-09-2014, 11:43   #2
Nagashi890
Junior Member
 
Iscritto dal: Nov 2010
Messaggi: 11
Allora.. ho risolto l'errore di segmentazione togliendo la funzione encryptString e mettendo tutto nel main..

Ora però il problema è che il server non decripta, e la funzione RSA_private_decrypt() restituisce -1

riporto il codice del server e del client saltando tutto il codice relativo alla creazione dei socket.

Codice:
//Client

        generate_RSA_keys("cpub.pem", "cpriv.pem");

	printf("Inserisci il tuo nome: ");
	fflush(stdout);

	scanf("%s", nome);

	//RSA ALGORITHM

	// Context allocation
	OpenSSL_add_all_algorithms();
	RSA* rsa = RSA_new();

	//Encryption
	FILE* fp;
	fp = fopen("spub.pem", "r");

	rsa = PEM_read_RSAPublicKey(fp, &rsa, NULL, NULL);
	rsa_size = RSA_size(rsa);
	
	cnome = (char*)malloc(rsa_size);
	memset(cnome, 0 , sizeof(cnome));
	
	nlen = strlen(nome);
	RSA_public_encrypt(nlen, nome, cnome, rsa, RSA_PKCS1_PADDING);

	//Context deallocation
	RSA_free(rsa);
	fclose(fp);

	int c_len = strlen(cnome);
	ret = send(sk, (void*)cnome, c_len+1, 0);
Codice:
//Server

        generate_RSA_keys("spub.pem", "spriv.pem");	

	ret = recv(c_sk, (void*)cnome, sizeof(cnome), 0);

	//RSA ALGORITHM
	//Context allocation
	OpenSSL_add_all_algorithms();
	RSA* rsa = RSA_new();
	
	FILE* fp;
	fp = fopen("spriv.pem", "r");

	//Decryption
	rsa = PEM_read_RSAPrivateKey(fp, &rsa, NULL, NULL);
	
	rsa_size = RSA_size(rsa);
	
	nome = (char*)malloc(rsa_size);
	memset(nome, 0, sizeof(nome));
	c_len = strlen(cnome);
	n = RSA_private_decrypt(rsa_size, cnome, nome, rsa, RSA_PKCS1_PADDING);
	
	//Context deallocation
	RSA_free(rsa);
	fclose(fp);
Questa è la funzione generate_RSA_keys()

Codice:
void generate_RSA_keys(char* public, char* private) {
	
	char file_pem[strlen(private)];
	char file_pem_pub[strlen(public)];
	strcpy(file_pem, private);
	strcpy(file_pem_pub, public);
	FILE *fp;

	int bits = 1024;
	unsigned long exp = RSA_F4;
	RSA *rsa;
	rsa = RSA_generate_key(bits,exp,NULL,NULL);

	fp = fopen(file_pem, "w");
	unsigned char *kstr = "pass";
	PEM_write_RSAPrivateKey(fp,rsa,EVP_des_ede3_cbc(),kstr,strlen(kstr),NULL,NULL);
	fclose(fp);
	fp = fopen(file_pem_pub, "w");
	PEM_write_RSAPublicKey(fp, rsa);
	fclose(fp);
	RSA_free(rsa);
	
}
La stringa criptata viene ricevuta correttamente dal server.. ma poi non viene decriptata..
Ho visto però che a volte funziona, altre volte dà questo errore:

Codice:
error:0407106B:rsa routines:RSA_padding_check_PKCS1_type_2:block type is not 02

Ultima modifica di Nagashi890 : 06-09-2014 alle 11:51.
Nagashi890 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
TV TCL QLED da 65 pollici a 491€ su Amaz...
Windows 11, l'aggiornamento di aprile è ...
Niente iPhone 18 base nel 2026? Ecco la ...
Tinder introduce la scansione dell'iride...
Google sta per aggiungere luci colorate ...
PS6 potrebbe offrire prestazioni tre vol...
SK hynix ha avviato la produzione di mod...
Microsoft non ha pace sul Menu Start di ...
Cinque robot aspirapolvere e lavapavimen...
De'Longhi Tasciugo AriaDry: il deumidifi...
Robot più veloci dell'uomo: la me...
Palantir-manifesto, tra tecnologia e ide...
Classifica Amazon top 10 sconvolta: nuov...
DRAM, domanda fuori controllo: produzion...
HUDIMM e HSODIMM: la risposta dell'indus...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 10:26.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v