好得很程序员自学网
  • 首页
  • 后端语言
    • C#
    • PHP
    • Python
    • java
    • Golang
    • ASP.NET
  • 前端开发
    • Angular
    • react框架
    • LayUi开发
    • javascript
    • HTML与HTML5
    • CSS与CSS3
    • jQuery
    • Bootstrap
    • NodeJS
    • Vue与小程序技术
    • Photoshop
  • 数据库技术
    • MSSQL
    • MYSQL
    • Redis
    • MongoDB
    • Oracle
    • PostgreSQL
    • Sqlite
    • 数据库基础
    • 数据库排错
  • CMS系统
    • HDHCMS
    • WordPress
    • Dedecms
    • PhpCms
    • 帝国CMS
    • ThinkPHP
    • Discuz
    • ZBlog
    • ECSHOP
  • 高手进阶
    • Android技术
    • 正则表达式
    • 数据结构与算法
  • 系统运维
    • Windows
    • apache
    • 服务器排错
    • 网站安全
    • nginx
    • linux系统
    • MacOS
  • 学习教程
    • 前端脚本教程
    • HTML与CSS 教程
    • 脚本语言教程
    • 数据库教程
    • 应用系统教程
  • 新技术
  • 编程导航
    • 区块链
    • IT资讯
    • 设计灵感
    • 建站资源
    • 开发团队
    • 程序社区
    • 图标图库
    • 图形动效
    • IDE环境
    • 在线工具
    • 调试测试
    • Node开发
    • 游戏框架
    • CSS库
    • Jquery插件
    • Js插件
    • Web框架
    • 移动端框架
    • 模块管理
    • 开发社区
    • 在线课堂
    • 框架类库
    • 项目托管
    • 云服务

当前位置:首页>后端语言>PHP
<tfoot draggable='sEl'></tfoot>

phpecb解密 php解密工具

很多站长朋友们都不太清楚phpecb解密,今天小编就来给大家整理phpecb解密,希望对各位有所帮助,具体内容如下:

本文目录一览: 1、 请教 php如何对字符串加密和解密,求一个相关的实例! 2、 PHP 加密:AES & RSA 3、 怎么用php进行3des解密 4、 PHP常用加密解密方法 请教 php如何对字符串加密和解密,求一个相关的实例!

字符串加密解密算法

php5.5中有更为可靠和方便的加密方式。喜欢钻研的朋友可以了解一下:

password_hash()

基于mcrypt扩展,按位异或总结的两个字符串加密解密算法

<?php

/**

* @info 字符串加密解密算法一,利用mcrypt扩展

* @param string $string 待处理字符串

* $action ENCODE,加密 | DECODE,解密

* @return string $returnstr

*/

functionmcrypt_handle_string($string,$action= 'ENCODE')

{

!is_array($string) orexit;

$action== 'DECODE' $string=base64_decode($string);

$key= "123456";//key可自定义或在配置文件中获取

$mcryptAlgorithm= MCRYPT_DES;//选择一种加密算法

$mcryptMode= MCRYPT_MODE_ECB;//选择一种加密模式

$mcryptIv= mcrypt_create_iv(mcrypt_get_iv_size($mcryptAlgorithm,$mcryptMode),MCRYPT_RAND);//创建初始化向量$returnstr=base64_encode(mcrypt_encrypt($mcryptAlgorithm,$key,$string,$mcryptMode,$mcryptIv));

if('DECODE' ==$action)

{$returnstr=mcrypt_decrypt($mcryptAlgorithm,$key,$string,$mcryptMode,$mcryptIv);

}return$returnstr;

}

<?php

/**

*

* @info 字符串加密解密算法二 利用按位异或

* @param string $string 待处理字符串

* @param $action ENCODE 加密 | DECODE 解密

* @return string*/

functionStrCode($string,$action= 'ENCODE')

