Maison >développement back-end >tutoriel php >Implémentation simple d'un algorithme de chiffrement symétrique en php

Implémentation simple d'un algorithme de chiffrement symétrique en php

高洛峰
高洛峰original
2017-01-07 16:37:251188parcourir

Avant-propos

J'ai trouvé un bon algorithme de chiffrement symétrique pour PHP sur Internet ; dans l'environnement de syntaxe PHP, il existe des algorithmes symétriques fournis avec urlencode et urldecode, base64_encode et base64_decode, mais ceux-ci viennent avec l'algorithme. ne peut pas être appelé un algorithme de chiffrement, il ne peut être appelé qu'une méthode de codage. Mais nous pouvons les utiliser pour effectuer certains traitements afin de mettre en œuvre des algorithmes simples de chiffrement et de déchiffrement.

Cette fois les algorithmes de chiffrement et de déchiffrement sont adaptés en base64. Habituellement, nous utilisons la chaîne générée par base64_encode($str). Sans aucun traitement, base64_decode() peut revenir à notre chaîne précédente ; mais que se passe-t-il si nous insérons quelques caractères dans la chaîne après base64_encode() ? en arrière, et même si on le retourne, ce n'est pas notre propre corde.

L'exemple de code est le suivant :

<?php
$content = "大家好,我是中国人,你是谁";
 
/**
* 简单对称加密算法之加密
* @param String $string 需要加密的字串
* @param String $skey 加密EKY
* @return String
*/
function encode($string = &#39;&#39;, $skey = &#39;wenzi&#39;) {
$strArr = str_split(base64_encode($string));
$strCount = count($strArr);
foreach (str_split($skey) as $key => $value)
 $key < $strCount && $strArr[$key].=$value;
return str_replace(array(&#39;=&#39;, &#39;+&#39;, &#39;/&#39;), array(&#39;O0O0O&#39;, &#39;o000o&#39;, &#39;oo00o&#39;), join(&#39;&#39;, $strArr));
}
 
/**
* 简单对称加密算法之解密
* @param String $string 需要解密的字串
* @param String $skey 解密KEY
* @return String
*/
function decode($string = &#39;&#39;, $skey = &#39;wenzi&#39;) {
$strArr = str_split(str_replace(array(&#39;O0O0O&#39;, &#39;o000o&#39;, &#39;oo00o&#39;), array(&#39;=&#39;, &#39;+&#39;, &#39;/&#39;), $string), 2);
$strCount = count($strArr);
foreach (str_split($skey) as $key => $value)
 $key <= $strCount && $strArr[$key][1] === $value && $strArr[$key] = $strArr[$key][0];
return base64_decode(join(&#39;&#39;, $strArr));
}
 
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
echo "string : " . $content . " <br />";
echo "encode : " . ($enstring = encode($content)) . &#39;<br />&#39;;
echo "decode : " . decode($enstring);
 
exit();

Dans l'algorithme ci-dessus, nous pouvons voir : nous insérons la clé que nous avons définie à l'avance dans les caractères générés par base64_encode(), puis Special les caractères sont remplacés, même si d'autres voient une telle chaîne, ils ne sauront pas de quoi il s'agit. Bien sûr, nous pouvons apporter de légères améliorations ici, comme insérer la clé dans la chaîne à l'envers, base64 la clé puis l'insérer, etc., insérer la clé puis la base64 à nouveau.

Bien sûr, le décryptage est le sens inverse du cryptage. Après avoir réfléchi un moment, j'ai compris le principe du décryptage : avant d'insérer des caractères dans la chaîne, il faut maintenant les retirer lors du décryptage. . Regroupez d'abord les chaînes chiffrées par 2 éléments dans chaque tableau, puis déterminez si le deuxième caractère est dans la clé. Si tel est le cas, le premier caractère est le caractère de la base64 d'origine.

Résumé

Ce qui précède représente l'intégralité du contenu de cet article. Bien sûr, en plus du cryptage et du décryptage base64 en php, il existe également des algorithmes tels que AES et DES Friends in need. faites attention à Script House, je pense que cela sera utile à tout le monde.

Pour plus d'articles liés à l'implémentation d'algorithmes de chiffrement symétriques simples en PHP, veuillez faire attention au site Web chinois de PHP !


Déclaration:
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