Exemple C
Cette classe C illustre la création d’un jeton de synthèse à partir de trois paramètres d’entrée.
- strEncryptionMethod – répertorie la méthode de calcul de hachage (SHA1, SHA256 ou MD5)
- Message : répertorie la valeur à convertir en jeton de synthèse.
- sharedKey – répertorie la clé secrète
Remarque :
Utilisez un algorithme de hachage sécurisé plus fort comme SHA256 pour la génération de jetons de synthèse.
Cet exemple suppose que :
- Le serveur Web prend en charge C
- Un autre code appelle cette classe et transmet les paramètres attendus
Exemple de code
private stringdigestData(string strEncryptionMethod , string message , string sharedKey ) {
UnicodeEncoding myUnicodeEncoding = new UnicodeEncoding ( ) ;
byte [ ] messageBytes = System. Text. Encoding. ASCII. GetBytes (message ) ;
byte [ ] sharedKeyBytes = System. Text. Encoding. ASCII. GetBytes (sharedKey ) ;
byte [ ] hashedMessage ;
string b64SHA1Message ;
if (this. DEBUG ) {
TextBoxMessage. Text = message ;
TextBoxSecret. Text = sharedKey ; }
switch ( (strEncryptionMethod ) )
{ case "SHA1" :
HMACSHA1 hmacsha1 = new HMACSHA1 ( ) ;
hmacsha1. Key = sharedKeyBytes ;
hashedMessage = hmacsha1. ComputeHash (messageBytes ) ;
b64SHA1Message = Convert. ToBase64String (hashedMessage ) ; if (this. DEBUG ) TextBoxDigest. Text = Convert. ToString (hashedMessage ) ; break ;
case "MD5" :
HMACMD5 hmacmd5 = new HMACMD5 (sharedKeyBytes ) ;
hashedMessage = hmacmd5. ComputeHash (messageBytes ) ;
b64SHA1Message = Convert. ToBase64String (hashedMessage ) ; if (this. DEBUG ) TextBoxDigest. Text = Convert. ToString (hashedMessage ) ; break ;
default :
b64SHA1Message = "Unknown Encryption Method" ; break ;
}
TextBoxBase64. Text = b64SHA1Message ; return b64SHA1Message ;
}