{$action!= 'ENCODE' $string=base64_decode($string);

$code= '';$key=substr(md5($GLOBALS['pwServer']['HTTP_USER_AGENT'] .$GLOBALS['db_hash']),

8,18);$keyLen=strlen($key);

$strLen=strlen($string);

for($i= 0;$i<$strLen;$i++)

{$k=$i%$keyLen;$code.=$string[$i] ^$key[$k];

}

return($action!= 'DECODE' ?base64_encode($code) :$code);

}

来源jingyan.baidu测试数据/m/article/e4d08ffdd1ca6b0fd2f60d13.html

PHP 加密:AES & RSA

最近两年一直从事与金融相关项目的开发与维护。但是,关于 PHP 加密解密的最佳实践,网上没有人给出一个完美的总结。恰逢最近看了《图解密码技术》一书,对 PHP 加解密有了更深刻的认识。

为了避免各位看枯燥的文字理论,开篇我就把总结给出:

一、对称加密

对称加密的特点是加解密速度快,加密后的密文强度目前还没有硬解的可能性。但是,在未来随着计算机性能的提升有可能会出现被破解的可能性。

对称加密的缺点也很明显。对称加密的加密过程与解密过程使用的是同一把密钥。一旦泄漏密钥,加密就失去了任何意义。

根据《图解密码技术》一书的推荐,对称加密目前推荐使用 AES。在 PHP 当中要实现 AES 加解密,是使用 openssl 扩展来实现。所以,请确保你的 PHP 已经开启了 openssl 扩展。

可以通过如下方式检测:

或者如下方式检测:

AES 的加密模式属于分组密码模式。所谓分组密码,是加密时把明文按照固定的长度分组,然后再进行加密。当然,细节之处很很多不同。AES 分组模式有多种:ECB、CBC、CFB、OFB、CTR 五种分组模式。目前优先推荐使用 CBC 模式。

如果使用 CBC 模式,那么在加密的时候,就需要一个前置的加密向量 IV。当初博主在使用 AES 来加密的时候,就很奇怪一个对称加密为何要这个向量。因为,在博主寒冰的潜意识里,对称加密只需要一个密钥就 Ok 了。没想到 AES 加密还有多种模式,而这个 CBC 模式恰恰就需要一个这样的向量值。关于这个向量大家可以在网上查阅相关的资料。这个东西非常重要,也非常好理解。

关于 PHP AES 加解密会用到的相关方法:

AES 支持三种强度:128、192、256。128 位的强度最低,但是,加密解密速度较快。256 位强度最高,但是,加密解密速度最低。所以,大家根据自己系统的重要程度选择使用对应强度。通常普通的金融项目使用 192 位完整够用了。顶级的就用 256 位。其他的就用 128 位吧。

二、非对称加密

非对称加密是指公钥加密私钥解密,私钥加密公钥解密的算法。非对称加密的算法有很多。《图解密码技术》一书推荐使用 RSA 算法。它使用起来也非常简单。

要使用 RSA 算法。首先,我们必须生成一对公钥私钥。其实生成公钥私钥很简单。

在 Linux 系统,直接使用如下命令生成:

此命令会生 ~/.ssh/ 目录下生成两个文件:

id_rsa 是私钥, is_rsa.pub 是公钥。

关于 PHP RSA 加解密会用到的相关方法:

以上就是关于在 PHP 项目开发中,我们使用的加密解密算法的一个总结。博主寒冰在总结过程中难免会有不足之处,还请大家指正!谢谢!

怎么用php进行3des解密

<?php

