नवीनतम ओपनसेल के साथ कर्ल कैसे बनाएं?


18

इसलिए मैं ओपनसेल का निर्माण करता हूं

./config
make
sudo make install
sudo ln -sf /usr/local/ssl/bin/openssl `which openssl`

मैं कर्ल का निर्माण

./configure --with-ssl 
make
make install

ओपनएसएसएल सही ढंग से स्थापित दिखता है:

openssl version
OpenSSL 1.0.1g 7 Apr 2014

हालांकि कर्ल पुराने खुलने वाले संस्करण का उपयोग करता है (1.0.1g के बजाय 1.0.1g):

curl --version
curl 7.37.0 (x86_64-unknown-linux-gnu) libcurl/7.37.0 OpenSSL/1.0.1f zlib/1.2.8 libidn/1.28 libssh2/1.4.3 librtmp/2.3
Protocols: dict file ftp ftps gopher http https imap imaps ldap ldaps pop3 pop3s rtmp rtsp scp sftp smtp smtps telnet tftp 
Features: IDN IPv6 Largefile NTLM NTLM_WB SSL libz TLS-SRP 

कैसे कर्ल नए संस्करण का उपयोग करने के लिए?

मैं नवीनतम संस्करणों की कोशिश करना चाहता हूं, क्योंकि मैं कुछ अजीब ओपनसेल / कर्ल बग # 1 # 2 के साथ लड़ रहा हूं

संपादित करें: मैंने भी कोशिश की ./configure --with-ssl=/usr/local/ssl/include/openssl, कोई सफलता नहीं

Edit2: अब तक मैंने भी कोशिश की:

  • sudo ./configure --with-ssl --with-libssl-prefix=/usr/local/ssl
  • ./configure --with-ssl=/usr/local/ssl
  • PKG_CONFIG_PATH=/usr/local/ssl/lib/pkgconfig ./configure
  • PKG_CONFIG_PATH=/usr/local/ssl/lib/pkgconfig ./configure --with-ssl
  • PKG_CONFIG_PATH=/usr/local/ssl/lib/pkgconfig ./configure --with-ssl=/usr/local/ssl/include/openssl

कोई सफलता नहीं...

जवाबों:


13

आपको उस निर्देशिका को निर्दिष्ट करने की आवश्यकता है जहां OpenSSL स्थापित है (आपका सिमलिंक न तो आवश्यक है और न ही पर्याप्त है)

./configure --with-ssl=/usr/local/ssl

संपादित करें: वैकल्पिक रूप से, आप अपना PKG_CONFIG_PATHपर्यावरण चर निर्धारित कर सकते हैं (जैसा कि सुझाव दिया गया है ./configure --help):

PKG_CONFIG_PATH=/usr/local/ssl/lib/pkgconfig ./configure


1
पहला विकल्प मुझे देता है configure: error: OpenSSL libs and/or directories were not found where specified!कृपया मेरा संपादन देखें - इसमें कोई त्रुटि नहीं है, --with-ssl=/usr/local/ssl/include/opensslलेकिन पुराने खुलने का उपयोग किया जाता है। दूसरा विकल्प HTTPS के बिना कर्ल को कॉन्फ़िगर करता है
पीटर

हो सकता है कि मैंने निर्देशिकाओं को थोड़ा गलत कर दिया हो, मेरे पास अभी एक लिनक्स बॉक्स तक पहुंच नहीं है ... मूल रूप से, आपके मैनुअल ओपनएसएसएल इंस्टॉलेशन ने एक फ़ाइल को openssl.pcकहीं रखा है, आपको PKG_CONFIG_PATHउस निर्देशिका को इंगित करने की आवश्यकता है जहां वह फ़ाइल है (और सुनिश्चित करें आपने निश्चित रूप से pkg-configस्थापित किया है)।
फकीरेम

1
PKG_CONFIG_PATH पथ सही है, मेरे पास pkg-config भी स्थापित है, लेकिन किसी तरह यह काम नहीं करता है। इसके बिना --with-sslकोई HTTPS नहीं है, --with-sslइसमें त्रुटि हैconfigure: error: OpenSSL libs and/or directories were not found where specified!
पीटर

