• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

PHPRSA加签的实现过程

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

一、得到私钥文件mycert.key

2.从pfx提取密钥信息,并转换为key格式(pfx使用pkcs12模式补足)

  (1)提取密钥对

       openssl pkcs12 -in 1.pfx -nocerts -nodes -out 1.key

       //如果pfx证书已加密,会提示输入密码。如果cer证书没有安装,则密码没法验证

  (2)从密钥对提取私钥

       openssl rsa -in  1.key -out 1_pri.key

  (3)从密钥对提取公钥

       openssl rsa -in 1.key -pubout -out 1_pub.key

  (4)因为RSA算法使用的是pkcs8模式补足,需要对提取的私钥进一步处理

       openssl pkcs8 -topk8 -inform PEM -in 1_pri.key -outform PEM -nocrypt

       复制窗口中生成的密钥,保存为1_pri_pkcs8.key

  (5)得到密钥对1_pri_pkcs8.key和1_pub.key

 

二、PHP加签

        $timestr=$this->byte2Str($this->toBE($timestamp));
        $hash=strtoupper(sha1($data.$timestr));
        $certfile = "d:/tmp/mycert.key";
        $res = openssl_pkey_get_private(file_get_contents($certfile), '');
        openssl_sign($hash, $encrypted, $res);
        openssl_free_key($res);
        $encrypted=strtoupper(bin2hex($encrypted));
        return $encrypted;

 

http://blog.csdn.net/problem2050/article/details/50528704


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
PHP---无限极分类数组处理发布时间:2022-07-10
下一篇:
PHP读取XML数据中CDATA内数值发布时间:2022-07-10
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap