Maison développement back-end tutoriel php 用PHP写的MD5加密函数_PHP

用PHP写的MD5加密函数_PHP

Jun 01, 2016 pm 12:34 PM
intval 函数 加密

用PHP写的MD5加密函数

//php_md5("字符串")
define("BITS_TO_A_BYTE",8);
define("BYTES_TO_A_WORD",4);
define("BITS_TO_A_WORD",32);
$m_lOnBits=array(30);
$m_l2Power=array(30);

function LShift($lValue,$iShiftBits)
{
        if ($iShiftBits==0) return $lValue;
        if ($iShiftBits==31)
        {
                if ($lValue&1) { return 0x80000000; }
                else { return 0; }
        }
        if ($iShiftBits 31) { }
        if (($lValue&$GLOBALS[31-$iShiftBits]))
        {        $tmpstr=(($lValue&$GLOBALS[31-($iShiftBits+1)])*$GLOBALS[$iShiftBits])|0x80000000; }
        else
        { $tmpstr=(($lValue&$GLOBALS[31-$iShiftBits])*$GLOBALS[$iShiftBits]); }
        return $tmpstr;
}

function RShift($lValue,$iShiftBits)
{
        if ($iShiftBits==0)return $lValue;
        if ($iShiftBits==31)
        {
                if ($lValue&0x80000000) { return 1; }
                else { return 0; }
        }
        if ($iShiftBits31) { }
        $tmpstr=floor(($lValue&0x7FFFFFFE)/$GLOBALS[$iShiftBits]);
        if ($lValue&0x80000000) { $tmpstr=$tmpstr|floor(0x40000000/$GLOBALS[$iShiftBits-1]); }
        return $tmpstr;
}

function RotateLeft($lValue,$iShiftBits)
{
        return LShift($lValue,$iShiftBits)|RShift($lValue,(32-$iShiftBits));
}

function AddUnsigned($lX,$lY)
{
        $lX8=$lX&0x80000000;
        $lY8=$lY&0x80000000;
        $lX4=$lX&0x40000000;
        $lY4=$lY&0x40000000;
        $lResult=($lX&0x3FFFFFFF)+($lY&0x3FFFFFFF);

        if ($lX4&$lY4) { $lResult=$lResult^0x80000000^$lX8^$lY8; }
        if ($lX4|$lY4)
        {
                if ($lResult&0x40000000)
                { $lResult=$lResult^0xC0000000^$lX8^$lY8; }
                else
                { $lResult=$lResult^0x40000000^$lX8^$lY8; }
        }
        else
        { $lResult=$lResult^$lX8^$lY8; }
        return $lResult;
}

function md5_F($x,$y,$z)
{
        return ($x&$y)|((~$x)&$z);
}

function md5_G($x,$y,$z)
{
        return ($x&$z)|($y&(~$z));
}

function md5_H($x,$y,$z)
{
        return ($x^$y^$z);
}

function md5_I($x,$y,$z)
{
        return ($y^($x|(~$z)));
}

function md5_FF(&$a,$b,$c,$d,$x,$s,$ac)
{
        $a=AddUnsigned($a,AddUnsigned(AddUnsigned(md5_F($b,$c,$d),$x),$ac));
        $a=RotateLeft($a,$s);
        $a=AddUnsigned($a,$b);
}

function md5_GG(&$a,$b,$c,$d,$x,$s,$ac)
{
        $a=AddUnsigned($a,AddUnsigned(AddUnsigned(md5_G($b,$c,$d),$x),$ac));
        $a=RotateLeft($a,$s);
        $a=AddUnsigned($a,$b);
}

function md5_HH(&$a,$b,$c,$d,$x,$s,$ac)
{
        $a=AddUnsigned($a,AddUnsigned(AddUnsigned(md5_H($b,$c,$d),$x),$ac));
        $a=RotateLeft($a,$s);
        $a=AddUnsigned($a,$b);
}

function md5_II(&$a,$b,$c,$d,$x,$s,$ac)
{
        $a=AddUnsigned($a,AddUnsigned(AddUnsigned(md5_I($b,$c,$d),$x),$ac));
        $a=RotateLeft($a,$s);
        $a=AddUnsigned($a,$b);
}

