在shell_exec期间,“找不到libcrypto.so.1.0.0:版本'OPENSSL_1.0.1'”

时间:2016-06-14 02:53:52

标签: php git github ssh openssl

我在PHP中遇到一个奇怪的问题,使用shell_exec来运行git命令。这是Ubuntu 16.x LTS的全新形象,只安装了Lampp和git软件包。在我想要webhook的php脚本中,运行shell_exec('/usr/bin/git pull 2>&1')会打印出以下错误。

ssh: /opt/lampp/lib/libcrypto.so.1.0.0: version 'OPENSSL_1.0.1' not found (required by ssh)
fatal: Could not read from remote repository.`

我可以从命令行使用git pull来获取存储库,并且运行apache的用户拥有htdocs目录中所有文件的所有权。

openssl version -a会产生以下结果:

OpenSSL 1.0.2g-fips  1 Mar 2016
built on: reproducible build, date unspecified
platform: debian-amd64
options:  bn(64,64) rc4(16x,int) des(idx,cisc,16,int) blowfish(idx)
compiler: cc -I. -I.. -I../include  -fPIC -DOPENSSL_PIC -DOPENSSL_THREADS -D_REENTRANT -DDSO_DLFCN
-DHAVE_DLFCN_H -m64 -DL_ENDIAN -g -O2 -fstack-protector-strong -Wformat -Werror=format-security
-Wdate-time -D_FORTIFY_SOURCE=2 -Wl,-Bsymbolic-functions -Wl,-z,relro -Wa,--noexecstack -Wall
-DMD32_REG_T=int -DOPENSSL_IA32_SSE2 -DOPENSSL_BN_ASM_MONT -DOPENSSL_BN_ASM_MONT5
-DOPENSSL_BN_ASM_GF2m -DSHA1_ASM -DSHA256_ASM -DSHA512_ASM -DMD5_ASM -DAES_ASM -DVPAES_ASM
-DBSAES_ASM -DWHIRLPOOL_ASM -DGHASH_ASM -DECP_NISTZ256_ASM
OPENSSLDIR: "/usr/lib/ssl"

这是Lamp 5.6.21的问题,还是我的设置问题?

1 个答案:

答案 0 :(得分:1)

因此,您已将XAMPP安装到/opt/lampp并尝试通过shell_exec()运行本机(如来自Ubuntu而非XAMPP)git。这个shell运行的环境是什么?它是XAMPP与LD_LIBRARY_PATH设置/opt/lampp/lib一起使用的环境,这是所有XAMPP组件绝对需要的(因为它们是为了/opt/lampp/lib使用这些库而构建的) 。然后git继承了这个相同的环境,并且(尽管它在/lib/x86_64-linux-gnu中的某个地方有来自Ubuntu的完美openssl库)尝试使用来自/opt/lampp/lib的库,bang。

您需要的只是在git调用之前清除LD_LIBRARY_PATH环境变量,例如:

$oldldpath = getenv('LD_LIBRARY_PATH');
putenv("LD_LIBRARY_PATH=");
shell_exec('/usr/bin/git pull 2>&1');
putenv("LD_LIBRARY_PATH=$oldldpath");