PC SOFT

DOCUMENTATION EN LIGNE
DE WINDEVWEBDEV ET WINDEV MOBILE

  • Notes
  • Fonction HashChaîne et UNICODE
  • Disponibilité des algorithmes
WINDEV
WindowsLinuxUniversal Windows 10 AppJavaEtats et RequêtesCode Utilisateur (MCU)
WEBDEV
WindowsLinuxPHPWEBDEV - Code Navigateur
WINDEV Mobile
AndroidWidget AndroidiPhone/iPadWidget IOSApple WatchMac CatalystUniversal Windows 10 App
Autres
Procédures stockées
Calcule le Hash d'une chaîne de caractères d'après un algorithme défini. Il est possible de calculer :
  • un hash simple.
  • un hash avec authentification de message.
  • Versions 27 et supérieures
    un hash obtenu par un algorithme de dérivation de clé qui prend en paramètre un sel (PBKDF2).
    WEBDEV - Code NavigateurPHP Non disponible.
    Nouveauté 27
    un hash obtenu par un algorithme de dérivation de clé qui prend en paramètre un sel (PBKDF2).
    WEBDEV - Code NavigateurPHP Non disponible.
    un hash obtenu par un algorithme de dérivation de clé qui prend en paramètre un sel (PBKDF2).
    WEBDEV - Code NavigateurPHP Non disponible.
Rappel : Le hachage permet de réaliser un résumé condensé d'un fichier ou d'une chaîne de caractères. Ce résumé est appelé Hash.
Versions 15 et supérieures
PHP Cette fonction est désormais disponible pour les sites PHP.
Nouveauté 15
PHP Cette fonction est désormais disponible pour les sites PHP.
PHP Cette fonction est désormais disponible pour les sites PHP.
Versions 25 et supérieures
WEBDEV - Code Navigateur Cette fonction est désormais disponible en code navigateur.
Nouveauté 25
WEBDEV - Code Navigateur Cette fonction est désormais disponible en code navigateur.
WEBDEV - Code Navigateur Cette fonction est désormais disponible en code navigateur.
WindowsLinuxPHP
// Calcul du Hash des valeurs de deux champs de saisie
Hash1 est un Buffer = HashChaîne(HA_MD5_128, SAI_Saisie1)
Hash2 est un Buffer = HashChaîne(HA_MD5_128, SAI_Saisie2)
// Comparaison des deux Hash
SI Hash1 = Hash2 ALORS Info("Les deux chaînes sont identiques.")
Versions 25 et supérieures
WEBDEV - Code Navigateur
HashChaîne(HA_SHA_160, "abc", HashChaîne_Callback)
 
PROCÉDURE INTERNE HashChaîne_Callback(buffer)
// Ce code permet de visualiser le buffer
Trace(BufferVersHexa(buffer))
FIN
Nouveauté 25
WEBDEV - Code Navigateur
HashChaîne(HA_SHA_160, "abc", HashChaîne_Callback)
 
PROCÉDURE INTERNE HashChaîne_Callback(buffer)
// Ce code permet de visualiser le buffer
Trace(BufferVersHexa(buffer))
FIN
WEBDEV - Code Navigateur
HashChaîne(HA_SHA_160, "abc", HashChaîne_Callback)
 
PROCÉDURE INTERNE HashChaîne_Callback(buffer)
// Ce code permet de visualiser le buffer
Trace(BufferVersHexa(buffer))
FIN
Syntaxe

Calculer un hash simple Masquer les détails

