我无法解决我的代码是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;
}
答案 0 :(得分:2)
您正在使用字符串文字作为strcat
的目标。您需要为指针分配内存,然后将它们用作strcpy
和strcat
函数中的目标
字符串文字通常位于RO区域,写入此类区域可能会调用未定义的行为
更改
等内容char *url
到
char url[100];
还要考虑使用n
版strcat
,strcpy
和适当的缓冲区大小来防止意外缓冲区溢出
答案 1 :(得分:0)
如果不自行分配内存,则无法执行strcat
。
答案 2 :(得分:0)
无论代码中可能出现的错误是什么引用,我在过去的观点中发现libssl的使用默认情况下不是线程安全的。 如果你使用的是libssl,请告诉我们。如果是这样,我将能够提供更多相关信息
请通过陷阱#2 http://horstr.blogspot.in/2008/04/on-libcurl-openssl-and-thread-safety.html 为了更多的启发