本文实例讲述了php基于openssl的rsa加密解密。分享给大家供大家参考,具体如下:

$config = array(

//"config" =>"D:/phpserver/Lighttpd/openssl.cnf",

//'config' =>'D:/phpStudy/Lighttpd/OpenSSL.cnf',

'private_key_bits' => 1024, // Size of Key.

'private_key_type' => OPENSSL_KEYTYPE_RSA

);

//$res = openssl_pkey_new();

$res = openssl_pkey_new($config);

// Get private key

// openssl_pkey_export($res, $privkey, "PassPhrase number 1" );

openssl_pkey_export($res, $privkey);

var_dump($privkey);

// Get public key

$pubkey=openssl_pkey_get_details($res);

// echo "------------>
";

// print_r($pubkey["rsa"]);

// $bin_str=$pubkey["rsa"]["n"];

// print_r($bin_str);

// echo "
";

// //echo $bin_hex_str = pack("H*" , bin2hex($bin_str));

// echo $bin_hex_str = bin2hex($bin_str);

// echo "
------------<
";

$pubkey=$pubkey["key"];

// var_dump($privkey);

// var_dump($pubkey);

echo $privkey."
";

echo $pubkey."
";

?>

$private_key = '-----BEGIN RSA PRIVATE KEY-----

MIICXQIBAAKBgQDNSQ4AmPZE01MpEO9dabRDsS0XwxKekEFUoWJneFG+NA6P52Js

ISw79QYNfQwM7akIaPpzU0+kkWjTSXiDqFUv5y2vaA3W2Tre5N51uCwUK6/LfzHX

Bg0d+Bnlzy6Kb6bpgPgvbhAkNbvjbCS0V9h4v3WUTLR9QauJ05Q8qe70sQIDAQAB

AoGAb/9aZ1MMkNImfbIilXk1AvVn353qy51yNyTxFfhbyISIKVSYqtuSUYfFbJh7

eZYz8UWs1jxuqB847IUZ/eJZzpVev480Tv9YejN0DhJ4Yw6y/kpJWo/9kEcET6Tk

vatXh+wgmieszkxe0kUvk41GPV7a4GWWQj6P4vjx+qktaNECQQDuo7ENW10dZXLG

YNKqUhgkdi9NPjRlHCgZ4RW0uoRqUsggqNVkaqpY8BaJOkkXWiQ0aVTPBiwo8k0+

S50rGNYNAkEA3DgxY9OwRc65VqS/UxV28pyLe2gy0XSVwA97SVNvYJJ58iNGEvYs

vEZ3GrTNAZpbPKcruCS6NiDK761Ot5A0NQJAOsRO1pY4QQP5lsbDOjRLQ7djAKef

6YJckbrvSHliIHjQVdKd8kOePZaqRhL3auvE3K9Ptkez2kWJJh0i0DkmhQJBAMCm

F+7wnWA0PEbj0MvqFyiechb/TJWXm/lskbnP17tv6GY/HWoxGWmLa15dlIo2cmJZ

DBIHby8y+NU7k4VaDZECQQCO018O5TJWl+O+bWyzV1eR603YP+JVjiSKUPtuyzVS

NIz+ClwspGmdUwPWlLqr5JfKm+OfpaLIepfJinsCgwpP

-----END RSA PRIVATE KEY-----';

//$private_key ='-----BEGIN RSA PRIVATE KEY-----

//MIICXAIBAAKBgQDVFOcE2nEBi+4FYvS36j1ShHHvusR0dXXe9NzAA/biH6NODywH

//cQo2Lyco6oSvY+cSsPewjjyatRCtq/Ri6c/am64CJu+HM1lZH1Gh05C2KVJ2dveX

//gcdsz+/XPHDxYKAq/hW9S1NeYr2x4eJdpYNYucLn8XWgeLRnlJUnBl/saQIDAQAB

//AoGAK2oz28hKKB+DorNT2zktv2de85JhPr1EA+ZuJ+1m2xHJKzlqJiYBB6M53ltS

//J446YZOPE/kXHgpwWIJlq9Wp1KiZPEfoRWzz1wmuj8koq95vcxBeuyjX4ez4Dio6