<Résultat> = HashChaîne(<Type d'algorithme> , <Chaîne>)
<Résultat> : Buffer
Résultat du hachage de la chaîne <Chaîne> avec l'algorithme <Type d'algorithme>.
Attention : ce résultat peut contenir des caractères non affichables. Si ce résultat doit être affiché, il peut être converti avec la fonction BufferVersHexa.
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme utilisé lors du hachage de la chaîne <Chaîne> :
Versions 22 et supérieures
Famille DJB2 (Bernstein)
Nouveauté 22
Famille DJB2 (Bernstein)
Famille DJB2 (Bernstein)
  • Versions 22 et supérieures
    HA_DJB2_32
    Nouveauté 22
    HA_DJB2_32
    HA_DJB2_32
  • Versions 22 et supérieures
    HA_DJB2_64
    Nouveauté 22
    HA_DJB2_64
    HA_DJB2_64
PHP Les constantes de cette famille ne sont pas disponibles.
Versions 25 et supérieures
Famille MD4
Nouveauté 25
Famille MD4
Famille MD4
Versions 25 et supérieures
HA_MD4
Nouveauté 25
HA_MD4
HA_MD4
Famille MD5HA_MD5_128
Versions 24 et supérieures
Famille MURMUR
Nouveauté 24
Famille MURMUR
Famille MURMUR
  • Versions 24 et supérieures
    HA_MURMUR_1 : Algorithme Murmur version 1 : hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_1 : Algorithme Murmur version 1 : hash résultat sur 32 bits
    HA_MURMUR_1 : Algorithme Murmur version 1 : hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_2 : Algorithme Murmur version 2 : hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_2 : Algorithme Murmur version 2 : hash résultat sur 32 bits
    HA_MURMUR_2 : Algorithme Murmur version 2 : hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_2_64A : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 64 bits
    Nouveauté 24
    HA_MURMUR_2_64A : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 64 bits
    HA_MURMUR_2_64A : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 64 bits
  • Versions 24 et supérieures
    HA_MURMUR_2_64B : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 32 bits
    Nouveauté 24
    HA_MURMUR_2_64B : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 32 bits
    HA_MURMUR_2_64B : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_2_A : Algorithme Murmur version 2 incrémentiel : hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_2_A : Algorithme Murmur version 2 incrémentiel : hash résultat sur 32 bits
    HA_MURMUR_2_A : Algorithme Murmur version 2 incrémentiel : hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_2_BIG_ENDIAN : Algorithme Murmur version 2 pour machine big-endian: hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_2_BIG_ENDIAN : Algorithme Murmur version 2 pour machine big-endian: hash résultat sur 32 bits
    HA_MURMUR_2_BIG_ENDIAN : Algorithme Murmur version 2 pour machine big-endian: hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_2_ALIGNE : Algorithme Murmur version 2 pour machine alignée : hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_2_ALIGNE : Algorithme Murmur version 2 pour machine alignée : hash résultat sur 32 bits
    HA_MURMUR_2_ALIGNE : Algorithme Murmur version 2 pour machine alignée : hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_3_32 : Algorithme Murmur version 3 : hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_3_32 : Algorithme Murmur version 3 : hash résultat sur 32 bits
    HA_MURMUR_3_32 : Algorithme Murmur version 3 : hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_3_128_X86 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 32 bits
    Nouveauté 24
    HA_MURMUR_3_128_X86 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 32 bits
    HA_MURMUR_3_128_X86 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_3_128_X64 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 64 bits
    Nouveauté 24
    HA_MURMUR_3_128_X64 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 64 bits
    HA_MURMUR_3_128_X64 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 64 bits

Versions 25 et supérieures
PHP Désormais disponible en PHP.
Nouveauté 25
PHP Désormais disponible en PHP.
PHP Désormais disponible en PHP.
Famille RIPEMD
  • HA_RIPEMD_128
  • HA_RIPEMD_160
Famille SHA
  • HA_SHA_160 (aussi appelé SHA-1)
  • HA_SHA_256 (spécifications FIPS PUB 198)
  • Versions 25 et supérieures
    HA_SHA_256_DOUBLE
    Nouveauté 25
    HA_SHA_256_DOUBLE
    HA_SHA_256_DOUBLE
  • HA_SHA_384
  • HA_SHA_512
Versions 23 et supérieures
Famille SHA-3
Nouveauté 23
Famille SHA-3
Famille SHA-3
  • Versions 23 et supérieures
    HA_SHA3_224
    Nouveauté 23
    HA_SHA3_224
    HA_SHA3_224
  • Versions 23 et supérieures
    HA_SHA3_256
    Nouveauté 23
    HA_SHA3_256
    HA_SHA3_256
  • Versions 23 et supérieures
    HA_SHA3_384
    Nouveauté 23
    HA_SHA3_384
    HA_SHA3_384
  • Versions 23 et supérieures
    HA_SHA3_512
    Nouveauté 23
    HA_SHA3_512
    HA_SHA3_512

Versions 25 et supérieures
PHP Désormais disponible en PHP.
Nouveauté 25
PHP Désormais disponible en PHP.
PHP Désormais disponible en PHP.
Famille TIGER
  • HA_TIGER_128
  • HA_TIGER_160
  • HA_TIGER_192
Famille WHIRLPOOLHA_WHIRLPOOL
Famille CKSUM
  • HA_CKSUM_8
  • HA_CKSUM_16
  • HA_CKSUM_32
  • HA_CKSUM_64
  • Algorithmes MD4 / MD5 / SHA / RIPEMD : fonctions de hachage cryptographiques classiques.
  • Algorithmes TIGER / WHIRLPOOL : fonctions de hachage ayant de très bonnes propriétés cryptographiques optimisées pour le 64 bits (mais leur utilisation est possible en 32 bits).
  • Algorithmes CKSUM : fonctions de hachage ne possédant pas de propriété cryptographique, à n'utiliser que pour des contrôles minimaux ou des tables de hachage.
  • Versions 22 et supérieures
    Algorithme DJB2 (Bernstein) : fonctions de hachage réservées aux chaînes et ne possédant pas de propriété cryptographique, à n'utiliser que pour des contrôles minimaux ou des tables de hachage. Peu de risques d'obtenir un hash identique.
    Nouveauté 22
    Algorithme DJB2 (Bernstein) : fonctions de hachage réservées aux chaînes et ne possédant pas de propriété cryptographique, à n'utiliser que pour des contrôles minimaux ou des tables de hachage. Peu de risques d'obtenir un hash identique.
    Algorithme DJB2 (Bernstein) : fonctions de hachage réservées aux chaînes et ne possédant pas de propriété cryptographique, à n'utiliser que pour des contrôles minimaux ou des tables de hachage. Peu de risques d'obtenir un hash identique.
  • Versions 24 et supérieures
    Algorithme MURMUR : fonctions de hachage très rapides et ne possédant pas de propriétés cryptographiques. C'est l'algorithme utilisé pour le "bloom filter" des portefeuilles bitcoin.
    Nouveauté 24
    Algorithme MURMUR : fonctions de hachage très rapides et ne possédant pas de propriétés cryptographiques. C'est l'algorithme utilisé pour le "bloom filter" des portefeuilles bitcoin.
    Algorithme MURMUR : fonctions de hachage très rapides et ne possédant pas de propriétés cryptographiques. C'est l'algorithme utilisé pour le "bloom filter" des portefeuilles bitcoin.
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
Versions 25 et supérieures
WEBDEV - Code Navigateur

Calculer un hash simple Masquer les détails

HashChaîne(<Type d'algorithme> , <Chaîne> , <Procédure WLangage>)
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme utilisé lors du hachage de la chaîne <Chaîne> :
Famille SHA
  • HA_SHA_160 (aussi appelé SHA-1)
  • HA_SHA_256 (spécifications FIPS PUB 198)
  • HA_SHA_256_DOUBLE
  • HA_SHA_384
  • HA_SHA_512

Remarques :
  • Ces algorithmes de hachage sont interdits sous Internet Explorer.
  • L'algorithme de hachage HA_SHA_160 est interdit sous Edge.
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
<Procédure WLangage> : Nom de procédure
Nom de la procédure WLangage (également nommée "callback") appelée lors du hachage. Cette procédure permet d'obtenir le résultat du hachage. Pour plus de détails, consultez Procédure utilisée par la fonction HashChaîne.
Nouveauté 25
WEBDEV - Code Navigateur

Calculer un hash simple Masquer les détails

HashChaîne(<Type d'algorithme> , <Chaîne> , <Procédure WLangage>)
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme utilisé lors du hachage de la chaîne <Chaîne> :
Famille SHA
  • HA_SHA_160 (aussi appelé SHA-1)
  • HA_SHA_256 (spécifications FIPS PUB 198)
  • HA_SHA_256_DOUBLE
  • HA_SHA_384
  • HA_SHA_512

Remarques :
  • Ces algorithmes de hachage sont interdits sous Internet Explorer.
  • L'algorithme de hachage HA_SHA_160 est interdit sous Edge.
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
<Procédure WLangage> : Nom de procédure
Nom de la procédure WLangage (également nommée "callback") appelée lors du hachage. Cette procédure permet d'obtenir le résultat du hachage. Pour plus de détails, consultez Procédure utilisée par la fonction HashChaîne.
WEBDEV - Code Navigateur

Calculer un hash simple Masquer les détails

HashChaîne(<Type d'algorithme> , <Chaîne> , <Procédure WLangage>)
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme utilisé lors du hachage de la chaîne <Chaîne> :
Famille SHA
  • HA_SHA_160 (aussi appelé SHA-1)
  • HA_SHA_256 (spécifications FIPS PUB 198)
  • HA_SHA_256_DOUBLE
  • HA_SHA_384
  • HA_SHA_512

Remarques :
  • Ces algorithmes de hachage sont interdits sous Internet Explorer.
  • L'algorithme de hachage HA_SHA_160 est interdit sous Edge.
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
<Procédure WLangage> : Nom de procédure
Nom de la procédure WLangage (également nommée "callback") appelée lors du hachage. Cette procédure permet d'obtenir le résultat du hachage. Pour plus de détails, consultez Procédure utilisée par la fonction HashChaîne.

Calculer un hash avec authentification de message (algorithme HMAC/algorithme MURMUR) Masquer les détails

<Résultat> = HashChaîne(<Type d'algorithme> , <Chaîne> , <Clé secrète>)
<Résultat> : Buffer
Résultat du hachage de la chaîne <Chaîne> avec l'algorithme <Type d'algorithme>. La longueur de cette chaîne dépend de l'algorithme utilisé. Par exemple, si la constante HA_HMAC_SHA_256 est utilisé, le résultat contiendra 32 octets.
Attention : ce résultat peut contenir des caractères non affichables.
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme (HMAC ou MURMUR) utilisé lors du hachage de la chaîne <Chaîne> :
Versions 25 et supérieures
Famille MD4
Nouveauté 25
Famille MD4
Famille MD4
Versions 25 et supérieures
HA_HMAC_MD4

Nouveauté 25
HA_HMAC_MD4

HA_HMAC_MD4

Famille MD5HA_HMAC_MD5_128
Versions 24 et supérieures
Famille MURMUR
Nouveauté 24
Famille MURMUR
Famille MURMUR
  • Versions 24 et supérieures
    HA_MURMUR_1 : Algorithme Murmur version 1 : hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_1 : Algorithme Murmur version 1 : hash résultat sur 32 bits
    HA_MURMUR_1 : Algorithme Murmur version 1 : hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_2 : Algorithme Murmur version 2 : hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_2 : Algorithme Murmur version 2 : hash résultat sur 32 bits
    HA_MURMUR_2 : Algorithme Murmur version 2 : hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_2_64A : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 64 bits
    Nouveauté 24
    HA_MURMUR_2_64A : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 64 bits
    HA_MURMUR_2_64A : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 64 bits
  • Versions 24 et supérieures
    HA_MURMUR_2_64B : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 32 bits
    Nouveauté 24
    HA_MURMUR_2_64B : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 32 bits
    HA_MURMUR_2_64B : Algorithme Murmur version 2 : hash résultat sur 64 bits optimisé pour processeurs 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_2_A : Algorithme Murmur version 2 incrémentiel : hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_2_A : Algorithme Murmur version 2 incrémentiel : hash résultat sur 32 bits
    HA_MURMUR_2_A : Algorithme Murmur version 2 incrémentiel : hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_2_BIG_ENDIAN : Algorithme Murmur version 2 pour machine big-endian: hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_2_BIG_ENDIAN : Algorithme Murmur version 2 pour machine big-endian: hash résultat sur 32 bits
    HA_MURMUR_2_BIG_ENDIAN : Algorithme Murmur version 2 pour machine big-endian: hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_2_ALIGNE : Algorithme Murmur version 2 pour machine alignée : hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_2_ALIGNE : Algorithme Murmur version 2 pour machine alignée : hash résultat sur 32 bits
    HA_MURMUR_2_ALIGNE : Algorithme Murmur version 2 pour machine alignée : hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_3_32 : Algorithme Murmur version 3 : hash résultat sur 32 bits
    Nouveauté 24
    HA_MURMUR_3_32 : Algorithme Murmur version 3 : hash résultat sur 32 bits
    HA_MURMUR_3_32 : Algorithme Murmur version 3 : hash résultat sur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_3_128_X86 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 32 bits
    Nouveauté 24
    HA_MURMUR_3_128_X86 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 32 bits
    HA_MURMUR_3_128_X86 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 32 bits
  • Versions 24 et supérieures
    HA_MURMUR_3_128_X64 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 64 bits
    Nouveauté 24
    HA_MURMUR_3_128_X64 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 64 bits
    HA_MURMUR_3_128_X64 : Algorithme Murmur version 3 : hash résultat sur 128 bits optimisé pour processeur 64 bits

Versions 25 et supérieures
PHP Désormais disponible en PHP.
Nouveauté 25
PHP Désormais disponible en PHP.
PHP Désormais disponible en PHP.
Famille RIPEMD
  • HA_HMAC_RIPEMD_128
  • HA_HMAC_RIPEMD_160
Famille SHA
  • HA_HMAC_SHA_160
  • HA_HMAC_SHA_256
  • Versions 25 et supérieures
    HA_HMAC_SHA_256_DOUBLE
    Nouveauté 25
    HA_HMAC_SHA_256_DOUBLE
    HA_HMAC_SHA_256_DOUBLE
  • HA_HMAC_SHA_384
  • HA_HMAC_SHA_512
Versions 23 et supérieures
Famille SHA-3
Nouveauté 23
Famille SHA-3
Famille SHA-3
  • Versions 23 et supérieures
    HA_HMAC_SHA3_224
    Nouveauté 23
    HA_HMAC_SHA3_224
    HA_HMAC_SHA3_224
  • Versions 23 et supérieures
    HA_HMAC_SHA3_256
    Nouveauté 23
    HA_HMAC_SHA3_256
    HA_HMAC_SHA3_256
  • Versions 23 et supérieures
    HA_HMAC_SHA3_384
    Nouveauté 23
    HA_HMAC_SHA3_384
    HA_HMAC_SHA3_384
  • Versions 23 et supérieures
    HA_HMAC_SHA3_512
    Nouveauté 23
    HA_HMAC_SHA3_512
    HA_HMAC_SHA3_512

Versions 25 et supérieures
PHP Désormais disponible en PHP.
Nouveauté 25
PHP Désormais disponible en PHP.
PHP Désormais disponible en PHP.
Famille TIGER
  • HA_HMAC_TIGER_128
  • HA_HMAC_TIGER_160
  • HA_HMAC_TIGER_192
Famille WHIRLPOOLHA_HMAC_WHIRLPOOL
  • Algorithmes MD4 / MD5 / SHA / RIPEMD : fonctions de hachage cryptographiques classiques.
  • Algorithmes TIGER / WHIRLPOOL : fonctions de hachage ayant de très bonnes propriétés cryptographiques optimisées pour le 64 bits (mais leur utilisation est possible en 32 bits).
    Algorithme MURMUR : fonctions de hachage très rapides et ne possédant pas de propriétés cryptographiques. C'est l'algorithme utilisé pour le "bloom filter" des portefeuilles bitcoin.
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
<Clé secrète> : Chaîne de caractères ou Entier
Clé d'authentification du message.
  • Si un algorithme HMAC est utilisé, ce paramètre doit être une chaîne.
  • Versions 24 et supérieures
    Si un algorithme MURMUR est utilisé, la clé doit être un entier.
    Nouveauté 24
    Si un algorithme MURMUR est utilisé, la clé doit être un entier.
    Si un algorithme MURMUR est utilisé, la clé doit être un entier.
Versions 25 et supérieures
WEBDEV - Code Navigateur

Calculer un hash avec authentification de message (algorithme HMAC) Masquer les détails

HashChaîne(<Type d'algorithme> , <Chaîne> , <Clé secrète> , <Procédure WLangage>)
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme (HMAC) utilisé lors du hachage de la chaîne <Chaîne> :
Famille SHA
  • HA_HMAC_SHA_160
  • HA_HMAC_SHA_256
  • HA_HMAC_SHA_384
  • HA_HMAC_SHA_512

Remarques :
  • Ces algorithmes de hachage sont interdits sous Internet Explorer.
  • Ces algorithmes de hachage sont interdits sous Edge.
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
<Clé secrète> : Chaîne de caractères
Clé d'authentification du message.
<Procédure WLangage> : Nom de procédure
Nom de la procédure WLangage (également nommée "callback") appelée lors du hachage. Cette procédure permet d'obtenir le résultat du hachage. Pour plus de détails, consultez Procédure utilisée par la fonction HashChaîne.
Nouveauté 25
WEBDEV - Code Navigateur

Calculer un hash avec authentification de message (algorithme HMAC) Masquer les détails

HashChaîne(<Type d'algorithme> , <Chaîne> , <Clé secrète> , <Procédure WLangage>)
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme (HMAC) utilisé lors du hachage de la chaîne <Chaîne> :
Famille SHA
  • HA_HMAC_SHA_160
  • HA_HMAC_SHA_256
  • HA_HMAC_SHA_384
  • HA_HMAC_SHA_512

Remarques :
  • Ces algorithmes de hachage sont interdits sous Internet Explorer.
  • Ces algorithmes de hachage sont interdits sous Edge.
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
<Clé secrète> : Chaîne de caractères
Clé d'authentification du message.
<Procédure WLangage> : Nom de procédure
Nom de la procédure WLangage (également nommée "callback") appelée lors du hachage. Cette procédure permet d'obtenir le résultat du hachage. Pour plus de détails, consultez Procédure utilisée par la fonction HashChaîne.
WEBDEV - Code Navigateur

Calculer un hash avec authentification de message (algorithme HMAC) Masquer les détails

HashChaîne(<Type d'algorithme> , <Chaîne> , <Clé secrète> , <Procédure WLangage>)
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme (HMAC) utilisé lors du hachage de la chaîne <Chaîne> :
Famille SHA
  • HA_HMAC_SHA_160
  • HA_HMAC_SHA_256
  • HA_HMAC_SHA_384
  • HA_HMAC_SHA_512

Remarques :
  • Ces algorithmes de hachage sont interdits sous Internet Explorer.
  • Ces algorithmes de hachage sont interdits sous Edge.
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
<Clé secrète> : Chaîne de caractères
Clé d'authentification du message.
<Procédure WLangage> : Nom de procédure
Nom de la procédure WLangage (également nommée "callback") appelée lors du hachage. Cette procédure permet d'obtenir le résultat du hachage. Pour plus de détails, consultez Procédure utilisée par la fonction HashChaîne.
Versions 27 et supérieures
WindowsLinux

Calculer un hash via un algorithme de dérivation de clé qui prend en paramètre un sel (PBKDF2) Masquer les détails

<Résultat> = HashChaîne(<Type d'algorithme> , <Chaîne> , <Sel> , <Itération> , <Longueur>)
<Résultat> : Buffer
Résultat du hachage de la chaîne <Chaîne> avec l'algorithme <Type d'algorithme>.
Attention : ce résultat peut contenir des caractères non affichables. Si ce résultat doit être affiché, il peut être converti avec la fonction BufferVersHexa.
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme pseudo-aléatoire utilisé par PBKDF2 lors du hachage de la chaîne <Chaîne> :
Famille MD4HA_PBKDF2_HMAC_MD4
Famille MD5HA_PBKDF2_HMAC_MD5_128
Famille RIPEMD
  • HA_PBKDF2_HMAC_RIPEMD_128
  • HA_PBKDF2_HMAC_RIPEMD_160
Famille SHA
  • HA_PBKDF2_HMAC_SHA_160
  • HA_PBKDF2_HMAC_SHA_256
  • HA_PBKDF2_HMAC_SHA_256_DOUBLE
  • HA_PBKDF2_HMAC_SHA_384
  • HA_PBKDF2_HMAC_SHA_512
Famille SHA-3
  • HA_PBKDF2_HMAC_SHA3_224
  • HA_PBKDF2_HMAC_SHA3_256
  • HA_PBKDF2_HMAC_SHA3_384
  • HA_PBKDF2_HMAC_SHA3_512
Famille TIGER
  • HA_PBKDF2_HMAC_TIGER_128
  • HA_PBKDF2_HMAC_TIGER_160
  • HA_PBKDF2_HMAC_TIGER_192
Famille WHIRLPOOLHA_PBKDF2_HMAC_WHIRLPOOL
  • Algorithmes MD4 / MD5 / SHA / RIPEMD : fonctions de hachage cryptographiques classiques.
  • Algorithmes TIGER / WHIRLPOOL : fonctions de hachage ayant de très bonnes propriétés cryptographiques optimisées pour le 64 bits (mais leur utilisation est possible en 32 bits).
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
<Sel> : Chaîne de caractères
Sel cryptographique utilisé. Chaîne, généralement aléatoire, ajoutée à la chaîne initiale pour modifier son empreinte. Par exemple, permet à deux utilisateurs d'avoir le même mot de passe.
<Itération> : Entier
Nombre d'itérations de l'algorithme (par défaut, 10000). Ce nombre dépend de la puissance de la machine de calcul et de la criticité du hachage. Un nombre minimum de 1000 itérations est en général recommandé.
<Longueur> : Entier
Longueur de la clé dérivée. Par défaut, correspond à la taille de la clé générée par l'algorithme pseudo-aléatoire. Cette longueur est techniquement non-bornée mais de par l'algorithme, elle est limitée à (2^32 – 1) * (la longueur des chaînes sorties par l'algorithme utilisé par PBKDF2).
Nouveauté 27
WindowsLinux

Calculer un hash via un algorithme de dérivation de clé qui prend en paramètre un sel (PBKDF2) Masquer les détails

<Résultat> = HashChaîne(<Type d'algorithme> , <Chaîne> , <Sel> , <Itération> , <Longueur>)
<Résultat> : Buffer
Résultat du hachage de la chaîne <Chaîne> avec l'algorithme <Type d'algorithme>.
Attention : ce résultat peut contenir des caractères non affichables. Si ce résultat doit être affiché, il peut être converti avec la fonction BufferVersHexa.
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme pseudo-aléatoire utilisé par PBKDF2 lors du hachage de la chaîne <Chaîne> :
Famille MD4HA_PBKDF2_HMAC_MD4
Famille MD5HA_PBKDF2_HMAC_MD5_128
Famille RIPEMD
  • HA_PBKDF2_HMAC_RIPEMD_128
  • HA_PBKDF2_HMAC_RIPEMD_160
Famille SHA
  • HA_PBKDF2_HMAC_SHA_160
  • HA_PBKDF2_HMAC_SHA_256
  • HA_PBKDF2_HMAC_SHA_256_DOUBLE
  • HA_PBKDF2_HMAC_SHA_384
  • HA_PBKDF2_HMAC_SHA_512
Famille SHA-3
  • HA_PBKDF2_HMAC_SHA3_224
  • HA_PBKDF2_HMAC_SHA3_256
  • HA_PBKDF2_HMAC_SHA3_384
  • HA_PBKDF2_HMAC_SHA3_512
Famille TIGER
  • HA_PBKDF2_HMAC_TIGER_128
  • HA_PBKDF2_HMAC_TIGER_160
  • HA_PBKDF2_HMAC_TIGER_192
Famille WHIRLPOOLHA_PBKDF2_HMAC_WHIRLPOOL
  • Algorithmes MD4 / MD5 / SHA / RIPEMD : fonctions de hachage cryptographiques classiques.
  • Algorithmes TIGER / WHIRLPOOL : fonctions de hachage ayant de très bonnes propriétés cryptographiques optimisées pour le 64 bits (mais leur utilisation est possible en 32 bits).
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
<Sel> : Chaîne de caractères
Sel cryptographique utilisé. Chaîne, généralement aléatoire, ajoutée à la chaîne initiale pour modifier son empreinte. Par exemple, permet à deux utilisateurs d'avoir le même mot de passe.
<Itération> : Entier
Nombre d'itérations de l'algorithme (par défaut, 10000). Ce nombre dépend de la puissance de la machine de calcul et de la criticité du hachage. Un nombre minimum de 1000 itérations est en général recommandé.
<Longueur> : Entier
Longueur de la clé dérivée. Par défaut, correspond à la taille de la clé générée par l'algorithme pseudo-aléatoire. Cette longueur est techniquement non-bornée mais de par l'algorithme, elle est limitée à (2^32 – 1) * (la longueur des chaînes sorties par l'algorithme utilisé par PBKDF2).
WindowsLinux

Calculer un hash via un algorithme de dérivation de clé qui prend en paramètre un sel (PBKDF2) Masquer les détails

<Résultat> = HashChaîne(<Type d'algorithme> , <Chaîne> , <Sel> , <Itération> , <Longueur>)
<Résultat> : Buffer
Résultat du hachage de la chaîne <Chaîne> avec l'algorithme <Type d'algorithme>.
Attention : ce résultat peut contenir des caractères non affichables. Si ce résultat doit être affiché, il peut être converti avec la fonction BufferVersHexa.
<Type d'algorithme> : Constante de type Entier
Indique le type d'algorithme pseudo-aléatoire utilisé par PBKDF2 lors du hachage de la chaîne <Chaîne> :
Famille MD4HA_PBKDF2_HMAC_MD4
Famille MD5HA_PBKDF2_HMAC_MD5_128
Famille RIPEMD
  • HA_PBKDF2_HMAC_RIPEMD_128
  • HA_PBKDF2_HMAC_RIPEMD_160
Famille SHA
  • HA_PBKDF2_HMAC_SHA_160
  • HA_PBKDF2_HMAC_SHA_256
  • HA_PBKDF2_HMAC_SHA_256_DOUBLE
  • HA_PBKDF2_HMAC_SHA_384
  • HA_PBKDF2_HMAC_SHA_512
Famille SHA-3
  • HA_PBKDF2_HMAC_SHA3_224
  • HA_PBKDF2_HMAC_SHA3_256
  • HA_PBKDF2_HMAC_SHA3_384
  • HA_PBKDF2_HMAC_SHA3_512
Famille TIGER
  • HA_PBKDF2_HMAC_TIGER_128
  • HA_PBKDF2_HMAC_TIGER_160
  • HA_PBKDF2_HMAC_TIGER_192
Famille WHIRLPOOLHA_PBKDF2_HMAC_WHIRLPOOL
  • Algorithmes MD4 / MD5 / SHA / RIPEMD : fonctions de hachage cryptographiques classiques.
  • Algorithmes TIGER / WHIRLPOOL : fonctions de hachage ayant de très bonnes propriétés cryptographiques optimisées pour le 64 bits (mais leur utilisation est possible en 32 bits).
<Chaîne> : Chaîne de caractères
Chaîne sur laquelle sera effectuée le calcul. Ce paramètre peut contenir des caractères binaires.
<Sel> : Chaîne de caractères
Sel cryptographique utilisé. Chaîne, généralement aléatoire, ajoutée à la chaîne initiale pour modifier son empreinte. Par exemple, permet à deux utilisateurs d'avoir le même mot de passe.
<Itération> : Entier
Nombre d'itérations de l'algorithme (par défaut, 10000). Ce nombre dépend de la puissance de la machine de calcul et de la criticité du hachage. Un nombre minimum de 1000 itérations est en général recommandé.
<Longueur> : Entier
Longueur de la clé dérivée. Par défaut, correspond à la taille de la clé générée par l'algorithme pseudo-aléatoire. Cette longueur est techniquement non-bornée mais de par l'algorithme, elle est limitée à (2^32 – 1) * (la longueur des chaînes sorties par l'algorithme utilisé par PBKDF2).
Remarques

Notes

  • Deux chaînes de caractères identiques auront, pour un même type d'algorithme, deux Hash identiques.
  • Le résultat du Hash peut contenir des caractères non affichables. Ces caractères ne pourront pas être vus lors de l'utilisation par exemple des fonctions Info ou Trace.

Fonction HashChaîne et UNICODE

  • Attention : Les fonctions de Hachage agissent au niveau des octets des chaînes de caractères. Le résultat pour un même type d'algorithme sera donc différent en UNICODE et en ANSI.
  • Développement multi-plateforme : Pour utiliser des Hash de chaînes entre plusieurs plateformes (par exemple un hash généré en iOS et vérifié en Android ou sur Windows), il ne faut pas utiliser des chaînes Unicode. En effet, les chaînes Unicode n'ont pas le même format selon les plate-formes. Dans ce cas, il est conseillé d'utiliser des chaînes au format ANSI ou UTF 8 (et de convertir les chaînes Unicode si nécessaire).
PHP

Disponibilité des algorithmes

PHP Les algorithmes disponibles dépendent de la configuration du serveur PHP (présence de l'extension 'mhash', version 5 de PHP avec sa fonction native hash, etc).
Liste des exemples associés :
Les fonctions de Hashage Exemples unitaires (WINDEV) : Les fonctions de Hashage
[ + ] Utilisation des fonctions de hashage.
Les fonctions HashFichier et HashChaîne permettent de calculer une clé de Hashage pour une chaîne ou pour un fichier.
Cette clé de Hashage permet par exemple de :
- Vérifier que le fichier est intègre suite à un transfert par exemple
- Rechercher des doublons de fichiers
- ...
Classification Métier / UI : Code métier
Composante : wd270com.dll
Version minimum requise
  • Version 11
Documentation également disponible pour…
Commentaires
Cliquez sur [Ajouter] pour publier un commentaire