Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-05-2006, 09:45   #1
ermasto
Senior Member
 
L'Avatar di ermasto
 
Iscritto dal: Mar 2004
Messaggi: 581
[Java] Controllare Certificato .Pem

Ragazzi ho bisogno di un aiuto, ho dei certificati in formato pem rilasciati dalla mia CA ora devo fare un programmino java che riconosce la correttezza dei certificati se sono validi e se la firma è corretta ora c'è qualche programma java che prendendo un certificato .pem e ne veda la correttezza e l'integrità??

Grazie Mille
__________________
Toshiba M40-281
ermasto è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2006, 13:56   #2
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
devi scriverlo tu o vuoi qualcosa di già fatto?
con openssl puoi verificare i certificati con facilità.
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2006, 14:22   #3
ermasto
Senior Member
 
L'Avatar di ermasto
 
Iscritto dal: Mar 2004
Messaggi: 581
Quote:
Originariamente inviato da kingv
devi scriverlo tu o vuoi qualcosa di già fatto?
con openssl puoi verificare i certificati con facilità.
se c'è gia fatto è meglio questa verifica di certificato la devo implementare poi in un Web Service

Grazie Mille
__________________
Toshiba M40-281
ermasto è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2006, 17:52   #4
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
Quote:
Originariamente inviato da ermasto
se c'è gia fatto è meglio questa verifica di certificato la devo implementare poi in un Web Service
Grazie Mille


se vuoi puoi farlo da java con qualche riga di codice, se vuoi un programma già fatto:
openssl verify -CAfile certificatoca.pem certificatodaverificare.pem
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2006, 18:40   #5
ermasto
Senior Member
 
L'Avatar di ermasto
 
Iscritto dal: Mar 2004
Messaggi: 581
scusami non avevo capito bene, se possibile vorrei averlo in codice java che non sono riuscito a trovarlo su internet

Ti ringrazio
__________________
Toshiba M40-281
ermasto è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2006, 00:08   #6
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
ho dato un'occhiata alla documentazione, per leggerlo da un PEM di basta:

InputStream is = new FileInputStream("cert.pem");
X509Certificate cert = X509Certificate.getInstance(inStream);
is.close();

e per verificarlo:

X509Certificate cert, caCert;
try
{
cert.verify( caCert.getPublicKey());
return true;
} catch (GeneralSecurityException e)
{
return false;
}
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2006, 09:55   #7
ermasto
Senior Member
 
L'Avatar di ermasto
 
Iscritto dal: Mar 2004
Messaggi: 581
Grazie mille quindi questa prima parte

InputStream is = new FileInputStream("cert.pem");
X509Certificate cert = X509Certificate.getInstance(inStream);
is.close();

serve per leggere il certificato da locale quindi "cert.pem" ci devo passare il path del mio certificato?? e lo stesso se ci passo un .der???

Ho provato a fare girare questa parte superiore di codice almeno per leggeere il certificato ma il compilatore mi da un errore in inSream mi dice che non puo risolverlo.

X509Certificate cert, caCert;
try
{
cert.verify( caCert.getPublicKey());
return true;
} catch (GeneralSecurityException e)
{
return false;
}

questo serve per verificarlo ma come output che ci posso mettere??

questo metodo ritorna treu o false ma non lo devo racchiudere in un metodo boolean??
e l'ultima cosa che classi devo importare per far funzionare questo codice??

Grazie mille e scusami per le mille domande
__________________
Toshiba M40-281

Ultima modifica di ermasto : 17-05-2006 alle 11:18.
ermasto è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2006, 12:03   #8
ermasto
Senior Member
 
L'Avatar di ermasto
 
Iscritto dal: Mar 2004
Messaggi: 581
allora sono riuscito a far girare il codice con delle aggiunte eccolo qua:

