混淆 php,PHP实现的ID混淆算法类与用法示例

本文实例讲述了PHP实现的ID混淆算法类与用法。分享给大家供大家参考,具体如下:

/**

* ID混淆算法

*/

class IdCrypt

{

/**

* 对整数id进行可逆混淆

*/

public static function encodeId($id)

{

$sid = ($id & 0xff000000);

$sid += ($id & 0x0000ff00) << 8;

$sid += ($id & 0x00ff0000) >> 8;

$sid += ($id & 0x0000000f) << 4;

$sid += ($id & 0x000000f0) >> 4;

$sid ^= 11184810;

return $sid;

}

/**

* 对通过encodeId混淆的id进行还原

*/

public static function decodeId($sid)

{

if (!is_numeric($sid)) {

return false;

}

$sid ^= 11184810;

$id = ($sid & 0xff000000);

$id += ($sid & 0x00ff0000) >> 8;

$id += ($sid & 0x0000ff00) << 8;

$id += ($sid & 0x000000f0) >> 4;

$id += ($sid & 0x0000000f) << 4;

return $id;

}

}

$idstr = new IdCrypt();

echo $encodeid = $idstr->encodeId('12345678');

echo "
";

echo $decodeid = $idstr->decodeId($encodeid);

?>

运行结果:

13309518

12345678

PS:关于加密解密感兴趣的朋友还可以参考本站在线工具:

在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:http://tools.jb51.net/password/hash_md5_sha

希望本文所述对大家PHP程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值