function ConvertToWordArray($sMessage)
{
        $lWordArray=array();
        $MODULUS_BITS=512;
        $CONGRUENT_BITS=448;
        $lMessageLength=strlen($sMessage);
        $lNumberOfWords=(floor(($lMessageLength+floor(($MODULUS_BITS-$CONGRUENT_BITS)/BITS_TO_A_BYTE))/floor($MODULUS_BITS/BITS_TO_A_BYTE))+1)*floor($MODULUS_BITS/BITS_TO_A_WORD);
        $lBytePosition=0;
        $lByteCount=0;
        while(!($lByteCount>=$lMessageLength))
        {
                $lWordCount=floor($lByteCount/BYTES_TO_A_WORD);
                $lBytePosition=($lByteCount%BYTES_TO_A_WORD)*BITS_TO_A_BYTE;
                $lWordArray[$lWordCount]=$lWordArray[$lWordCount]|LShift(ord(substr($sMessage,$lByteCount+1-1,1)),$lBytePosition);
                $lByteCount=$lByteCount+1;
        }
        $lWordCount=floor($lByteCount/BYTES_TO_A_WORD);
        $lBytePosition=($lByteCount%BYTES_TO_A_WORD)*BITS_TO_A_BYTE;
        $lWordArray[$lWordCount]=$lWordArray[$lWordCount]|LShift(0x80,$lBytePosition);
        $lWordArray[$lNumberOfWords-2]=LShift($lMessageLength,3);
        $lWordArray[$lNumberOfWords-1]=RShift($lMessageLength,29);
        return $lWordArray;
}

