问题:warning: libssl.so.1.0.0, needed by …lib/libcurl.so, not found (try using -rpath or -rpath-link)

项目需用https协议,原curl库不支持,编译curl库支持https需添加openssl。编译时虽指定openssl库路径仍失败,根据warning提示,在configure配置添加rpath参数后编译通过。

前言:

最近在项目需要用到https协议,原本使用的curl库是不支持https协议的,如果想要使用curl支持https协议,那么在编译curl库的时候,需要添加已经编译好的openssl,

但是在编译的过程中,我已经指定了openssl库的路径,但是依然编译不过,出现了上述bug:

warning: libssl.so.1.0.0, needed by …lib/libcurl.so, not found (try using -rpath or -rpath-link)

我的configure配置如下:

./configure --prefix=$(pwd)/../output \
--host=$CROSS_COMPILER_NAME \
CC=$GCC_NAME CXX=$CXX_NAME \
LD=$LD_NAME \
--with-ssl \
LDFLAGS="-L/home/qiIhua/VDS-880-C1F_MAIN/APP/ACS/libs/openssl/lib" \
CFLAGS="-I/home/qihua/VDS-880-C1F_MAIN/APP/ACS/libs/openssl/include/"  \
CPPFLAGS="-I/home/qihua/VDS-880-C1F_MAIN/APP/ACS/libs/openssl/include/"

问题是已经指定了库的路径,但连接器还是找不到,然后根据warning的提示,在configure配置的时候,添加了rpath参数,然后就顺利通过了!

configure配置如下示:

GCC_NAME=${CROSS_COMPILER_NAME}-gcc
CXX_NAME=${CROSS_COMPILER_NAME}-g++
LD_NAME=${CROSS_COMPILER_NAME}-ld

./configure --prefix=$(pwd)/../output \
--host=$CROSS_COMPILER_NAME \
CC=$GCC_NAME CXX=$CXX_NAME \
LD=$LD_NAME \
--with-ssl \ #enable curl的ssl支持
LDFLAGS="-Wl,-rpath,/home/qihua/VDS-880-C1F_MAIN/APP/ACS/libs/openssl/lib 
-L/home/qihua/VDS-880-C1F_MAIN/APP/ACS/libs/openssl/lib/" \ #改了这个
CFLAGS="-I/home/qihua/VDS-880-C1F_MAIN/APP/ACS/libs/openssl/include/" \
CPPFLAGS="-I/home/qihua/VDS-880-C1F_MAIN/APP/ACS/libs/openssl/include/"

over!

当编译时提示 `./lib/libpaho - mqtt3as.so` 需要 `libssl.so.1.1` 和 `libcrypto.so.1.1` 但找不到,可参考以下解决方法: ### 1. 确认库文件是否存在 在系统中搜索 `libssl.so.1.1` 和 `libcrypto.so.1.1` 文件,使用如下命令: ```bash sudo find / -name "libssl.so.1.1" sudo find / -name "libcrypto.so.1.1" ``` ### 2. 若库文件存在但路径未被系统识别 - **创建软链接**:若找到库文件,但路径不在系统默认的库搜索路径中,可在 `/usr/lib` 或 `/usr/local/lib` 目录下创建软链接。假设库文件在 `/path/to/library` 目录下,执行如下命令: ```bash sudo ln -s /path/to/library/libssl.so.1.1 /usr/lib/libssl.so.1.1 sudo ln -s /path/to/library/libcrypto.so.1.1 /usr/lib/libcrypto.so.1.1 ``` - **更新动态链接库缓存**:创建软链接后,执行如下命令更新动态链接库缓存: ```bash sudo ldconfig ``` ### 3. 若库文件不存在 - **安装 OpenSSL**:使用包管理器安装 OpenSSL,以 Ubuntu 为例,执行如下命令: ```bash sudo apt-get update sudo apt-get install libssl-dev ``` - **手动编译安装 OpenSSL**:若包管理器中没有所需版本的 OpenSSL,可手动编译安装。从 OpenSSL 官方网站下载所需版本的源码,解压后编译安装: ```bash tar -zxvf openssl-x.x.x.tar.gz cd openssl-x.x.x ./config --prefix=/usr/local/openssl make sudo make install ``` 安装完成后,在编译 `paho.mqtt.c` 时,指定 OpenSSL 的路径,参考命令如下: ```bash cmake . -DPAHO_WITH_SSL=TRUE -DPAHO_BUILD_STATIC=TRUE -DPAHO_ENABLE_TESTING=FALSE -DCMAKE_SYSTEM_NAME=Linux -DCMAKE_INSTALL_PREFIX=${PWD}/build -DOPENSSL_INCLUDE_DIR=/usr/local/openssl/include -DOPENSSL_SSL_LIBRARY=/usr/local/openssl/lib/libssl.so -DOPENSSL_CRYPTO_LIBRARY=/usr/local/openssl/lib/libcrypto.so ``` ### 4. 编译时指定库文件路径 在编译 `paho.mqtt.c` 时,使用 `-L` 选项指定库文件的搜索路径,使用 `-l` 选项指定库名,参考命令如下: ```bash gcc -o your_program your_source.c -L/path/to/library -lssl -lcrypto ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值