class?Crypt3Des?{??????

?????var?$key;?????

?????function?Crypt3Des($key){??????????

????$this->key?=?$key;

?????}

?????function?encrypt($input){

?????????$size?=?mcrypt_get_block_size(MCRYPT_3DES,'ecb');??

?????????$input?=?$this->pkcs5_pad($input,?$size);??

?????????$key?=?str_pad($this->key,24,'0');??

?????????$td?=?mcrypt_module_open(MCRYPT_3DES,?'',?'ecb',?'');??

?????????$iv?=?@mcrypt_create_iv?(mcrypt_enc_get_iv_size($td),?MCRYPT_RAND);??

?????????@mcrypt_generic_init($td,?$key,?$iv);??

?????????$data?=?mcrypt_generic($td,?$input);??

?????????mcrypt_generic_deinit($td);??

?????????mcrypt_module_close($td);??

?????????//????$data?=?base64_encode($this->PaddingPKCS7($data));?

?????????$data?=?base64_encode($data);

??????????????return?$data;??

?????}??????????

?????function?decrypt($encrypted){

?????????$encrypted?=?base64_decode($encrypted);??

?????????$key?=?str_pad($this->key,24,'0');??

?????????$td?=?mcrypt_module_open(MCRYPT_3DES,'','ecb','');

?????????$iv?=?@mcrypt_create_iv(mcrypt_enc_get_iv_size($td),MCRYPT_RAND);

?????????$ks?=?mcrypt_enc_get_key_size($td);

?????????@mcrypt_generic_init($td,?$key,?$iv);

?????????$decrypted?=?mdecrypt_generic($td,?$encrypted);

?????????mcrypt_generic_deinit($td);

?????????mcrypt_module_close($td);?

?????????$y=$this->pkcs5_unpad($decrypted);

??????????????return?$y;??????

?????}

?????function?pkcs5_pad?($text,?$blocksize)?{

?????????$pad?=?$blocksize?-?(strlen($text)?%?$blocksize);

?????????return?$text?.?str_repeat(chr($pad),?$pad);??

?????}

?????function?pkcs5_unpad($text){??????????

?????????$pad?=?ord($text{strlen($text)-1});??

?????????if?($pad?>?strlen($text))?{??

?????????????return?false;??

?????????}??

?????????if?(strspn($text,?chr($pad),?strlen($text)?-?$pad)?!=?$pad){??

?????????????return?false;??

?????????}??

???????????????return?substr($text,?0,?-1?*?$pad);??

?????}?

?????

?????function?PaddingPKCS7($data)?{

?????????$block_size?=?mcrypt_get_block_size(MCRYPT_3DES,?MCRYPT_MODE_CBC);

?????????$padding_char?=?$block_size?-?(strlen($data)?%?$block_size);

?????????$data?.=?str_repeat(chr($padding_char),$padding_char);

?????????return?$data;

?????}?

}

用法:

$crypt?=?new?Crypt3Des('密钥');

$code?=?"加密后的字符串";

echo?$crypt->decrypt($code);

echo出来的就是结果

PHP常用加密解密方法

作者/上善若水

1.md5(string $str,bool $flag = false);

$flag = false 默认返回32位的16进至数据散列值

$flag = true ?返回原始流数据

2.sha1($string,$flag = false)

$flag = false 默认返回40位的16进至数据散列值

true ?返回原始流数据

3.hash(string $algo,srting $str,bool $flag);

$algo : 算法名称,可通过hash_algos()函数获取所有hash加密的算法

如:md5,sha1等,采用md5,sha1加密所得结果和1,2两种方式结 果相同。

$flag = false 默认返回16进至的数据散列值,具体长度根据算法不同

而不同。

true ?返回原始流数据。

4.crypt(string $str,$string $salt);

函数返回使用 DES、Blowfish 或 MD5 算法加密的字符串。

具体算法依赖于PHP检查之后支持的算法和$salt的格式和长度,当 然具体结果也和操作系统有关。比较结果采用 hash_equals($crypted,crypt($input,$salt));//且salt值相同

Password_verify($str,$crypted);

5.password_hash ( string $str, integer $algo [, array $options ] )

函数返回哈希加密后的密码字符串, password_hash() 是crypt()的 一个简单封装

$algo : 算法 PASSWORD_DEFAULT ,PASSWORD_BCRYPT

$options = [

“cost”=>10,//指明算法递归的层数,

“salt”=>“xxadasdsad”//加密盐值,即将被遗 弃,采用系统自动随机生成安全性更高

];

使用的算法、cost 和盐值作为哈希的一部分返回

Password_verify($str,$hashed);

