Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
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


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...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
La NASA ha confermato il supporto per il...
Sierra Space ha completato il test acust...
Ryzen 7 5800X3D pronto a tornare sul mer...
NASA: l'amministrazione Trump prosegue s...
L'Iran avrebbe acquistato un satellite p...
VivaTech compie dieci anni e raddoppia p...
Le vendite di CPU si sono ridotte di 25 ...
Starship: SpaceX ha completato lo static...
Huawei FusionSolar Roadshow 2026: l'inno...
Nuovo trailer per Street Fighter: un fil...
Sovranità sui dati: arriva la pri...
Schede video NVIDIA e AMD di nuovo su Ma...
Robot aspirapolvere, TV OLED, iPhone 17 ...
EUREKA J15 Pro Ultra super interessante ...
Intel porta l'AI nei notebook entry-leve...
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: 06:20.


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