我是靠谱客的博主 落寞钢笔,最近开发中收集的这篇文章主要介绍php URl参数基于base64_encode加密与解密,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

php url地址中参数加密问题

在我们常用的加密方法中,有的是可逆有些是不可逆的,比如我们经常使用的base64_encode() 和 base64_decode() 为可逆的加密方式,不可逆的我们常用的MD5 等,但是一般url加密当我们涉及到参数的时候都会选择可逆的加密方法,我们今天介绍的方法是在base64_encode上面去改良的,因为base64_encode有些特殊字符被加密以后,参数接收的时候会因为一些特殊字符导致接收参数不对,直接上代码了!
原理很简单就是我们把一些可能存在的特殊字符先处理再加密!

/**
   * @ 路径加密
  **/
function enPssUrl($data, $key="urlPass")
{
    $key    =    md5($key);
    $x        =    0;
    $len    =    strlen($data);
    $l        =    strlen($key);
    $char = "";
    $str = "";
    for ($i = 0; $i < $len; $i++)
    {
        if ($x == $l)
        {
            $x = 0;
        }
        $char .= $key{$x};
        $x++;
    }
    for ($i = 0; $i < $len; $i++)
    {
        $str .= chr(ord($data{$i}) + (ord($char{$i})) % 256);
    }
    return base64_encode($str);
}
/**
 * @ 路径解密
 **/
function dePssUrl($data, $key="urlPass")
{
    $key = md5($key);
    $x = 0;
    $data = base64_decode($data);
    $len = strlen($data);
    $l = strlen($key);
    $char = "";
    for ($i = 0; $i < $len; $i++)
    {
        if ($x == $l)
        {
            $x = 0;
        }
        $char .= substr($key, $x, 1);
        $x++;
    }
    $str = "";
    for ($i = 0; $i < $len; $i++)
    {
        if (ord(substr($data, $i, 1)) < ord(substr($char, $i, 1)))
        {
            $str .= chr((ord(substr($data, $i, 1)) + 256) - ord(substr($char, $i, 1)));
        }
        else
        {
            $str .= chr(ord(substr($data, $i, 1)) - ord(substr($char, $i, 1)));
        }
    }
    return $str;
}

最后

以上就是落寞钢笔为你收集整理的php URl参数基于base64_encode加密与解密的全部内容,希望文章能够帮你解决php URl参数基于base64_encode加密与解密所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(39)

评论列表共有 0 条评论

立即
投稿
返回
顶部