本文章今天來給大家介紹一個libcurl升級後找不到libcurl.so.3解決之法,希望對各位朋友有幫助呀。
系統裝的是libcurl 7.19的版本,編譯的動態庫是libcurl.so.4
自己的程序編譯是在libcurl 7.15的版本下編譯的,用的是libcurl.so.3的版本,要做下軟鏈接即可:
根據自己使用的是32位系統或者64位系統 做如下處理:
cd /usr/lib 或者 cd /usr/lib64
ln -s libcurl.so.4 libcurl.so.3
libcurl主要功能就是用不同的協議連接和溝通不同的服務器~也就是相當封裝了的sockPHP 支持libcurl(允許你用不同的協議連接和溝通不同的服務器)。, libcurl當前支持http, https, ftp, gopher, telnet, dict, file, 和ldap 協議。libcurl同樣支持HTTPS證書授權,HTTP POST, HTTP PUT, FTP 上傳(當然你也可以使用PHP的ftp擴展), HTTP基本表單上傳,代理,cookies,和用戶認證。
給出我的一個簡單的代碼例子:
說明:
1.關鍵在curl_easy_setopt函數設置option,可以設置ftp,http,get,post等許多選項,請根據具體使用情況設置。
2.對取回來的數據需要進行判斷,比如http下載文件,如果文件不存在,需要進行處理。因為writer是可以將buf填充404 not found等網頁內容的,不能將這個內容當成文件內容,所以需要判斷http web返回來的code,進行判斷。
3.我有個問題,就是想得到服務器上filename的具體名稱,verbose調試已經返回了,但是我在getinfo的時候,試過好多選項,但未找到這個存放真實服務器文件名的選項,如果有知道的麻煩告訴我,謝謝了!
代碼如下 復制代碼
#include "curl/curl.h"
#pragma comment(lib, "libcurl.lib")
long writer(void *data, int size, int nmemb, string &content);
bool CurlInit(CURL *&curl, const char* url,string &content);
bool GetURLDataBycurl(const char* URL, string &content);
void main()
{
char *url ="http://www.bKjia.c0m";
string content;
if ( GetURLDataBycurl(url,content))
{
printf("%sn",content);
}
getchar();
}
bool CurlInit(CURL *&curl, const char* url,string &content)
{
CURLcode code;
string error;
curl = curl_easy_init();
if (curl == NULL)
{
printf( "Failed to create CURL connectionn");
return false;
}
code = curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, error);
if (code != CURLE_OK)
{
printf( "Failed to set error buffer [%d]n", code );
return false;
}
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
code = curl_easy_setopt(curl, CURLOPT_URL, url);
if (code != CURLE_OK)
{
printf("Failed to set URL [%s]n", error);
return false;
}
code = curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
if (code != CURLE_OK)
{
printf( "Failed to set redirect option [%s]n", error );
return false;
}
code = curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, writer);
if (code != CURLE_OK)
{
printf( "Failed to set writer [%s]n", error);
return false;
}
code = curl_easy_setopt(curl, CURLOPT_WRITEDATA, &content);
if (code != CURLE_OK)
{
printf( "Failed to set write data [%s]n", error );
return false;
}
return true;
}
long writer(void *data, int size, int nmemb, string &content)
{
long sizes = size * nmemb;
string temp(data,sizes);
content += temp;
return sizes;
}
bool GetURLDataBycurl(const char* URL, string &content)
{
CURL *curl = NULL;
CURLcode code;
string error;
code = curl_global_init(CURL_GLOBAL_DEFAULT);
if (code != CURLE_OK)
{
printf( "Failed to global init default [%d]n", code );
return false;
}
if ( !CurlInit(curl,URL,content) )
{
printf( "Failed to global init default [%d]n" );
return PM_FALSE;
}
code = curl_easy_perform(curl);
if (code != CURLE_OK)
{
printf( "Failed to get '%s' [%s]n", URL, error);
return false;
}
long retcode = 0;
code = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE , &retcode);
if ( (code == CURLE_OK) && retcode == 200 )
{
double length = 0;
code = curl_easy_getinfo(curl, CURLINFO_CONTENT_LENGTH_DOWNLOAD , &length);
printf("%d",retcode);
FILE * file = fopen("1.gif","wb");
fseek(file,0,SEEK_SET);
fwrite(content.c_str(),1,length,file);
fclose(file);
//struct curl_slist *list;
//code = curl_easy_getinfo(curl,CURLINFO_COOKIELIST,&list);
//curl_slist_free_all (list);
return true;
}
else
{
// debug1( "%s n ",getStatusCode(retcode));
return false;
}
curl_easy_cleanup(curl);
return false;
}