आपने ssl कहाँ और कैसे स्थापित किया? सही पथ का उपयोग करें।
पैंथर

@ bodhi.zazen मैंने उबंटू पैकेज को आधिकारिक रिपॉजिटरी से संकलित किया है और संकलित खुलता है/usr/local/ssl
पीटर

6
sudo apt-get install libssl-dev
./configure --prefix=/usr --libdir=/usr/lib/x86_64-linux-gnu
sudo make
sudo make install

क्या मुझे ubuntu 15.04 पर कर्ल 7.43 बनाने की आवश्यकता है


सुंदर। यह 19.04 को काम किया। किसी तरह curlमेरा पता नहीं लगा सका openssl, इसलिए मैंने इन सटीक कदमों के साथ किया libssl-devऔर यह आकर्षण की तरह काम किया!
एलेक्स

5

जब मुझे पता चला, जब मैं उसी अभ्यास से गुजर रहा था, तो यह है कि कर्ल केवल ओपनस्लैट स्टैटिक लाइब्रेरी के साथ काम नहीं कर सकता है। यह हमेशा गतिशील की खोज में था, कोई फर्क नहीं पड़ता कि मैं क्या कर रहा था, इसलिए आखिरकार मैंने तीन चीजें कीं जो मेरे लिए काम करती थीं

Configured openssl with enable-shared: ./config enable-shared
Configured curl with openssl: ./configure --with-ssl
Used LD_LIBRARY_PATH: LD_LIBRARY_PATH=/usr/local/lib:/usr/local/ssl/lib /usr/local/bin/curl -V

-V फ्लैग के साथ बाद वाला कमांड कर्ल द्वारा उपयोग किए जाने वाले ओपनसेल संस्करण को दिखाएगा। मैंने यह सुनिश्चित करने के लिए LD_LIBRARY_PATH में / usr / स्थानीय / lib जोड़ा है कि कर्ल सही libcurth संस्करण का उपयोग करता है।


इससे मुझे मदद मिली, खासकर LD_LIBRARY_PATHजो मैंने bash_profile में जोड़ी है। मैंने कुछ ऐसा ही किया, लेकिन पहली पंक्ति के बजाय, मैंने उपयोग किया export CFLAGS=-fPIC; ./config shared(सक्षम-साझा नहीं)। कर्ल के लिए, मैंने इस्तेमाल किया --with-ssl=/usr/local/sslहालांकि पथ arg बेमानी हो सकता है।
mahemoff

1
मुझे खुशी है कि यह आपके लिए काम कर रहा है और हाँ, रास्ते में - साथ ssl बेमानी है, क्योंकि आपने जो प्रदान किया है वह बिल्ड के लिए एक डिफ़ॉल्ट स्थान है।
ओलेग ग्रैब

4

यह मेरे लिए एक लंबा और कठिन रास्ता था। घंटे और घंटे (आप जानते हैं कि यह कैसा है)। यहाँ मैं क्या पाया:

के लिए Ubuntu 12.04 / 14.04 आप के लिए है मैन्युअल रूप से दोनों को स्थापित openssl और कर्ल

मैन्युअल रूप से इंस्टॉल करता है खुलता है 1.0.2g:

sudo apt-get install make # (Install compiling library Make)
wget https://www.openssl.org/source/openssl-1.0.2g.tar.gz # (Download the latest OpenSSL 1.0.2g binaries)
tar -xzvf openssl-1.0.2g.tar.gz # (Extract the tar ball to the local directory)
cd openssl-1.0.2g # (Enter extracted OpenSSL directory)
sudo ./config # (Configure binaries for compiling)
sudo make install # (install configured binaries)
sudo ln -sf /usr/local/ssl/bin/openssl `which openssl` # (This will create a sym link to the new binaries)
openssl version -v