//Vmr9BABFuoAh0GAq8kTJOz0DURCEcwv+iI7ILaNoRjPFWuUCQQDveqRLE2/N8NIy

//P7YVnniAiaSL/e+XYQXCMIDsdEdqZNRjhjfDoBqpV/tGjnuAn9zBVHNNLbLni5nf

//2nqgrh5jAkEA48gQmBO9koOnvO//Q581JSBKfga4i7DetQ80OD4kYt6fwezkaeHX

//k64sjmpfD/Ys2heKFhyNDO/k0NsUxGlNwwJBAKPx7/u9qLLyBNSFrWALhy9oC5AT

//Hi0iLNEOZ5R43lNGB+jCf/aa6uW357wb2wzpZDWuXOkfOfUuKv+HEKBj00UCQCxd

//woWsiqcoB5rwcBrevr49fOTxMC7dQ3Omw3gU+odbb2iZWKAbAh9ctIcExwFX5MKS

//BS5rXzne3AWmNnRPQnsCQDdOCBxkF5YctHqlmEETfKodVZG69COZGykdlenOxK6g

//qNNAT2y2mxInYGlPIJ+TfxxFIqesHdph4s/lw6T2ISY=

//-----END RSA PRIVATE KEY-----';

$public_key = '-----BEGIN PUBLIC KEY-----

MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDNSQ4AmPZE01MpEO9dabRDsS0X

wxKekEFUoWJneFG+NA6P52JsISw79QYNfQwM7akIaPpzU0+kkWjTSXiDqFUv5y2v

aA3W2Tre5N51uCwUK6/LfzHXBg0d+Bnlzy6Kb6bpgPgvbhAkNbvjbCS0V9h4v3WU

TLR9QauJ05Q8qe70sQIDAQAB

-----END PUBLIC KEY-----';

//$private_key=$privkey;

//$public_key=$pubkey;

$fp=fopen("private_key","w");

fwrite($fp,$private_key);

fclose($fp);

$fp=fopen("public_key","w");

fwrite($fp,$public_key);

fclose($fp);

//echo $private_key;

$pi_key = openssl_pkey_get_private($private_key);//这个函数可用来判断私钥是否是可用的,可用返回资源id Resource id

$pu_key = openssl_pkey_get_public($public_key);//这个函数可用来判断公钥是否是可用的

print_r($pi_key);echo "\n";

print_r($pu_key);echo "\n";

echo "
----------------------
";

$data = "woshizhu";//原始数据

$encrypted = "";

$decrypted = "";

echo "source data:",$data,"
";

echo "private key encrypt:\n";

openssl_private_encrypt($data,$encrypted,$pi_key);//私钥加密

$encrypted = base64_encode($encrypted);//加密后的内容通常含有特殊字符,需要编码转换下,在网络间通过url传输时要注意base64编码是否是url安全的

echo "
----------私钥加密------------
";

echo $encrypted,"
";

echo "
----------私钥加密------------
";

echo "public key decrypt:\n";

$decrypted="";

openssl_public_decrypt(base64_decode($encrypted),$decrypted,$pu_key);//私钥加密的内容通过公钥可用解密出来

echo $decrypted,"\n";

echo "---------------------------------------\n";

echo "public key encrypt:\n";

openssl_public_encrypt($data,$encrypted,$pu_key);//公钥加密

$encrypted = base64_encode($encrypted);

echo $encrypted,"\n";

$decrypted="";

//$encrypted="JBeapcp9iWWYJYElgqtrZxfxM4wVkCaSn/oJZ7NjfR23o76fdbxEXpf+PGWACw3PeTdObwL4108wR3ihKmy2iYkIExGjBYyvx2w9aHies8ZsOIP3LjiMHYTm93Rr8Sc5XxHWQc3Dhbq16JWHYZ2d+RrOpHd4x84GF3JXwivrGO4=";

echo "private key decrypt:\n";

openssl_private_decrypt(base64_decode($encrypted),$decrypted,$pi_key);//私钥解密

echo "--->:".$decrypted,"\n";

?>

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

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