Codice:
public static void main(String[] args) {

	  
	try
	{
	//------ Get the certificates issuer DN ------------------
	InputStream inStream = new FileInputStream("e:\\Prova.der");
	CertificateFactory cf = CertificateFactory.getInstance("X.509");
	X509Certificate cert = (X509Certificate)cf.generateCertificate(inStream);
	inStream.close();
	String subjectdn	= cert.getSubjectDN().getName();
	String issuerdn		= cert.getIssuerDN().getName() ;
	System.out.println();
	System.out.println("\nNome del Soggetto:\r\n" + subjectdn) ;
	System.out.println("\nNome del Emittente:\r\n" + issuerdn) ;

	//----- If this is a self-signed certificate, can verify signature immediately ---
	X509Certificate caCert = null;
		try
		{
		System.out.println();
		System.out.println("This is a self-signed certificate. Verifying signature ...") ;
		cert.verify(caCert.getPublicKey()) ;
		System.out.println("Signature verified") ;
		}
		catch(Exception exc)
		{
		 System.out.println("Failed to verify self-signed certificate");
		}				
	 return;
	
	}
ma il mio problema è che questo va bene per verificare un certificato firmato da me invece io ho bisogno di verificare questo certificato firmato dalla mia OpenCA non da me.

Qlc mi puo aiutare
__________________
Toshiba M40-281
ermasto è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2006, 13:01   #9
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
in caCert al posto di metterlo null carica il certificato della ca così come fai con il tuo e hai risolto.
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2006, 13:27   #10
ermasto
Senior Member
 
L'Avatar di ermasto
 
Iscritto dal: Mar 2004
Messaggi: 581
Ho capito ma in linea di massima io posseggo solo il certificato che mi ha dato la CA io con le informazioni che ho in questo certificato non posso verificare la firma??


Attraverso i vari campi che ci sono tipo: X509v3 Authority Key Identifier o Signature Algorithm o quant'altro

In effetti il codice postato prima era leggermte sbagliato:

Codice:
class CheckCert {

 
    public static void main(String[] args) {

	try
	{
	//------ Preleva Il Certificato ottiene qualche info e controlla se è nel periodo valido the------------------
	InputStream inStream = new FileInputStream("e:\\Prova.der");
	CertificateFactory cf = CertificateFactory.getInstance("X.509");
	X509Certificate cert = (X509Certificate)cf.generateCertificate(inStream);
	inStream.close();
	String subjectdn	= cert.getSubjectDN().getName();
	String issuerdn		= cert.getIssuerDN().getName() ;
	System.out.println();
	System.out.println("\nNome del Soggetto:\r\n" + subjectdn) ;
	System.out.println("\nNome del Emittente:\r\n" + issuerdn) ;
	cert.checkValidity();
	System.out.println("Il Certificato è Valido");
	//----- If this is a self-signed certificate, can verify signature immediately ---
	
		try
		{
		System.out.println();
		System.out.println("This is a self-signed certificate. Verifying signature ...") ;
		cert.verify(cert.getPublicKey()) ;
		System.out.println("Signature verified") ;
		}
		catch(Exception exc)
		{
		 System.out.println("Failed to verify self-signed certificate");
		}
		
	 return;
	
	}
	
	catch (Exception e)
	{
            System.err.println("Caught exception " + e.toString());
            System.err.println("Il certificato non è Valido!");   
	}
	
	}
}
Grazie mille x il prezioso aiuto
__________________
Toshiba M40-281
ermasto è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2006, 15:39   #11
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
modifica così il tuo codice (al posto di e:\\ca.der metti il path giusto):

Codice:
class CheckCert {

 
    public static void main(String[] args) {

	try
	{
	//------ Preleva Il Certificato ottiene qualche info e controlla se è nel periodo valido the------------------
	InputStream inStream = new FileInputStream("e:\\Prova.der");
	CertificateFactory cf = CertificateFactory.getInstance("X.509");
	X509Certificate cert = (X509Certificate)cf.generateCertificate(inStream);
	inStream.close();
	inStream = new FileInputStream("e:\\ca.der");
	X509Certificate caCert = (X509Certificate)cf.generateCertificate(inStream);
	inStream.close();
	String subjectdn	= cert.getSubjectDN().getName();
	String issuerdn		= cert.getIssuerDN().getName() ;
	System.out.println();
	System.out.println("\nNome del Soggetto:\r\n" + subjectdn) ;
	System.out.println("\nNome del Emittente:\r\n" + issuerdn) ;
	cert.checkValidity();
	System.out.println("Il Certificato è Valido");
	
		try
		{
		System.out.println();
		System.out.println("Verifying signature ...") ;
		cert.verify(caCert.getPublicKey()) ;
		System.out.println("Signature verified") ;
		}
		catch(Exception exc)
		{
		 System.out.println("Failed to verify certificate");
		}
		
	 return;
	
	}
	
	catch (Exception e)
	{
            System.err.println("Caught exception " + e.toString());
            System.err.println("Il certificato non è Valido!");   
	}
	
	}
}
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2006, 15:56   #12
ermasto
Senior Member
 
L'Avatar di ermasto
 
Iscritto dal: Mar 2004
Messaggi: 581
Ok grazie quindi per verificare la firma devo per forza avere il certificato della mia CA non si puo fare altrimenti??cioe senza certificato della CA??

quindi il metodo verify in definitiva cosa fa??

vediamo se ho capito bene:
si prende la chiave pubblica della mia ca e estrapola la sua chiave privata e controlla se il mio certificato è stato firmato con quella chiave giusto??

Mi stai salvando la vita

Grazie
__________________
Toshiba M40-281
ermasto è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2006, 16:31   #13
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
con la chiave pubblica della ca fai una verifica firma, ovvero ti accerti che chi ha emesso il certificato sia chi possiede la chiave associata al certificato della ca (cioè la CA stessa).

Ciao
kingv è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
SpaceX sta provando le piastrelle isolan...
Il National Reconnaissance Office statun...
Volkswagen avvia la produzione su CEA: c...
La crisi delle memorie non influenzer&ag...
MoM-z14 è la galassia scoperta da...
Da Sony nuovi display professionali dell...
Com'è fatta una delle e-bike pi&u...
iPhone 16 domina il 2025: ecco la classi...
Huawei a supporto delle startup: potenzi...
Iliad è il miglior operatore di l...
Le pompe di calore parlano italiano: Bon...
Moltbot non è solo un chatbot: ag...
Sinner e Alcaraz fermati dall'arbitro: i...
L'audio-video professionale arriva a MIR...
Musk fa i complimenti alla Cina: nel set...
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:25.


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