需要接入方自己生成rsa(2048位)密钥对,然后将公钥提供给易通。
并使用服务商自己申请的RSA私钥(2048位 SHA256WithRSA)对摘要做签名操作
刚开始还不知道什么是rsa,公钥和私钥的用处。怎么获取?
先了解一下关于公钥私钥加解密的作用
一、公钥加密
假设一下,我找了两个数字,一个是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签名和验签