java是php的mcrypt的简单介绍

本文目录一览:

java进行3des加密传过来的数据,php怎么解密?

?php

/**

* 3DES加解密类

* @Author: 黎志斌

* @version: v1.0

* 2016年7月21日

*/

class Encrypt

{

//加密秘钥,

private $_key;

private $_iv;

public function __construct($key, $iv)

{

$this-_key = $key;

$this-_iv = $iv;

}

/**

* 对字符串进行3DES加密

* @param string 要加密的字符串

* @return mixed 加密成功返回加密后的字符串,否则返回false

*/

public function encrypt3DES($str)

{

$td = mcrypt_module_open(MCRYPT_3DES, “”, MCRYPT_MODE_CBC, “”);

if ($td === false) {

return false;

}

//检查加密key,iv的长度是否符合算法要求

$key = $this-fixLen($this-_key, mcrypt_enc_get_key_size($td));

$iv = $this-fixLen($this-_iv, mcrypt_enc_get_iv_size($td));

//加密数据长度处理

$str = $this-strPad($str, mcrypt_enc_get_block_size($td));

if (mcrypt_generic_init($td, $key, $iv) !== 0) {

return false;

}

$result = mcrypt_generic($td, $str);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return $result;

}

/**

* 对加密的字符串进行3DES解密

* @param string 要解密的字符串

* @return mixed 加密成功返回加密后的字符串,否则返回false

*/

public function decrypt3DES($str)

{

$td = mcrypt_module_open(MCRYPT_3DES, “”, MCRYPT_MODE_CBC, “”);

if ($td === false) {

return false;

}

//检查加密key,iv的长度是否符合算法要求

$key = $this-fixLen($this-_key, mcrypt_enc_get_key_size($td));

$iv = $this-fixLen($this-_iv, mcrypt_enc_get_iv_size($td));

if (mcrypt_generic_init($td, $key, $iv) !== 0) {

return false;

}

$result = mdecrypt_generic($td, $str);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return $this-strUnPad($result);

}

/**

* 返回适合算法长度的key,iv字符串

* @param string $str key或iv的值

* @param int $td_len 符合条件的key或iv长度

* @return string 返回处理后的key或iv值

*/

private function fixLen($str, $td_len)

{

$str_len = strlen($str);

if ($str_len $td_len) {

return substr($str, 0, $td_len);

} else if($str_len $td_len) {

return str_pad($str, $td_len, ‘0’);

}

return $str;

}

/**

* 返回适合算法的分组大小的字符串长度,末尾使用\0补齐

* @param string $str 要加密的字符串

* @param int $td_group_len 符合算法的分组长度

* @return string 返回处理后字符串

*/

private function strPad($str, $td_group_len)

{

$padding_len = $td_group_len – (strlen($str) % $td_group_len);

return str_pad($str, strlen($str) + $padding_len, “\0”);

}

/**

* 返回适合算法的分组大小的字符串长度,末尾使用\0补齐

* @param string $str 要加密的字符串

* @return string 返回处理后字符串

*/

private function strUnPad($str)

{

return rtrim($str);

}

}

$key = ‘ABCEDFGHIJKLMNOPQ’;

$iv = ‘0123456789’;

$des = new Encrypt($key, $iv);

$str = “abcdefghijklmnopq”;

echo “source: {$str},len: “,strlen($str),”\r\n”;

$e_str = $des-encrypt3DES($str);

echo “entrypt: “, $e_str, “\r\n”;

$d_str = $des-decrypt3DES($e_str);

echo “dntrypt: {$d_str},len: “,strlen($d_str),”\r\n”;

PHP函数mcrypt_ecb在JAVA中是哪个

JDK6中有个class是java.security.Security

看看这个对你有帮助。 java可以使用MD5等这样的加密方式

急!! php 调用库函数 mcrypt_get_block_size 无效

那你再看看 php.ini 的配置中 ;extension=php_mcrypt.dll 这一句前面有没有分号,如果有就把它去掉,不要有分号 ,然后重启 apache 或 IIS 等web服务

Java用Des方式加密之后,PHP怎么解密

DES是一种标准的数据加密算法,关于这个算法的详细介绍可以参考wiki和百度百科:

php中有一个扩展可以支持DES的加密算法,是:extension=php_mcrypt.dll

在配置文件中将这个扩展打开还不能够在windows环境下使用

需要将PHP文件夹下的 libmcrypt.dll 拷贝到系统的 system32 目录下,这是通过phpinfo可以查看到mcrypt表示这个模块可以正常试用了。

下面是PHP中使用DES加密解密的一个例子:

//$input – stuff to decrypt

//$key – the secret key to use

function do_mencrypt($input, $key)

{

$input = str_replace(“”n”, “”, $input);

$input = str_replace(“”t”, “”, $input);

$input = str_replace(“”r”, “”, $input);

$key = substr(md5($key), 0, 24);

$td = mcrypt_module_open(‘tripledes’, ”, ‘ecb’, ”);

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

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

$encrypted_data = mcrypt_generic($td, $input);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return trim(chop(base64_encode($encrypted_data)));

}

//$input – stuff to decrypt

//$key – the secret key to use

function do_mdecrypt($input, $key)

{

$input = str_replace(“”n”, “”, $input);

$input = str_replace(“”t”, “”, $input);

$input = str_replace(“”r”, “”, $input);

$input = trim(chop(base64_decode($input)));

$td = mcrypt_module_open(‘tripledes’, ”, ‘ecb’, ”);

$key = substr(md5($key), 0, 24);

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

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

$decrypted_data = mdecrypt_generic($td, $input);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return trim(chop($decrypted_data));

}

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/236583.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-12 12:00
下一篇 2024-12-12 12:00

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • PHP和Python哪个好找工作?

    PHP和Python都是非常流行的编程语言,它们被广泛应用于不同领域的开发中。但是,在考虑择业方向的时候,很多人都会有一个问题:PHP和Python哪个好找工作?这篇文章将从多个方…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • Python简单数学计算

    本文将从多个方面介绍Python的简单数学计算,包括基础运算符、函数、库以及实际应用场景。 一、基础运算符 Python提供了基础的算术运算符,包括加(+)、减(-)、乘(*)、除…

    编程 2025-04-29
  • Python满天星代码:让编程变得更加简单

    本文将从多个方面详细阐述Python满天星代码,为大家介绍它的优点以及如何在编程中使用。无论是刚刚接触编程还是资深程序员,都能从中获得一定的收获。 一、简介 Python满天星代码…

    编程 2025-04-29

发表回复

登录后才能评论