Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-02-2009, 10:38   #1
Energy++
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 1059
[Win32][C#] CryptoAPI - Usare CryptEncrypt

salve ragazzi, ho questo codice che permette di decifrare un file o dei dati utilizzando le cryptoAPI:

Codice:
    [DllImport("advapi32.dll", CharSet = CharSet.Auto)]
    private static extern bool CryptAcquireContext(out IntPtr hProv, string pszContainer, string pszProvider, uint dwProvType, uint dwFlags);
    [DllImport("advapi32.dll", CharSet = CharSet.Auto)]
    private static extern bool CryptCreateHash(IntPtr hProv, uint Algid, IntPtr hKey, uint dwFlags, out IntPtr phHash);
    [DllImport("advapi32.dll", CharSet = CharSet.Auto)]
    private static extern bool CryptHashData(IntPtr hHash, byte[] pbData, uint dwDataLen, uint dwFlags);
    [DllImport("advapi32.dll", CharSet = CharSet.Auto)]
    private static extern bool CryptDeriveKey(IntPtr hProv, uint Algid, IntPtr hBaseData, uint dwFlags, out IntPtr phKey);
    [DllImport("advapi32.dll", CharSet = CharSet.Auto)]
    private static extern bool CryptDecrypt(IntPtr hKey, IntPtr hHash, bool Final, uint dwFlags, byte[] pbData, ref uint pdwDataLen);
    [DllImport("advapi32.dll", CharSet = CharSet.Auto)]
    private static extern bool CryptEncrypt(IntPtr hKey, IntPtr hHash, bool Final, uint dwFlags, byte[] pbData, ref uint pdwDataLen);
    [DllImport("advapi32.dll", CharSet = CharSet.Auto)]
    private static extern bool CryptDestroyKey(IntPtr hKey);
    [DllImport("advapi32.dll", CharSet = CharSet.Auto)]
    private static extern bool CryptDestroyHash(IntPtr hHash);
    [DllImport("advapi32.dll", CharSet = CharSet.Auto)]
    private static extern bool CryptReleaseContext(IntPtr hProv, uint dwFlags);

    private const uint PROV_RSA_AES = 24;
    private const uint CALG_SHA1 = 0x8004;
    private const uint CALG_AES_128 = 0x660E;
    private const uint CRYPT_EXPORTABLE = 1;

    private const long E_FAIL = 0x80004005;
    private IntPtr m_hProvider;
    private IntPtr m_hHash;
    private IntPtr m_hKey;

    private void ReleaseKey()
    {
        if (m_hKey != IntPtr.Zero)
            CryptDestroyKey(m_hKey);

        if (m_hHash != IntPtr.Zero)
            CryptDestroyHash(m_hHash);

        if (m_hProvider != IntPtr.Zero)
            CryptReleaseContext(m_hProvider, 0);
    }

    private long UpdateKey(string szKey)
    {
        if (szKey.Length != 16)
            return E_FAIL;

        ReleaseKey();

        szKey = szKey.ToLower();
        uint length = (uint)Encoding.Unicode.GetBytes(szKey).Length;
        if (!CryptAcquireContext(out m_hProvider, null, null, PROV_RSA_AES, 0))
        {
            if (!CryptAcquireContext(out m_hProvider, null, null, PROV_RSA_AES, 8))
                return E_FAIL;
        }

        if (CryptCreateHash(m_hProvider, CALG_SHA1, IntPtr.Zero, 0, out m_hHash))
            if (CryptHashData(m_hHash, Encoding.Unicode.GetBytes(szKey), length, 0))
                if (CryptDeriveKey(m_hProvider, CALG_AES_128, m_hHash, CRYPT_EXPORTABLE, out m_hKey))
                    return 0;

        return E_FAIL;
    }

    public long Decrypt(string szKey, byte[] pData, Stream result)
    {
        long lResult = UpdateKey(szKey);
        if (lResult != 0)
            return lResult;

        uint dwSize = (uint)pData.Length;
        if (CryptDecrypt(m_hKey, IntPtr.Zero, true, 0, pData, ref dwSize))
        {
            result.Write(pData, 0, (int)dwSize);
            return 0;
        }

        return lResult;
    }
ora io non sono molto esperto di win32 e questo codice che ho trovato è un pò criptico per me, ma a quanto ho capito inizializza il provider per la crittografia asimmetrica rsa e con la chiave pubblica passata al metodo Decrypt recupera quella privata e decifra i dati...

ora io avrei bisogno di crittografare nuovamente i dati però utilizzando una chiave pubblica diversa...

c'è qualcuno che può indirizzarmi verso il procedimento esatto?

Ultima modifica di Energy++ : 24-02-2009 alle 10:40.
Energy++ è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2009, 12:21   #2
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
scusa se non rispondo alla tua domanda, ma come mai usi le CryptoAPI anziché l'apposito namespace System.Security.Cryptography di .NET?
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2009, 12:45   #3
Energy++
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 1059
ho provato ad utilizzare la classe RSACryptoServiceProvider, ma non riesco a capire come procedere per recuperare la chiave privata...

potresti aiutarmi magari traducendo quel codice in modo che utilizzi RSACryptoServiceProvider?

come faccio a recuperare la chiave privata? come faccio a specificare il contenitore dove si trova la chiave?


quel codice di sopra non l'ho scritto io, quindi non so esattamente come arriva allo scopo...

Ultima modifica di Energy++ : 24-02-2009 alle 12:59.
Energy++ è offline   Rispondi citando il messaggio o parte di esso
Old 25-02-2009, 20:09   #4
Energy++
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 1059
up
Energy++ è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Hyundai: spunta un'elettrica estremament...
Una connessione diretta con AWS European...
La Toyota Yaris avrà una versione...
Minori sessualizzati da Grok: l'UE mette...
NIO stabilisce il nuovo record di scambi...
Dell Private Cloud sempre più ape...
Ennesimo incidente per la guida autonoma...
Dopo le maniglie, è il turno dei ...
Addio incendi incontrollati? Svolt dice ...
WINDTRE si mette in proprio: vender&agra...
The Mandalorian & Grogu: il trailer ...
OpenClaw sotto attacco: i malware infost...
Resident Evil Requiem: pre-load dal 25 f...
Vaticano, la Messa si traduce in 60 ling...
Kia prepara il facelift della Kia EV5: n...
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: 21:41.


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