背景

最近在对接微信支付的时候,需要在退款处用到证书,由于我们是SAAS平台,要支持多方多渠道支付,如果把所有证书文件保存在应用服务器会受到SLB的影响,会导致某台机器文件不同步而阻碍退款流程,但把文件存在OSS的话,后端又要从OSS下载到应用服务器来保证一致性。思来想去,最终决定将证书内容保存在数据库,不同客户各对应一份证书文件,无论几台机器做集群都能保证文件的一致性,同时也避免了多余的下载步骤。

问题

但是刚做就遇到了问题,PHP的CURL证书并不支持字符串的传输,只能填写证书路径(以下是官方的说法)Client certificates must be specified by a path expression to a certificate store.

解决过程

我第一个想到的就是创建空白文件,将证书内容写进去,等证书使用完毕后再将文件删除,但是创建实体文件再删除的操作消耗性能不说,还非常麻烦,有没有创建临时文件的方法呢?有,tmpfile()函数就可以帮我们创建临时文件并拿到文件路径,于是我写了一个获取临时文件路径的方法<?php

public function getTmpPathByContent($content)

{

$tmpFile = tmpfile();

fwrite($tmpFile, $content);

$tempPemPath = stream_get_meta_data($tmpFile);

return $tempPemPath['uri']; ///tmp/phpXZCtAO

}

?>

比较悲哀的是,通过这个方法返回的路径根本读不到内容,甚至一度以为是不是被骗了file_get_contents(/tmp/phpyyiOZv): failed to open stream: No such file or directory

看了官方文档才找到原因,如果tmpfile()返回的句柄引用计数为0的话就会将临时文件回收,临时路径自然也就失效了,显然方法getTmpPathByContent()执行完后,局部变量$tmpFile的生命周期就结束了(官方文档如下)The file is automatically removed when closed (for example, by calling fclose(), or when there are no remaining references to the file handle returned by tmpfile()), or when the script ends.

确认了根源,那我们现在亟需找到一个生命周期随进程结束而终止的变量类型来保存句柄,什么类型能满足条件呢?静态变量。静态变量与局部变量不同的是,在PHP生命周期开始时便会为其分配内存空间,并会把它存储在全局变量区域,而全局变量是在模块关闭阶段销毁的,这样的话,声明静态变量就可以使$tmpFile引用计数持续保持大于0的状态,那我们的代码就可以做出如下处理<?php

public function getTmpPathByContent($content)

{

static $tmpFile = null;

$tmpFile = tmpfile();

fwrite($tmpFile, $content);

$tempPemPath = stream_get_meta_data($tmpFile);

return $tempPemPath['uri'];

}

?>

再执行一次就成功读取了临时文件的内容-----BEGIN CERTIFICATE-----

MIIEbDCCA9WgAwIBAgIEAWJKHDANBgkqhkiG9w0BAQUFADCBijELMAkGA1UEBhMC

Q04xEjAQBgNVBAgTCUd1YW5nZG9uZzERMA8GA1UEBxMIU2hlbnpoZW4xEDAOBgNV

BAoTB1RlbmNlbnQxDDAKBgNVBAsTA1dYRzETMBEGA1UEAxMKTW1wYXltY2hDQTEf

MB0GCSqGSIb3DQEJARYQbW1wYXltY2hAdGVuY2VudDAeFw0xNzA4MDcwOTIxNDda

Fw0yNzA4MDUwOTIxNDdaMIGbMQswCQYDVQQGEwJDTjESMBAGA1UECBMJR3Vhbmdk

b25nMREwDwYDVQQHEwhTaGVuemhlbjEQMA4GA1UEChMHVGVuY2VudDEOMAwGA1UE

CxMFTU1QYXkxMDAuBgNVBAMUJ a3seWcs W4guaYjua6kOi9r S7tuiCoeS7veac

iemZkOWFrOWPuDERMA8GA1UEBBMIMTAyNTkyODEwggEiMA0GCSqGSIb3DQEBAQUA

