Heim >Backend-Entwicklung >PHP-Tutorial >PHP-Verschlüsselungsfunktion
In diesem Artikel wird hauptsächlich die Verschlüsselungsfunktion von PHP vorgestellt, die jetzt mit allen geteilt werden kann. Freunde in Not können sich darauf beziehen
Im Entwicklungsprozess der Website. Es ist häufig erforderlich, einige Daten zu verschlüsseln (z. B. Benutzerkennwörter). In diesem Artikel werden hauptsächlich einige gängige Verschlüsselungsfunktionen von PHP vorgestellt
MD5-Verschlüsselung:string md5 ( string $str [, bool $raw_output = false ] )
1.md5() hat standardmäßig 32 Zeichen. Gibt die zurück Hash-Wert in hexadezimaler digitaler Form. Der erste ist der zu verschlüsselnde String und der zweite ist der boolesche Wert von raw_output. Wenn er auf true gesetzt ist, gibt md5() den ursprünglichen Wert zurück. Bit-Binärformat-Nachrichtendigest 2.md5() ist eine Einwegverschlüsselung, es gibt keinen umgekehrten Entschlüsselungsalgorithmus, aber einige gängige Zeichenfolgen können dennoch durch Sammlung, Aufzählung, Kollision usw. geknackt werden.
?
4 5 6 7 8 9 10 11 12 13 14 15 16 |
<?php $username='jellybool'; $password='jellybool.com'; /*简单地对字符串进行md5加密*/ echo md5($username); echo "<hr>"; echo md5($password); echo "<hr>"; /*更推荐的做法是对重要的敏感数据进行多次加密,以防被轻易破解*/ echo md5(md5($password)); /*以上输出: username:4f5436e5d72608fb647b691e8edcf42e password:7bf02cf0f4af6da4accbc73d2a175476 password(两次加密):864704bb35754f8cd0232cba6b91521b */ |
Crypt-Verschlüsselung:
string crypt ( string $str [, string $salt ] )
1.crypt() akzeptiert zwei Parameter, der erste ist die Zeichenfolge, die verschlüsselt werden muss, und die zweite ist der Salt-Wert (der der Verschlüsselungsinterferenzwert ist; wenn er nicht angegeben wird, wird er standardmäßig automatisch von PHP generiert); , letzteres Zur Unterscheidung des Salzwertes.
2.crypt() ist eine Einwegverschlüsselung, genau wie md5.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
<?php $password='jellybool.com'; echo crypt($password); //输出:$1$Fe0.qr5.$WOhkI4/5VPo7n7TnXHh5K /*第二个$与第三个$之间的八个字符是由PHP生成的,每刷新一次就变一次 */ echo "<hr>"; echo crypt($password,"jellybool"); //输出:je7fNiu1KNaEs /*当我们要加自定义的盐值时,如例子中的jellybool作为第二个参数直接加入, 超出两位字符的会截取前两位*/ echo "<hr>"; echo crypt($password,'$1$jellybool$'); //输出:$1$jellyboo$DxH7wF7SygRpWb6XBBgfH/ /* crypt加密函数有多种盐值加密支持,以上例子展示的是MD5散列作为盐值,该方式下 盐值以$1$$的形式加入,如例子中的jellybool加在后两个$符之间, 超出八位字符的会截取前八位,总长为12位;crypt默认就是这种形式。 */ echo "<hr>"; //crypt还有多种盐值加密支持,详见手册 |
Sha1-Verschlüsselung:
string sha1 ( string $str [, bool $raw_output = false ]
1. Es ist MD5 sehr ähnlich, aber der Unterschied is sha1( ) gibt standardmäßig einen 40-stelligen Hash-Wert zurück. Der erste ist der verschlüsselte String und der zweite ist der boolesche Wert von raw_output auf true, sha1() wird den ursprünglichen 20-Bit-Nachrichtenauszug im Originalformat zurückgeben
2.sha1() ist ebenfalls einzeilige Verschlüsselung, es gibt keinen umgekehrten Entschlüsselungsalgorithmus
1 2 3 4 5 6 7 8 9 |
<?php $my_intro="jellybool"; echo sha1($my_intro); //输出:c98885c04c1208fd4d0b1dadd3bd2a9ff4d042ca echo "<hr>"; //当然,可以将多种加密算法混合使用 echo md5(sha1($my_intro)); //输出:94f25bf9214f88b1ef065a3f9b5d9874 //这种方式的双重加密也可以提高数据的安全性 |
Urlencode-Verschlüsselung:
string urlencode ( string $str )
1. Ein Parameter, übergeben Sie den zu verschlüsselnden String (wird normalerweise zum Verschlüsseln von URLs verwendet),
2. Urlencode ist eine Zwei-Wege-Verschlüsselung, die mit Urldecode verschlüsselt werden kann (streng genommen handelt es sich nicht um eine echte Verschlüsselung)
3 Gibt eine Zeichenfolge zurück, alle Nicht-Buchstaben in dieser Zeichenfolge außer -_ werden durch ein Prozentzeichen (%) gefolgt von zwei hexadezimalen Ziffern ersetzt und Leerzeichen werden durch ein Pluszeichen (+) kodiert.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 |
<?php //urlencode()通常用于URL中明文数据的隐藏 $my_urlencode="jellybool.com?jellybool=true + 4-3%5= \& @!"; echo urlencode($my_urlencode); //输出:jellybool.com%3Fjellybool%3Dtrue+%2B+4-3%255%3D+%5C%26+%40%21 echo "<hr>"; $my_urldecode="jellybool.com%3Fjellybool%3Dtrue+%2B+4-3%255%3D+%5C%26+%40%21"; echo urldecode($my_urldecode); //输出:jellybool.com?jellybool=true + 4-3%5= \& @! //还原了$my_urlencode的输出 echo "<hr>"; $my_urldecode="http://www.baidu.com/s?word=jellybool+%E8%A7%89%E7%B4%AF%E4%B8%8D%E7%88%B1&tn=98236947_hao_pg&ie=utf-8"; echo urldecode($my_urldecode); /*输出:http://www.baidu.com/s?word=jellybool 觉累不爱&tn=98236947_hao_pg&ie=utf-8 没错,这就是在百度搜索jellybool 觉累不爱 */ /* ========================================================================= 解决第二个经典问题 ========================================================================= */ $pre_url_encode="jellybool.com?username=jellybool&password=jelly"; //在实际开发中,我们很多时候要构造这种URL,这是没有问题的 $url_decode ="jellybool.com?username=jelly&bool&password=jelly"; /*注意上面两个变量的差别:第一个的username=jellybool, 第二个为username=jelly&bool 这种情况下用$_GET()来接受是会出问题的,这是可以用下面的方法解决 */ $username="jelly&bool"; $url_decode ="jellybool.com?username=".urlencode($username)."&password=jelly"; //这是可以很好的解决问题 /* 总结一下常见的urlencode()的转换字符 ?=> %3F = => %3D % => %25 & => %26 \ => %5C + => %2B 空格 => + */ |
Base64-Kodierung Verschlüsselung:
String base64decode ( string $encodeddata )
1.base64_encode() akzeptiert einen Parameter, bei dem es sich um die zu kodierenden Daten handelt (String wird nicht erwähnt). hier, da Base64 häufig zum Kodieren von Bildern verwendet wird)
2.base64encode() ist eine bidirektionale Verschlüsselung, und base64decode() kann zum Entschlüsseln von
12 345678
9 10 11 12 13 |
echo base64_encode($my_intro); echo "<hr>"; /*输出:SmVsbHlCb29s5piv5LiA5Liq6Lqr5p2Q5pyJ6auY5bqmLOiCqeiGgOacieWuveW 6pizog7jogozmnInljprluqYs5oCd5oOz5pyJ5rex5bqm55qE5Zu95a625YWN5qOA5Lq UQee6p+S8mOi0qOS8quWJjeerr0lU55S35bGM5Lid */ echo base64_decode('SmVsbHlCb29s5piv5LiA5Liq6Lqr5p2Q5pyJ6auY5bqmLOiCqeiGg OacieWuveW6pizog7jogozmnInljprluqYs5oCd5oOz5pyJ5rex5bqm55qE5Zu95a6 25YWN5qOA5LqUQee6p+S8mOi0qOS8quWJjeerr0lU55S35bGM5Lid'); /*输出:JellyBool是一个身材有高度,肩膀有宽度,胸肌有厚度,思想有深度的国家免检五A 级优质伪前端IT男屌丝 */ |
Ein Beispiel für ein Bild:
1 2 3 4 5 6 7 8 9 10 11 |
<?php /* 一个图片的应用例子 */ $filename="https://worktile.com/img/index/index_video.png"; $data=file_get_contents($filename); echo base64_encode($data); /*然后你查看网页源码就会得到一大串base64的字符串, 再用base64_decode()还原就可以得到图片 */ |
相关推荐:
Das obige ist der detaillierte Inhalt vonPHP-Verschlüsselungsfunktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!