简单的libcurl应用程序 - 段错误

时间:2012-04-28 10:01:41

标签: c++ c curl segmentation-fault libcurl

我无法解决我的代码是segfaulting的问题?

基本上它通过SSL(HTTPS)安全连接连接到服务器并进行GET,提供MachineID(程序将其作为参数)。

还应设置一些自定义标头。然后我保存返回的正文和标题,作为单独的文本文件。 (基本上它将运行一个shell脚本,因此我的远程系统可以自动从我的服务器获取'订单')

但它的段错误和我唯一需要开发的Linux机器是我的VPS,由于它的奇怪的虚拟化,总是崩溃加载GDB ......:o

谁能告诉我问题出在哪里? - 我认为它几乎可以肯定在我的字符串连接 - 我建立标题,并请求URL。

编辑:Duh,忘了密码!

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <curl/curl.h>
#include <string.h>

 static size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream)
{
 int written = fwrite(ptr, size, nmemb, (FILE *)stream);
 return written;
}

int main(int argc, char *argv[])
{
static const char *headerfilename = "head.out";
static const char *bodyfilename = "body.out";

char *url = "https://fakeserver.fakesite.com:8443/SystemManager/getOrders.jsp?machineID=";
char *customHeader = "MachineID:";
char *machineID = NULL;

struct curl_slist *chunk = NULL;

CURL *curl;
CURLcode res;
FILE *headerfile;
FILE *bodyfile;

    if (argc == 2)
{
    machineID = argv[1];
    strcat(url,machineID);
}
else
{
 printf("Usage: %s <MachineID>\n", argv[0]);
 return 1;
}

 curl_global_init(CURL_GLOBAL_SSL);

 // init the curl session 
 curl = curl_easy_init();

 if(curl) {
    // set URL to get 

 curl_easy_setopt(curl, CURLOPT_URL, url);

    // no progress meter please 
    curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 1L);

    // send all data to this function 
 curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_data);

 // some servers don't like requests that are made without a user-agent field, so we provide one 
 curl_easy_setopt(curl, CURLOPT_USERAGENT, "libcurl-agent/1.0");

 // Also add a custom MachineID header 
 strcat(customHeader, machineID);
 chunk = curl_slist_append(chunk, customHeader);
 res = curl_easy_setopt(curl, CURLOPT_HTTPHEADER, chunk);

    // These tweaks must be enabled for my dodgy self-signed certificate.

    // DONT bother verifying our certificate is signed by a trusted CA.
    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L);
    // DONT check the hostname on the certificate matcheds the remote system.
    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L);


    // open the files 
 headerfile = fopen(headerfilename,"w");
 if (headerfile == NULL) {
 curl_easy_cleanup(curl);
 return -1;
 }
 else
 {
 // we want the headers to this file handle 
 curl_easy_setopt(curl, CURLOPT_WRITEHEADER, headerfile);
 }

 bodyfile = fopen(bodyfilename,"w");
 if (bodyfile == NULL) {
 curl_easy_cleanup(curl);
 return -1;
 }
 else
 {
 // we want the body to this file handle 
 curl_easy_setopt(curl, CURLOPT_WRITEDATA, bodyfile);
 }
     // get it! 
 res = curl_easy_perform(curl);

    // close the files 
 fclose(headerfile);
 fclose(bodyfile);

 // always cleanup curl stuff 
 curl_easy_cleanup(curl);
 }
 curl_global_cleanup();
 return 0;
}

3 个答案:

答案 0 :(得分:2)

您正在使用字符串文字作为strcat的目标。您需要为指针分配内存,然后将它们用作strcpystrcat函数中的目标

字符串文字通常位于RO区域,写入此类区域可能会调用未定义的行为

更改

等内容
char *url

char url[100];

还要考虑使用nstrcatstrcpy和适当的缓冲区大小来防止意外缓冲区溢出

答案 1 :(得分:0)

如果不自行分配内存,则无法执行strcat

答案 2 :(得分:0)

无论代码中可能出现的错误是什么引用,我在过去的观点中发现libssl的使用默认情况下不是线程安全的。 如果你使用的是libssl,请告诉我们。如果是这样,我将能够提供更多相关信息

请通过陷阱#2 http://horstr.blogspot.in/2008/04/on-libcurl-openssl-and-thread-safety.html 为了更多的启发