php java openssl ras_php基于openssl的rsa加密解密示例相关推荐

  1. C# Java间进行RSA加密解密交互

    C# Java间进行RSA加密解密交互 原文:C# Java间进行RSA加密解密交互 这里,讲一下RSA算法加解密在C#和Java之间交互的问题,这两天纠结了很久,也看了很多其他人写的文章,颇受裨益, ...

  2. iOS使用Security.framework进行RSA 加密解密签名和验证签名

    iOS 上 Security.framework为我们提供了安全方面相关的api: Security框架提供的RSA在iOS上使用的一些小结 支持的RSA keySize 大小有:512,768,10 ...

  3. MacOS下使用C语言基于openssl库进行RSA加密解密

    MacOS下使用C语言基于openssl库进行RSA加密解密 1 安装openssl并生成密钥 首先当然要安装openssl(这里记得看一下安装路径,应该是/usr/local/Cellar/open ...

  4. Java使用RSA加密解密签名及校验

    RSA加密解密类: import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileReader; i ...

  5. java rsa 验_Java使用RSA加密解密签名及校验

    RSA加密解密类: package com.ihep; import java.io.BufferedReader; import java.io.BufferedWriter; import jav ...

  6. 条理清晰的入门:使用Java实现RSA加密解密

    条理清晰的入门:使用Java实现RSA加密解密 什么是RSA 使用Java 需要导入的头文件 生成公钥.私钥 进行加密解密 密钥的存储 密文的存储.读取 什么是RSA 翻一下以前的密码学笔记,找到了! ...

  7. RSA加密解密-java

    RSA加密解密 maven依赖: <!-- RSA --><dependency><groupId>org.apache.axis</groupId>& ...

  8. java rsa签名_Java使用RSA加密解密签名及校验

    由于项目要用到非对称加密解密签名校验什么的,于是参考<Java加密解密的艺术>写一个RSA进行加密解密签名及校验的Demo,代码很简单,特此分享! 一.项目截图 代码下载后,导入到ecli ...

  9. RSA加密解密及数字签名Java实现--转

    RSA公钥加密算法是1977年由罗纳德·李维斯特(Ron Rivest).阿迪·萨莫尔(Adi Shamir)和伦纳德·阿德曼(Leonard Adleman)一起提出的.当时他们三人都在麻省理工学院 ...

最新文章

  1. Linux下进程间通信-------管道通信
  2. 汇编程序开发环境搭配
  3. 风讯dotNETCMS源码分析—数据存取篇
  4. big sur无法验证macos_网易邮箱出现重大失误,忘记续期HTTPS证书导致大量用户无法使用...
  5. Dapr 在阿里云原生的实践
  6. 处理中文乱码_为什么PDF转换成Word后是乱码?这种PDF要怎么转换?
  7. 【spring容器启动】之bean的实例化和初始化(文末附:spring循环依赖原理)
  8. excel导入数据到sqlserver
  9. [文章存档]Azure上部署的java app在向第三方服务传送中文时出现乱码
  10. OAuth:每次授权暗中保护你的那个“MAN”
  11. vSphere 7 Kubernetes 初体验
  12. bash中的算术运算
  13. 中国象棋博弈源代码Android,中国象棋源代码
  14. 混频器的噪声来源与抑制方法
  15. android 释放摄像头,android – 为什么Camera需要在onPause()而不是onstop()方法中释放?...
  16. 未名down了,人生无趣
  17. 为静态照片添加动画表情的iOS应用MugLife来了,网友惊呼「这技术等着被收购吧」
  18. 整理2004-2018年地级市进出口贸易总额数据
  19. 按照lfw pairs.txt的格式生成自己的pairs.txt
  20. kali linux改root密码

热门文章

  1. linux修改last权限,Linux常用命令2/3(有关用户、权限管理的命令)--Unix/Linux操作系统04...
  2. mysql重新创建测试对象的SQL_MySQL_Sql_打怪升级_进阶篇_测试: SQL随机生成测试数据...
  3. 「小程序JAVA实战」小程序 loading 提示框与页面跳转(37)
  4. bzoj3687简单题*
  5. D3DXMatrixMultiply 函数
  6. 域对象的引用,ActionContext 和ServletActionContext类的使用
  7. sql2012 数据库连接错误
  8. 【51Nod1773】A国的贸易 解题报告
  9. java8 Stream2
  10. pycharm 中 pep8 检查开启.