यदि आप NGHTTP2 (वैकल्पिक / अनुशंसित) चाहते हैं:

# Get build requirements
# Some of these are used for the Python bindings
# this package also installs
sudo apt-get install g++ make binutils autoconf automake autotools-dev libtool pkg-config \
  zlib1g-dev libcunit1-dev libssl-dev libxml2-dev libev-dev libevent-dev libjansson-dev \
  libjemalloc-dev cython python3-dev python-setuptools

# Build nghttp2 from source
git clone https://github.com/tatsuhiro-t/nghttp2.git
cd nghttp2
autoreconf -i
automake
autoconf
./configure
make
sudo make install

मैन्युअल रूप से कर्ल स्थापित करें:

cd ~
sudo apt-get build-dep curl
wget http://curl.haxx.se/download/curl-7.46.0.tar.bz2
tar -xvjf curl-7.46.0.tar.bz2
cd curl-7.46.0
./configure --with-nghttp2 --with-ssl --with-libssl-prefix=/usr/local/ssl # This is the line I had the most trouble with, especially figure out --with-libssl-prefix
make
sudo make install
sudo ldconfig

अंतिम चरण

$ sudo ldconfig
$ sudo service apache2 restart # if you're using apache

अब जब आप काम कर रहे हैं, तो कोशिश करें $ curl --versionऔर सुनिश्चित करें कि आपको वहां ओपनस्स्ल का सही संस्करण दिखाई दे। विशेष रूप से Opensl> = 1.0.2g (और nghttp2 यदि आपने इसे चुना है)

$ curl --version
curl 7.50.2 (x86_64-pc-linux-gnu) libcurl/7.50.2 OpenSSL/1.0.2k zlib/1.2.8 nghttp2/1.21.0-DEV
Protocols: dict file ftp ftps gopher http https imap imaps pop3 pop3s rtsp smb smbs smtp smtps telnet tftp 
Features: IPv6 Largefile NTLM NTLM_WB SSL libz TLS-SRP HTTP2 UnixSockets 

उद्धरण: कर्ल opennssl


2
./configure --with-ssl=/usr/lib/ssl --libdir=/usr/lib/x86_64-linux-gnu
sudo make
sudo make install

कुछ घंटों के संघर्ष के बाद मैंने ubuntu 15.05 में libcurl 7.38 के साथ https सक्षम किया


1

मैं स्थिर OpenSSL पुस्तकालयों का उपयोग करके कर्ल संकलन करने में कामयाब रहा। यह tl; dr संस्करण है:

OpenSSL

./config no-shared --prefix=$PWD/_installdir
make depend && make && make install

कर्ल

LIBS="-ldl" ./configure --prefix=$PWD/_installdir --with-ssl=/something/opensslrootdir/_installdir --disable-shared
make && make install

LIBS="-ldl"भाग आवश्यक है।


0

कम्पाइलिंग ओपनसेल उपयोग डिफ़ॉल्ट कॉन्फिगरेशन स्टैटिक लाइब्रेरी को ही उत्पन्न करता है , इसलिए, यदि आप कर्ल में स्टैटिक लाइब्रेरी का उपयोग करना चाहते हैं, तो आप इसे पसंद कर सकते हैं:

LIBS="-ldl -lpthread" ./configure --disable-shared --prefix=/usr/local/curl --with-ssl=/usr/local/ssl

मैंने यहां से जवाब मांगा ।

नोट: इस तरह से केवल कर्ल स्थिर पुस्तकालय उत्पन्न करता है।


0

मैंने आम तौर पर जैक्सनक्रा के उत्तर का पालन किया, लेकिन मुझे उपरोक्त सभी को एक साथ दूसरों की आवश्यकता थी:

LIBS="-ldl" PKG_CONFIG_PATH=/usr/local/ssl/lib/pkgconfig ./configure --with-ssl --with-libssl-prefix=/usr/local/ssl --disable-shared

--disable-shared वैकल्पिक है, मुझे लगता है, यह सिर्फ मुझे इसकी आवश्यकता है

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.