A4IBDwAwggEKAoIBAQDg2D3 uOxY/yMGQPBnROvyYimnCsfGE0dnqdGUTCykqBh

yfv82zE1/St/4DQX2QDiIvLif sMGcYwF4bkzdY HgitYLI0k5o/5LCNZOMctuio

kdYC2bNdWHq2y9S5UWLQR1Zvq 6QyPBVBVY9yq9xtQhIlUTsZnICAp3iQLfQUR3l

aEdH9IERoRUIkbyb8oX5ONQz4P9jOeE9C5iwx0QrH4s01NFhkhr8JHlugRLpo9vA

xGgi/48fOlONj6wWal5Gt0OvvEbIwgQwya15KBX2YeGnZvYBQa lQMeXEqZSFie3

G wGvbtlONczQEtp JDxLZLUS/FT7U0TQN/t8JDvAgMBAAGjggFGMIIBQjAJBgNV

HRMEAjAAMCwGCWCGSAGG EIBDQQfFh0iQ0VTLUNBIEdlbmVyYXRlIENlcnRpZmlj

YXRlIjAdBgNVHQ4EFgQUjDJ75bu3Roog7XOH6uFAdZ6kpcIwgb8GA1UdIwSBtzCB

tIAUPgUm9iJitBVbiM1kfrDUYqflhnShgZCkgY0wgYoxCzAJBgNVBAYTAkNOMRIw

EAYDVQQIEwlHdWFuZ2RvbmcxETAPBgNVBAcTCFNoZW56aGVuMRAwDgYDVQQKEwdU

ZW5jZW50MQwwCgYDVQQLEwNXWEcxEzARBgNVBAMTCk1tcGF5bWNoQ0ExHzAdBgkq

hkiG9w0BCQEWEG1tcGF5bWNoQHRlbmNlbnSCCQC7VJcrvADoVzAOBgNVHQ8BAf8E

BAMCBsAwFgYDVR0lAQH/BAwwCgYIKwYBBQUHAwIwDQYJKoZIhvcNAQEFBQADgYEA

ucJLJkkHxlqQCEapZOWmySutqNVZxFbqyG//UXxxpA/1yG4e KmufKZWv c MtYI

8i0KDDCv/UE kkFIrHYDDKsdLRpxrYOUHGoqq0c7yBJ6Dimgy6m8U8FsEv3HtUR2

8g5xrg2Tc5MPWEp9ncEw575hGk0CXLDGOkI1nU pGqk=

-----END CERTIFICATE-----

下面就可以把生成的临时文件地址设置到CURLOPT_SSLCERT了<?php

$sslCertPath = getTmpPathByContent($content);

curl_setopt($ch,CURLOPT_SSLCERT, $sslCertPath);

//......

?>

【推荐课程:PHP视频教程】

