服务器密钥(openssl)

一般接口处于安全考虑,会增加秘钥处理,实现数据安全

公钥则为提供接口方的,私钥则为使用者方


私钥封装类方法:

public static function sign($content, $rsaPrivateKeyPem)
	{
		$priKey = file_get_contents($rsaPrivateKeyPem); //打开文件,将文件内容保存成字符串
		$res = openssl_pkey_get_private($priKey); //检查该私钥是否可用
		$content = base64_encode($content); //时间戳进行base64转码
		openssl_sign($content, $sign, $res, OPENSSL_ALGO_MD5); //设置签名的哈希算法(Algorithm)为MD5
		openssl_free_key($res);
		$sign = base64_encode($sign);

		return $sign;
	}


使用:

self::sign(参数, '文件名');



公钥验证:

function verify($data, $sign)  {
    //读取公钥文件
    $pubKey = file_get_contents('rsa_public_key.pem');
 
    //转换为openssl格式密钥
    $res = openssl_get_publickey($pubKey);
 
    //调用openssl内置方法验签,返回bool值
    $result = (bool)openssl_verify($data, $sign, $res);
     
    //释放资源
    openssl_free_key($res);
 
    return $result;
}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值