• PHP RSA加签的实现过程


    一、得到私钥文件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

  • 相关阅读:
    P3391 【模板】文艺平衡树(Splay)
    P4198 楼房重建
    P1491 集合位置
    P3957 跳房子
    P4016 负载平衡问题
    bzoj1077: [SCOI2008]天平 差分约束
    bzoj1151: [CTSC2007]动物园zoo 状压dp
    bzoj1076: [SCOI2008]奖励关 状压dp
    bzoj1226: [SDOI2009]学校食堂Dining 状压dp
    bzoj1879: [Sdoi2009]Bill的挑战 状压dp
  • 原文地址:https://www.cnblogs.com/xihong2014/p/6249128.html
Copyright © 2020-2023  润新知