6.base64_encode(string $str)

设计此种编码是为了使二进制数据可以通过非纯 8-bit 的传输层 传输,例如电子邮件的主体。base64_decode(string $encoded)

可以进行解码;

7.mcrypt_encrypt ( string $cipher , string $key , string $data ,

string $mode [, string $iv ] )

mcrypt_decrypt ( string $cipher , string $key , string $crypted ,

string $mode [, string $iv ] )

$ciper:加密算法,mcrypt_list_algorithms()可以获取该函数所有支持的算法

如MCRYPT_DES(“des”),MCRYPT_RIJNDAEL_128(“rijndael-128”);

$mode : 加密模式 ,mcrypt_list_modes()获取所有支持的加密模式,ecb,cbc

$key: 加密的秘钥,mcrypt_get_key_size ( string $cipher , string $mode )

获取指定的算法和模式所需的密钥长度。$key要满足这个长度,如果长 度无效会报出警告。

$iv : 加密的初始向量,可通过mcrypt_create_iv ( int $size [, int $source = MCRYPT_DEV_URANDOM ] ),

Iv的参数size:

通过mcrypt_get_iv_size ( string $cipher , string $mode )获取

Iv 的参数source:

初始向量数据来源。可选值有: MCRYPT_RAND (系统随机数生成 器), MCRYPT_DEV_RANDOM (从 /dev/random 文件读取数据) 和 ?MCRYPT_DEV_URANDOM (从 /dev/urandom 文件读取数据)。 在 Windows 平台,PHP 5.3.0 之前的版本中,仅支持 MCRYPT_RAND。

请注意,在 PHP 5.6.0 之前的版本中, 此参数的默认值 为 MCRYPT_DEV_RANDOM。

Note: 需要注意的是,如果没有更多可用的用来产生随机数据的信息, 那么 MCRYPT_DEV_RANDOM 可能进入阻塞状态。

$data : 要加密的字符串数据

关于phpecb解密的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。

查看更多关于phpecb解密 php解密工具的详细内容...

声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did198193
更新时间:2023-04-26   阅读:47次

上一篇: php自学完整教程 php自学完整教程百度云

下一篇:php匹配标记 php字符匹配

最新资料更新

  • 1.phpflv播放器 php视频播放
  • 2.php连接vertica php连接mysql
  • 3.php技术网学习 php技术门户
  • 4.php循环处理速度 phpforeach循环
  • 5.商品展示模块php 商品展示模块的设计要点
  • 6.bashphp的简单介绍
  • 7.php语法基础csdn php语言基础
  • 8.智能朗读系统php 智能ai朗读
  • 9.口袋源码php下载 口袋com
  • 10.php数据抓取实例 php采集数据
  • 11.php页面加ico php嵌入网页
  • 12.包含phpgabage的词条
  • 13.php7.1des加密 php7 加密
  • 14.手机文件php怎么打开 手机php格式文件怎么打开
  • 15.php设备判断在线 php判断用户在线状态
  • 16.php5.2cgi的简单介绍
  • 17.php教程全局交流 phpunit教程
  • 18.php定义多个常量 php定义多个变量
  • 19.php获取阴历 php获取日期
  • 20.php项目任务分配 php任务调度框架

CopyRight:2016-2025好得很程序员自学网 备案ICP:湘ICP备09009000号-16 http://www.haodehen.cn
本站资讯不构成任何建议,仅限于个人分享,参考须谨慎!
本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。
本网站刊载的所有内容(包括但不仅限文字、图片、LOGO、音频、视频、软件、程序等)版权归原作者所有。任何单位或个人认为本网站中的内容可能涉嫌侵犯其知识产权或存在不实内容时,请及时通知本站,予以删除。

网站内容来源于网络分享,如有侵权发邮箱到:kenbest@126.com,收到邮件我们会即时下线处理。
网站框架支持:HDHCMS   51LA统计 百度统计
Copyright © 2018-2025 「好得很程序员自学网」
[ SiteMap ]