php和java加密解码方法,加密的php源码如何解密

本文目录一览:

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常用加密解密方法

作者/上善若水

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 : 要加密的字符串数据

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));

    }

参考自:

java加密用PHP解密

当然可以,加密解密算法都是通用的,可以用对称加密或者是非对称加密!

为了安全性,建议使用Rsa非对称加密。

支付宝支付也是使用Rsa算法,不分语言,php和java都有现成的方法可以使用!

java 和 php 有没有相通的加密解密方法

如下:

public static String do_post(String url, ListNameValuePair name_value_pair) throws IOException {

        String body = “{}”;

        DefaultHttpClient httpclient = new DefaultHttpClient();

        try {

            HttpPost httpost = new HttpPost(url);

            httpost.setEntity(new UrlEncodedFormEntity(name_value_pair, StandardCharsets.UTF_8));

            HttpResponse response = httpclient.execute(httpost);

            HttpEntity entity = response.getEntity();

            body = EntityUtils.toString(entity);

        } finally {

            httpclient.getConnectionManager().shutdown();

        }

        return body;

    }

    public static String do_get(String url) throws ClientProtocolException, IOException {

        String body = “{}”;

        DefaultHttpClient httpclient = new DefaultHttpClient();

        try {

            HttpGet httpget = new HttpGet(url);

            HttpResponse response = httpclient.execute(httpget);

            HttpEntity entity = response.getEntity();

            body = EntityUtils.toString(entity);

        } finally {

            httpclient.getConnectionManager().shutdown();

        }

        return body;

    }

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

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

相关推荐

  • 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
  • ArcGIS更改标注位置为中心的方法

    本篇文章将从多个方面详细阐述如何在ArcGIS中更改标注位置为中心。让我们一步步来看。 一、禁止标注智能调整 在ArcMap中设置标注智能调整可以自动将标注位置调整到最佳显示位置。…

    编程 2025-04-29
  • 解决.net 6.0运行闪退的方法

    如果你正在使用.net 6.0开发应用程序,可能会遇到程序闪退的情况。这篇文章将从多个方面为你解决这个问题。 一、代码问题 代码问题是导致.net 6.0程序闪退的主要原因之一。首…

    编程 2025-04-29
  • Python创建分配内存的方法

    在python中,我们常常需要创建并分配内存来存储数据。不同的类型和数据结构可能需要不同的方法来分配内存。本文将从多个方面介绍Python创建分配内存的方法,包括列表、元组、字典、…

    编程 2025-04-29
  • Python中init方法的作用及使用方法

    Python中的init方法是一个类的构造函数,在创建对象时被调用。在本篇文章中,我们将从多个方面详细讨论init方法的作用,使用方法以及注意点。 一、定义init方法 在Pyth…

    编程 2025-04-29

发表回复

登录后才能评论