php curl p12证书处理,PHP如何支持CURL字符串证书传输(详细解决过程)相关推荐

  1. 虚拟机打不开,提示“此主机不支持虚拟化实际模式”的详细解决方法

    虚拟机打不开,提示"此主机不支持虚拟机实际模式"的解决方法 一.第一种情况安装/启动虚拟机失败, 在VMWare软件中,安装/启动虚拟机时,如果出以类似以下的错误提示: 出现该提示 ...

  2. centos+tomcate + https协议 SSL证书制作、部署支持iphone、ipa下载安装.ipa程序

    使用工具:openssl.keytool 一.制作SSL证书 a)根证书制作 1.创建制作根证书的私钥文件myCA.key openssl genrsa -out /usr/local/myCA.ke ...

  3. 如何制作SSL证书即https服务支持

    如何制作SSL证书即https服务支持 目的 最近需要做个网站,支持https的访问,但是,是内部使用的,不需要对外网开放. 基础知识 在制作之前先了解一下OpenSSL.HTTPS的关系.见http ...

  4. VeriSign SSL服务器证书——128位支持型SSL证书(VeriSign Secure Site)_VeriSign数字证书产品...

    VeriSign SSL服务器证书--128位支持型SSL证书(VeriSign Secure Site) • 全球最为知名的SSL证书品牌 • 40/56/128/256 位自适用加密 • 支持主流 ...

  5. php重新编译curl扩展,在Linux安装php的curl扩展,并支持https请求,重新编译法

    环境:php5.5.5 + nginx 任务:安装php curl扩展,并支持https 血与泪之坑:我先安装了curl,发现不支持https,然后再安装openssl,然而一切都晚了,折腾了半天,还 ...

  6. 主机支持php的curl扩展,[Windows技术] 使服务器支持PHP curl函数:开启CURL扩展的方法...

    一.window下安装php_curl支持 1.将PHP文件夹下的libeay32.dll, ssleay32.dll, php5ts.dll, php_curl.dll复制到 %windir%/sy ...

  7. app上架电子版权证书电子软著支持苹果应用商店还是安卓应用商店?还是都支持?

    苹果应用商店支持电子版权证书啦! 很多开发者提交APP上架的时候公司名称用的英文简称 无法与实际公司名称对应起来 之前的做法是去公证处做公证 费时又费钱 现在我们可以在核发电子版权的时候 加上APP和 ...

  8. linux php支持curl,linux下给php安装和开启curl扩展

    在使用某些PHP系统时要求开启curl扩展,下面是linux下安装.开启php curl 扩展方法: 方法一 安装cURL wget http://curl.haxx.se/download/curl ...

  9. eap wifi 证书_用openssl为EAP-TLS生成证书(CA证书,服务器证书,用户证书)

    我用的是openssl-1.0.2k. 脚本支持生成RSA,ECC证书. 运行时带参数指定类型. -->开始.按以下路径建立文件,脚本.ssl_create-cert-v0.4.7z ssl_c ...

最新文章

  1. java库加载,Java:使用依赖项加载共享库
  2. java 伪异步 netty,Netty(一) - 不死的达芬奇的个人空间 - OSCHINA - 中文开源技术交流社区...
  3. mysql设计一个简单的系统_一个简单数据库设计例子
  4. C语言工作笔记-函数指针的使用(补充C回调系统)
  5. atexit()函数(进程退出函数,类似析构)
  6. [转载] 【python】Python中*args和**kwargs的区别(在Python中如何使用可变长参数列表)
  7. CSS样式(一)- 基本语法
  8. 487-3279 (poj1002)
  9. 题解 P1217 【[USACO1.5]回文质数 Prime Palindromes】
  10. docker registry push 覆盖_Maven一键部署Springboot到Docker仓库,为自动化做准备
  11. linux关闭rpcbind服务,rpcbind服务 关闭
  12. 基于springboot实现宠物医院管理系统
  13. 怎样设置CorelDRAW中的网格参数
  14. html页面去边框线,html中怎么去掉表格边框线的?
  15. 英国开创自我修复城市概念,利用无人机和机器人自动检测道路裂缝并进行修复
  16. Zend Studio 10.6.0正式版注册破解
  17. Android_线程_多线程下载
  18. 从自动驾驶事故中探索有效的性能提升及判责策略
  19. Java clk啥意思_clock (CLK)是什么意思
  20. oracle中文转换为unicode,oracle 用函数unistr将Oracle数据库中的Unicode转换为中文

热门文章

  1. 在Windows上使用终端模拟程序连接操作Linux以及上传下载文件
  2. 【C 语言】二级指针作为输入 ( 二维数组 | 抽象业务函数 | 二维数组打印函数 | 二维数组排序函数 )
  3. 【Flutter】Flutter 调试 ( 调试回退功能 | Debug 调试中查看变量的方式 | 控制台信息 )
  4. 【云计算 Hadoop】Hadoop 版本 生态圈 MapReduce模型
  5. python学习笔记 day25 封装
  6. Selenium_python自动化环境搭建篇
  7. 【实验吧】CTF_Web_简单的SQL注入之1
  8. VirtualBox——在Win7的HOST上安装配置虚拟机CentOS7
  9. 简单理解kafka---入门
  10. 原生JS和jQuery实现banner图滚动那些事