php如何生成RSA公钥私钥

发布时间:2020-05-15作者:小灵龙点击:74

问题描述:

  我们公司对接易通的数据。他们要求:

需要接入方自己生成rsa2048位)密钥对,然后将公钥提供给易通。

 

并使用服务商自己申请的RSA私钥(2048位 SHA256WithRSA)对摘要做签名操作

 

刚开始还不知道什么是rsa,公钥和私钥的用处。怎么获取?

php服务端与客户端交互、提供开放api时,通常需要对敏感的部分api数据传输进行数据加密,这时候rsa非对称加密就能派上用处了,下面通过一个例子来说明如何用php来实现数据的加密解密

先了解一下关于公钥私钥加解密的作用

一、公钥加密
假设一下,我找了两个数字,一个是1,一个是2。我把2保留起来,不告诉你们,当做我的私钥,然后我告诉大家,1是我的公钥。

我有一个文件,不能让别人看,我就用1加密了。别人找到了这个文件,但是他不知道2就是解密的私钥啊,所以他解不开,只有我可以用数字2,就是我的私钥,来解密。这样我就可以保护数据了。

我的好朋友小明用我的公钥1加密了字符a,加密后成了b,放在网上。别人偷到了这个文件,但是别人解不开,因为别人不知道2就是我的私钥,只有我才能解密,解密后就得到a。这样,我们就可以传送加密的数据了。

二、私钥签名
如果我用私钥加密一段数据(当然只有我可以用私钥加密,因为只有我知道2是我的私钥),结果所有的人都看到我的内容了,因为他们都知道我的公钥是1,那么这种加密有什么用处呢?

但是我的好朋友小红说有人冒充我给他发信。怎么办呢?我把我要发的信,内容是‘天涯’,用我的私钥2,加密,加密后的内容是‘冰封’,发给小红,再告诉他解密看看是不是‘天涯’。他用我的公钥1解密,发现果然是‘天涯’。
这个时候,他会想到,能够用我的公钥解密的数据,必然是用我的私钥加的密。只有我知道我的私钥,因此他就可以确认是不是我发的东西。
这样我们就能确认发送方身份了。这个过程叫做数字签名。当然具体的过程要稍微复杂一些。用私钥来加密数据,用途就是数字签名。

三、总结

公钥和私钥是成对的,它们互相解密。

公钥加密,私钥解密。

私钥数字签名,公钥验证。


解决办法:
             $opensslConfigPath = "E:\phpstudy\Extensions\Apache2.4.39\conf\openssl.cnf";//本地openssl.cnf路径
             //$opensslConfigPath="/etc/pki/tls/openssl.cnf"//apache路径

        $config = array(


            "digest_alg" => "sha256",

            "private_key_bits" =>2048,

            "private_key_type" => OPENSSL_KEYTYPE_RSA,

            'config'=> $opensslConfigPath

        );

        //创建密钥对

        $res = openssl_pkey_new($config);

        //生成私钥

        openssl_pkey_export($res, $privkey, null, $config);

        //生成公钥

        $pubKey = openssl_pkey_get_details($res)['key'];
                 file_put_contents("./cert_public.key",$pubKey);//生成在根目录
          file_put_contents("./cert_private.pem",$privkey);

          //生成证书
          $dn = array(   
            "countryName" => 'CH', //所在国家名称    
            "stateOrProvinceName" => 'Shandong', //所在省份名称    
            "localityName" => 'JiNan', //所在城市名称    
            "organizationName" => 'liyajun',   //注册人姓名    
            "organizationalUnitName" => 'guotong', //组织名称    
            "commonName" => 'mySelf', //公共名称    
            "emailAddress" => 'user@domain.com' //邮箱    
        );    
         $privkeypass = '123456'; //私钥密码    
        $numberofdays = 365;     //有效时长    
        $cerpath = "./tests.cer"; //生成证书路径    
        $pfxpath = "./testd.pfx"; //密钥文件路径   
        //生成证书    
        $privkey = openssl_pkey_new($config);    
        $csr = openssl_csr_new($dn, $privkey,$config);
        // $sscert = openssl_csr_sign($csr, null, $privkey, 365, $config);   
        $sscert = openssl_csr_sign($csr,null, $privkey, $numberofdays,$config);
        openssl_pkey_export_to_file($privkey,"server.key",NULL, $config);

        openssl_x509_export_to_file($sscert,"server.crt");
        openssl_csr_export_to_file($csr, "server.csr");

        print_r($privkey);

        echo '<p style="height:100px;background:red">1</p>';

        print_r($pubKey);




标签:php,rsa