文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

PHP 8.1.14升级低版本openssl扩展的操作方法

2023-09-03 05:19

关注

问题背景:

PHP8.1.4内嵌openssl源码编译出来的openssl库版本号是1.0.2.x系列,低版本的openssl扩展存在安全漏洞,需要将该扩展升级openssl 社区最新版本3.0.8

操作步骤:

安装最新版本的openssl

  wget https://github.com/openssl/openssl/releases/download/openssl-3.0.8/openssl-3.0.8.tar.gz  tar -zxvf openssl-3.0.8.tar.gz  mkdir -p /usr/local/openssl ./Configure --prefix=/usr/local/openssl --openssldir=/usr/local/openssl    make && make install   ln -s /usr/local/openssl/lib64/libssl.so.3 /usr/lib64/libssl.so.3   ln -s /usr/local/openssl/lib64/libcrypto.so.3  /usr/lib64/libcrypto.so.3   cp -a /usr/local/openssl/bin/openssl /usr/bin

安装完毕以后执行

openssl verion -a

在这里插入图片描述

安装bison

yum install bison

安装re2c

wget https://github.com/skvadrik/re2c/archive/refs/tags/3.0.tar.gztar -zxvf 3.0.tar.gzcd re2c-3.0yum install git./autogen.sh./configuremakemake install

下载PHP8.1.14

wget https://github.com/php/php-src/archive/refs/tags/php-8.1.14.tar.gztar -zxvf php-8.1.14.tar.gzcd php-8.1.4mkdir -p /usr/local/php

设置动态链接库的位置

PKG_CONFIG_PATH
作用:pkg-config用来检索系统中安装库文件的信息,典型的是用作库的编译和连接,用于放置.pc库

export PKG_CONFIG_PATH=/usr/local/openssl/lib64/pkgconfig

在这里插入图片描述

PKG_CONFIG_LIBDIR
如果你想覆盖掉原来的pkg,可选择用PKG_CONFIG_LIBDIR。因为PKG_CONFIG_LIBDIR的优先级比 PKG_CONFIG_PATH 高,所以会覆盖PKG_CONFIG_PATH的设置。LD_LIBRARY_PATH,用于放置.so库

编译PHP

./configure --prefix=/usr/local/php --with-config-path=/usr/local/php/lib --with-openssl=/usr/local/openssl makemake instal

查看PHP编译的openssl版本信息

vi test.php

在该文件中添加如下内容

 phpinfo();?>

执行如下命令查看openssl版本信息

php test.php

在这里插入图片描述

这说明PHP内置的openssl扩展升级成功。
经验总结:
在编译openssl的过程中,很容易忽略的一点就是PKG_CONFIG_PATH参数的设置,如果不手动设置pc库的路径,编译器就会跑到/usr/lib64/pkgcofig目录下寻找openssl.pc库文件,它会读取该文件的版本信息并链接接到PHP中。
在这里插入图片描述
在这里插入图片描述
这也解释了之前为什么我编译出来的openssl.so版本号为1.0.2k,如果设置了PKG_CONFIG_PATH参数,编译器会优先搜索PKG_CONFIG_PATH指向的路径是否有openssl.pc库文件的版本信息,如果有则优先采用PKG_CONFIG_PATH指向的路径,如果没有则采用/usr/lib64/pkgconfig目录下的库文件。

参考链接:
https://www.cnblogs.com/rainsoul/p/10567390.html

来源地址:https://blog.csdn.net/u014265398/article/details/129331773

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