
我现在正在制作官方错误报告,但是有谁知道我怎么能让它发挥作用?
这是我的代码和(logfile)输出:
注意:如果您运行我的程序,请管道到/ dev / null,因为libcurl默认将接收到的缓冲区发送到stdout.
#include <curl/curl.h>#include <string>#include <unistd.h>#include <iostream>using namespace std;voID log(string str){ //Todo: remove static const char logfile[] = "/home/austin/megalog"; file *f = fopen(logfile,"a"); fwrite(str.data(),str.size(),1,f); fclose(f); cout << str;}int main(int argc,char *argv[]){ string url = "https://www.Google.com/"; char errBuf[1024]; CURLcode err; curl_global_init(CURL_GLOBAL_DEFAulT); CURL *handle = curl_easy_init(); curl_easy_setopt(handle,CURLOPT_URL,url.c_str()); curl_easy_setopt(handle,CURLOPT_ERRORBUFFER,errBuf); if ((err = curl_easy_perform(handle))) { log("first request Failed\n"); return 1; } curl_easy_cleanup(handle); if(fork()) return 0; handle = curl_easy_init(); curl_easy_setopt(handle,errBuf); if ((err = curl_easy_perform(handle))) { log(string("curl error while sending: (") + to_string(err) + ") " + curl_easy_strerror(err) + "\n"); log(errBuf); } else log("no error\n"); return 0;} ……和输出:
$g++ -std=c++11 main.cpp -lcurl$rm -f log$./a.out > /dev/null$cat logcurl error while sending: (35) SSL connect errorA PKCS #11 module returned CKR_DEVICE_ERROR,indicating that a problem has occurred with the token or slot.
我正在使用(最新的)libcurl版本7.29.0,(最新的)openssl版本1.0.1e,我正在使用内核版本3.7.4运行Fedora 18.
解决方法 要使其工作,您需要在fork之前调用curl_global_cleanup,在fork之后再次调用curl_global_init. libcurl邮件列表中的某个人提到在初始化需要初始化的库之后调用fork时这是一个常见问题. 总结以上是内存溢出为你收集整理的linux – fork()后的libCurl SSL错误全部内容,希望文章能够帮你解决linux – fork()后的libCurl SSL错误所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)