function WordToHex($lValue)
{
        $tmpstr="";
        for ($lCount=0; $lCount        {
                $lByte=RShift($lValue,$lCount*BITS_TO_A_BYTE)&$GLOBALS[BITS_TO_A_BYTE-1];
                $tmpstr=$tmpstr.(substr("0".dechex($lByte),strlen("0".dechex($lByte))-2));//这行可能有问题
        }
        return $tmpstr;
}
function php_MD5($sMessage)
{
        $GLOBALS[0]=intval(1);
        $GLOBALS[1]=intval(3);
        $GLOBALS[2]=intval(7);
        $GLOBALS[3]=intval(15);
        $GLOBALS[4]=intval(31);
        $GLOBALS[5]=intval(63);
        $GLOBALS[6]=intval(127);
        $GLOBALS[7]=intval(255);
        $GLOBALS[8]=intval(511);
        $GLOBALS[9]=intval(1023);
        $GLOBALS[10]=intval(2047);
        $GLOBALS[11]=intval(4095);
        $GLOBALS[12]=intval(8191);
        $GLOBALS[13]=intval(16383);
        $GLOBALS[14]=intval(32767);
        $GLOBALS[15]=intval(65535);
        $GLOBALS[16]=intval(131071);
        $GLOBALS[17]=intval(262143);
        $GLOBALS[18]=intval(524287);
        $GLOBALS[19]=intval(1048575);
        $GLOBALS[20]=intval(2097151);
        $GLOBALS[21]=intval(4194303);
        $GLOBALS[22]=intval(8388607);
        $GLOBALS[23]=intval(16777215);
        $GLOBALS[24]=intval(33554431);
        $GLOBALS[25]=intval(67108863);
        $GLOBALS[26]=intval(134217727);
        $GLOBALS[27]=intval(268435455);
        $GLOBALS[28]=intval(536870911);
        $GLOBALS[29]=intval(1073741823);
        $GLOBALS[30]=intval(2147483647);

        $GLOBALS[0]=intval(1);
        $GLOBALS[1]=intval(2);
        $GLOBALS[2]=intval(4);
        $GLOBALS[3]=intval(8);
        $GLOBALS[4]=intval(16);
        $GLOBALS[5]=intval(32);
        $GLOBALS[6]=intval(64);
        $GLOBALS[7]=intval(128);
        $GLOBALS[8]=intval(256);
        $GLOBALS[9]=intval(512);
        $GLOBALS[10]=intval(1024);
        $GLOBALS[11]=intval(2048);
        $GLOBALS[12]=intval(4096);
        $GLOBALS[13]=intval(8192);
        $GLOBALS[14]=intval(16384);
        $GLOBALS[15]=intval(32768);
        $GLOBALS[16]=intval(65536);
        $GLOBALS[17]=intval(131072);
        $GLOBALS[18]=intval(262144);
        $GLOBALS[19]=intval(524288);
        $GLOBALS[20]=intval(1048576);
        $GLOBALS[21]=intval(2097152);
        $GLOBALS[22]=intval(4194304);
        $GLOBALS[23]=intval(8388608);
        $GLOBALS[24]=intval(16777216);
        $GLOBALS[25]=intval(33554432);
        $GLOBALS[26]=intval(67108864);
        $GLOBALS[27]=intval(134217728);
        $GLOBALS[28]=intval(268435456);
        $GLOBALS[29]=intval(536870912);
        $GLOBALS[30]=intval(1073741824);

        $S11=7;
        $S12=12;
        $S13=17;
        $S14=22;
        $S21=5;
        $S22=9;
        $S23=14;
        $S24=20;
        $S31=4;
        $S32=11;
        $S33=16;
        $S34=23;
        $S41=6;
        $S42=10;
        $S43=15;
        $S44=21;

        $x=ConvertToWordArray($sMessage);

        $a=0x67452301;
        $b=0xEFCDAB89;
        $c=0x98BADCFE;
        $d=0x10325476;

        for ($k=0; $k        {
                $AA=$a;
                $BB=$b;
                $CC=$c;
                $DD=$d;
                md5_FF($a,$b,$c,$d,$x[$k+0],$S11,0xD76AA478);
        md5_FF($d,$a,$b,$c,$x[$k+1],$S12,0xE8C7B756);
        md5_FF($c,$d,$a,$b,$x[$k+2],$S13,0x242070DB);
        md5_FF($b,$c,$d,$a,$x[$k+3],$S14,0xC1BDCEEE);
        md5_FF($a,$b,$c,$d,$x[$k+4],$S11,0xF57C0FAF);
        md5_FF($d,$a,$b,$c,$x[$k+5],$S12,0x4787C62A);
        md5_FF($c,$d,$a,$b,$x[$k+6],$S13,0xA8304613);
        md5_FF($b,$c,$d,$a,$x[$k+7],$S14,0xFD469501);
        md5_FF($a,$b,$c,$d,$x[$k+8],$S11,0x698098D8);
        md5_FF($d,$a,$b,$c,$x[$k+9],$S12,0x8B44F7AF);
        md5_FF($c,$d,$a,$b,$x[$k+10],$S13,0xFFFF5BB1);
        md5_FF($b,$c,$d,$a,$x[$k+11],$S14,0x895CD7BE);
        md5_FF($a,$b,$c,$d,$x[$k+12],$S11,0x6B901122);
        md5_FF($d,$a,$b,$c,$x[$k+13],$S12,0xFD987193);
        md5_FF($c,$d,$a,$b,$x[$k+14],$S13,0xA679438E);
        md5_FF($b,$c,$d,$a,$x[$k+15],$S14,0x49B40821);

        md5_GG($a,$b,$c,$d,$x[$k+1],$S21,0xF61E2562);
        md5_GG($d,$a,$b,$c,$x[$k+6],$S22,0xC040B340);
        md5_GG($c,$d,$a,$b,$x[$k+11],$S23,0x265E5A51);
        md5_GG($b,$c,$d,$a,$x[$k+0],$S24,0xE9B6C7AA);
        md5_GG($a,$b,$c,$d,$x[$k+5],$S21,0xD62F105D);
        md5_GG($d,$a,$b,$c,$x[$k+10],$S22,0x2441453);
        md5_GG($c,$d,$a,$b,$x[$k+15],$S23,0xD8A1E681);
        md5_GG($b,$c,$d,$a,$x[$k+4],$S24,0xE7D3FBC8);
        md5_GG($a,$b,$c,$d,$x[$k+9],$S21,0x21E1CDE6);
        md5_GG($d,$a,$b,$c,$x[$k+14],$S22,0xC33707D6);
        md5_GG($c,$d,$a,$b,$x[$k+3],$S23,0xF4D50D87);
        md5_GG($b,$c,$d,$a,$x[$k+8],$S24,0x455A14ED);
        md5_GG($a,$b,$c,$d,$x[$k+13],$S21,0xA9E3E905);
        md5_GG($d,$a,$b,$c,$x[$k+2],$S22,0xFCEFA3F8);
        md5_GG($c,$d,$a,$b,$x[$k+7],$S23,0x676F02D9);
        md5_GG($b,$c,$d,$a,$x[$k+12],$S24,0x8D2A4C8A);

        md5_HH($a,$b,$c,$d,$x[$k+5],$S31,0xFFFA3942);
        md5_HH($d,$a,$b,$c,$x[$k+8],$S32,0x8771F681);
        md5_HH($c,$d,$a,$b,$x[$k+11],$S33,0x6D9D6122);
        md5_HH($b,$c,$d,$a,$x[$k+14],$S34,0xFDE5380C);
        md5_HH($a,$b,$c,$d,$x[$k+1],$S31,0xA4BEEA44);
        md5_HH($d,$a,$b,$c,$x[$k+4],$S32,0x4BDECFA9);
        md5_HH($c,$d,$a,$b,$x[$k+7],$S33,0xF6BB4B60);
        md5_HH($b,$c,$d,$a,$x[$k+10],$S34,0xBEBFBC70);
        md5_HH($a,$b,$c,$d,$x[$k+13],$S31,0x289B7EC6);
        md5_HH($d,$a,$b,$c,$x[$k+0],$S32,0xEAA127FA);
        md5_HH($c,$d,$a,$b,$x[$k+3],$S33,0xD4EF3085);
        md5_HH($b,$c,$d,$a,$x[$k+6],$S34,0x4881D05);
        md5_HH($a,$b,$c,$d,$x[$k+9],$S31,0xD9D4D039);
        md5_HH($d,$a,$b,$c,$x[$k+12],$S32,0xE6DB99E5);
        md5_HH($c,$d,$a,$b,$x[$k+15],$S33,0x1FA27CF8);
        md5_HH($b,$c,$d,$a,$x[$k+2],$S34,0xC4AC5665);

        md5_II($a,$b,$c,$d,$x[$k+0],$S41,0xF4292244);
        md5_II($d,$a,$b,$c,$x[$k+7],$S42,0x432AFF97);
        md5_II($c,$d,$a,$b,$x[$k+14],$S43,0xAB9423A7);
        md5_II($b,$c,$d,$a,$x[$k+5],$S44,0xFC93A039);
        md5_II($a,$b,$c,$d,$x[$k+12],$S41,0x655B59C3);
        md5_II($d,$a,$b,$c,$x[$k+3],$S42,0x8F0CCC92);
        md5_II($c,$d,$a,$b,$x[$k+10],$S43,0xFFEFF47D);
        md5_II($b,$c,$d,$a,$x[$k+1],$S44,0x85845DD1);
        md5_II($a,$b,$c,$d,$x[$k+8],$S41,0x6FA87E4F);
        md5_II($d,$a,$b,$c,$x[$k+15],$S42,0xFE2CE6E0);
        md5_II($c,$d,$a,$b,$x[$k+6],$S43,0xA3014314);
        md5_II($b,$c,$d,$a,$x[$k+13],$S44,0x4E0811A1);
        md5_II($a,$b,$c,$d,$x[$k+4],$S41,0xF7537E82);
        md5_II($d,$a,$b,$c,$x[$k+11],$S42,0xBD3AF235);
        md5_II($c,$d,$a,$b,$x[$k+2],$S43,0x2AD7D2BB);
        md5_II($b,$c,$d,$a,$x[$k+9],$S44,0xEB86D391);
                $a=AddUnsigned($a,$AA);
                $b=AddUnsigned($b,$BB);
                $c=AddUnsigned($c,$CC);
                $d=AddUnsigned($d,$DD);
        }
        return strtolower(WordToHex($a).WordToHex($b).WordToHex($c).WordToHex($d));
}

$aaa=php_MD5("sdfasdf");
echo $aaa;

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Conseils pour créer dynamiquement de nouvelles fonctions dans les fonctions Golang Conseils pour créer dynamiquement de nouvelles fonctions dans les fonctions Golang Apr 25, 2024 pm 02:39 PM

Le langage Go propose deux technologies de création de fonctions dynamiques : la fermeture et la réflexion. les fermetures permettent d'accéder aux variables dans la portée de la fermeture, et la réflexion peut créer de nouvelles fonctions à l'aide de la fonction FuncOf. Ces technologies sont utiles pour personnaliser les routeurs HTTP, mettre en œuvre des systèmes hautement personnalisables et créer des composants enfichables.

Considérations relatives à l'ordre des paramètres dans la dénomination des fonctions C++ Considérations relatives à l'ordre des paramètres dans la dénomination des fonctions C++ Apr 24, 2024 pm 04:21 PM

Dans la dénomination des fonctions C++, il est crucial de prendre en compte l’ordre des paramètres pour améliorer la lisibilité, réduire les erreurs et faciliter la refactorisation. Les conventions courantes d'ordre des paramètres incluent : action-objet, objet-action, signification sémantique et conformité de la bibliothèque standard. L'ordre optimal dépend de l'objectif de la fonction, des types de paramètres, de la confusion potentielle et des conventions du langage.

Comment écrire des fonctions efficaces et maintenables en Java ? Comment écrire des fonctions efficaces et maintenables en Java ? Apr 24, 2024 am 11:33 AM

La clé pour écrire des fonctions Java efficaces et maintenables est la suivante : restez simple. Utilisez un nom significatif. Gérer des situations particulières. Utilisez une visibilité appropriée.

Collection complète de formules de fonctions Excel Collection complète de formules de fonctions Excel May 07, 2024 pm 12:04 PM

1. La fonction SOMME permet de sommer les nombres d'une colonne ou d'un groupe de cellules, par exemple : =SOMME(A1:J10). 2. La fonction MOYENNE permet de calculer la moyenne des nombres dans une colonne ou un groupe de cellules, par exemple : =AVERAGE(A1:A10). 3. Fonction COUNT, utilisée pour compter le nombre de nombres ou de texte dans une colonne ou un groupe de cellules, par exemple : =COUNT(A1:A10) 4. Fonction IF, utilisée pour effectuer des jugements logiques basés sur des conditions spécifiées et renvoyer le résultat correspondant.

Exception de fonction C++ avancée : gestion personnalisée des erreurs Exception de fonction C++ avancée : gestion personnalisée des erreurs May 01, 2024 pm 06:39 PM

La gestion des exceptions en C++ peut être améliorée grâce à des classes d'exceptions personnalisées qui fournissent des messages d'erreur spécifiques, des informations contextuelles et effectuent des actions personnalisées en fonction du type d'erreur. Définissez une classe d'exception héritée de std::exception pour fournir des informations d'erreur spécifiques. Utilisez le mot-clé throw pour lancer une exception personnalisée. Utilisez Dynamic_cast dans un bloc try-catch pour convertir l'exception interceptée en un type d'exception personnalisé. Dans le cas réel, la fonction open_file lève une exception FileNotFoundException. La capture et la gestion de l'exception peuvent fournir un message d'erreur plus spécifique.

Choses à noter lorsque les fonctions Golang reçoivent des paramètres de carte Choses à noter lorsque les fonctions Golang reçoivent des paramètres de carte Jun 04, 2024 am 10:31 AM

Lors du passage d'une carte à une fonction dans Go, une copie sera créée par défaut et les modifications apportées à la copie n'affecteront pas la carte d'origine. Si vous devez modifier la carte originale, vous pouvez la passer via un pointeur. Les cartes vides doivent être manipulées avec précaution, car ce sont techniquement des pointeurs nuls, et passer une carte vide à une fonction qui attend une carte non vide provoquera une erreur.

Obtenez le package d'installation Gate.io gratuitement Obtenez le package d'installation Gate.io gratuitement Feb 21, 2025 pm 08:21 PM

Gate.io est un échange de crypto-monnaie populaire que les utilisateurs peuvent utiliser en téléchargeant son package d'installation et en l'installant sur leurs appareils. Les étapes pour obtenir le package d'installation sont les suivantes: Visitez le site officiel de Gate.io, cliquez sur "Télécharger", sélectionnez le système d'exploitation correspondant (Windows, Mac ou Linux) et téléchargez le package d'installation sur votre ordinateur. Il est recommandé de désactiver temporairement les logiciels antivirus ou le pare-feu pendant l'installation pour assurer une installation fluide. Une fois terminé, l'utilisateur doit créer un compte Gate.io pour commencer à l'utiliser.

La formule magique pour l'efficacité de l'exécution des fonctions PHP La formule magique pour l'efficacité de l'exécution des fonctions PHP Apr 23, 2024 pm 10:21 PM

Pour résoudre le problème de la faible efficacité de l'exécution des fonctions PHP, vous pouvez suivre la formule magique suivante : réduire le nombre de paramètres, utiliser le passage de paramètres par référence, raccourcir la longueur du corps de la fonction et réduire la profondeur des appels de fonction. Exemple pratique : passer des paramètres par référence peut améliorer considérablement les performances. Les meilleures pratiques incluent : éviter les appels inutiles, utiliser la mise en cache, analyser les goulots d’étranglement des performances et respecter les normes de codage.

See all articles