Libcurl timeouts on URLs which are working in my webbrowser
I have this code for curl:
size_t write_to_string(void * ptr,size_t size,size_t nmeb,ResponseStruct * res_struct){
size_t bytes = size*nmeb;
res_struct->length += bytes;
res_struct->response = realloc(res_struct->response, res_struct->length);
strncat(res_struct->response,ptr,bytes);
return bytes;
}
char * get_url_data(char * url){
CURLcode res;
curl_easy_reset(curl);
if(curl){
curl_easy_setopt(curl开发者_开发知识库, CURLOPT_URL, url);
curl_easy_setopt(curl, CURLOPT_TIMEOUT, 10);
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION,write_to_string);
ResponseStruct result;
result.response = malloc(sizeof(char));
result.response[0] = '\0';
result.length = 1;
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &result);
res = curl_easy_perform(curl);
if (res) {
return NULL;
}
return result.response;
}
return NULL;
}
DateData * get_prices(DateData * prior_prices){
char * response = get_url_data("https://mtgox.com/api/0/data/getTrades.php");
char * orig = response;
if (response) {
//Stuff here just calculates price data
errno = 1;
return new_prices;
}
errno = 0;
return prior_prices;
}
The get_prices function will constantly timeout while "http://mtgox.com/api/0/data/getTrades.php" is fine in a web browser.
What is the problem?
Thank you!
Edit dtruss output (Note that connect gives an error...):
SYSCALL(args) = return
__sysctl(0x7FFF5FBFE060, 0x6, 0x0) = 0 0
__sysctl(0x7FFF5FBFE060, 0x6, 0x10084D400) = 0 0
kqueue(0x7FFF5FBFE280, 0x0, 0x50) = 4 0
kevent(0x4, 0x7FFF5FBFE280, 0x1) = 0 0
socket(0x1, 0x1, 0x0) = 5 0
setsockopt(0x5, 0xFFFF, 0x1022) = 0 0
connect_nocancel(0x5, 0x7FFF5FBFE050, 0x6A) = 0 0
sendto_nocancel(0x5, 0x10013D5F0, 0x1C) = 28 0
recvfrom_nocancel(0x5, 0x7FFF5FBFE09C, 0x4) = 4 0
socketpair(0x1, 0x1, 0x0) = 0 0
sendto_nocancel(0x5, 0x100141C80, 0x33) = 51 0
sendmsg_nocancel(0x5, 0x7FFF5FBFDFB0, 0x0) = 1 0
close_nocancel(0x7) = 0 0
recvfrom_nocancel(0x6, 0x7FFF5FBFDFFC, 0x4) = 4 0
close_nocancel(0x6) = 0 0
socketpair(0x1, 0x1, 0x0) = 0 0
sendto_nocancel(0x5, 0x100141C80, 0x33) = 51 0
sendmsg_nocancel(0x5, 0x7FFF5FBFDFB0, 0x0) = 1 0
close_nocancel(0x7) = 0 0
recvfrom_nocancel(0x6, 0x7FFF5FBFDFFC, 0x4) = 4 0
close_nocancel(0x6) = 0 0
kevent(0x4, 0x7FFF5FBFE280, 0x1) = 0 0
kevent(0x4, 0x0, 0x0) = 1 0
kevent(0x4, 0x0, 0x0) = 1 0
recvfrom_nocancel(0x5, 0x7FFF5FBFE0B0, 0x1C) = 28 0
recvfrom_nocancel(0x5, 0x100141D30, 0x21) = 33 0
select_nocancel(0x6, 0x7FFF5FBFE030, 0x0) = 0 0
kevent(0x4, 0x7FFF5FBFDAE0, 0x1) = 0 0
kevent(0x4, 0x0, 0x0) = 1 0
kevent(0x4, 0x0, 0x0) = 0 0
kevent(0x4, 0x0, 0x0) = 1 0
kevent(0x4, 0x0, 0x0) = 1 0
recvfrom_nocancel(0x5, 0x7FFF5FBFE0B0, 0x1C) = 28 0
recvfrom_nocancel(0x5, 0x100141D30, 0x25) = 37 0
select_nocancel(0x6, 0x7FFF5FBFE030, 0x0) = 0 0
kevent(0x4, 0x7FFF5FBFDAE0, 0x1) = 0 0
sendto_nocancel(0x5, 0x100141C90, 0x1C) = 28 0
sendto_nocancel(0x5, 0x100141C90, 0x1C) = 28 0
close_nocancel(0x4) = 0 0
sigaction(0xE, 0x7FFF5FBFE940, 0x0) = 0 0
setitimer(0x0, 0x7FFF5FBFE940, 0x7FFF5FBFE920) = 0 0
socket(0x2, 0x1, 0x6) = 4 0
setsockopt(0x4, 0xFFFF, 0x1022) = 0 0
fcntl(0x4, 0x3, 0x0) = 2 0
fcntl(0x4, 0x4, 0x6) = 0 0
connect(0x4, 0x7FFF5FBFEC20, 0x10) = -1 Err#36
select(0x5, 0x7FFF5FBFE9C0, 0x7FFF5FBFE940, 0x7FFF5FBFE8C0, 0x7FFF5FBFEA60) = 1 0
getsockopt(0x4, 0xFFFF, 0x1007) = 0 0
stat64("/dev/urandom\0", 0x7FFF5FBFE780, 0x0) = 0 0
open_nocancel("/dev/urandom\0", 0x0, 0x1B6) = 6 0
read_nocancel(0x6, "\"\247\326\354\001-\250\263\346\377%Kn\222_X\307^3\372Z\370\233\357[\372\376\247\241\022\336\340K\240\211\027S\335qY\255L\320G\205h\"\f^\266\355\336\345sG\315\337>\367\213&Y\264\371\310\357\017\274\367\370ek7\341]\226\322-\004\330\022\325\304%\212`\307\364e\316M\262\367\020LEM\r{\206\335\257\354%\f\307\242\002#\303\307\360\271\357\226\337\351\0", 0x400) = 1024 0
close_nocancel(0x6) = 0 0
open("/dev/urandom\0", 0x20004, 0x7FFF5FBFE978) = 6 0
fstat64(0x6, 0x7FFF5FBFE970, 0x0) = 0 0
select(0x7, 0x7FFF5FBFEB20, 0x0, 0x0, 0x7FFF5FBFEBA0) = 1 0
read(0x6, "M\004\343\370\204\020\373\243\351\316X\240o\351!c\306\342\210\345}wcB\220\005{\205\177\016\005c\0", 0x20) = 32 0
close(0x6) = 0 0
getuid(0x0, 0x1, 0x0) = 501 0
write(0x4, "\026\003\001\0", 0x73) = 115 0
dtrace: error on enabled probe ID 1770 (ID 18656: syscall::read:return): out of scratch space in action #12 at DIF offset 44
select(0x5, 0x7FFF5FBFEBA0, 0x7FFF5FBFEB20, 0x7FFF5FBFEAA0, 0x7FFF5FBFEC40) = 1 0
read(0x4, "\026\003\001\025'\002\0", 0x7) = 7 0
read(0x4, "\0", 0x1525) = 1353 0
dtrace: error on enabled probe ID 1770 (ID 18656: syscall::read:return): out of scratch space in action #12 at DIF offset 44
select(0x5, 0x7FFF5FBFEBA0, 0x7FFF5FBFEB20, 0x7FFF5FBFEAA0, 0x7FFF5FBFEC40) = 1 0
read(0x4, "crl0\201\216\006\b+\006\001\005\005\a\001\001\004\201\2010\17709\006\b+\006\001\005\005\a0\001\206-http://ocsp.startssl.com/sub/class2/server/ca0B\006\b+\006\001\005\005\a0\002\2066http://aia.startssl.com/certs/sub.class2.server.ca.crt0#\006\003U\035\022\004\0340\032\206\030http://www.startssl.com/0\r\006\t*\206H\206\367\r\001\001\005\005\0", 0xFDC) = 1360 0
dtrace: error on enabled probe ID 1770 (ID 18656: syscall::read:return): out of scratch space in action #12 at DIF offset 44
select(0x5, 0x7FFF5FBFEBA0, 0x7FFF5FBFEB20, 0x7FFF5FBFEAA0, 0x7FFF5FBFEC40) = 1 0
read(0x4, "http://crl.startssl.com/sfsca.crl0\201\200\006\003U\035 \004y0w0u\006\v+\006\001\004\001\201\2657\001\002\0010f0.\006\b+\006\001\005\005\a\002\001\026\"http://www.startssl.com/policy.pdf04\006\b+\006\001\005\005\a\002\001\026(http://www.startssl.com/intermediate.pdf0\r\006\t*\206H\206\367\r\001\001\005\005\0", 0xA8C) = 1360 0
dtrace: error on enabled probe ID 1770 (ID 18656: syscall::read:return): out of scratch space in action #12 at DIF offset 44
select(0x5, 0x7FFF5FBFEBA0, 0x7FFF5FBFEB20, 0x7FFF5FBFEAA0, 0x7FFF5FBFEC40) = 1 0
read(0x4, "nB\343?\336!>{\341\rp\373c\252\250l\032T\264\\%z\311\242\311\213\026\246\273,~\027^\005MXn\022\035\001\356\022\020\r\3062\177\030\377\374\364\372\315n\221\3506I\276\032Hi\213\302\226M\032\022\262i\027\301\n\220\326\372y\"H\277\272{i\370p\307\372z7\330\330\r\322vOW\377\220\267\343\221\322\335\357\302`\267g:\335\376\252\234\360\324\213\177r\"\316\306\237\227\266\370\257\212\240\020\250\331\373\030\306\266\265\\R<\211\266\031*s\001\n\017\003\263\022`\362z/\201\333\243n\377&0\227\365\213\335\211W\266\255=\263\257+\305\267v\002\360\245\326+\232\206\024*r\366\3433\214]\tK\023\337\273\214t\023RK\002\003\001\0", 0x53C) = 1340 0
sigaction(0xD, 0x7FFF5FBFEF10, 0x7FFF5FBFEF40) = 0 0
sigprocmask(0x1, 0x0, 0x7FFF5FBFE950) = 0x0 0
sigaltstack(0x0, 0x7FFF5FBFE940, 0x0) = 0 0
sigaction(0xE, 0x0, 0x7FFF5FBFE9C0) = 0 0
sigaction(0xE, 0x7FFF5FBFE940, 0x0) = 0 0
setitimer(0x0, 0x7FFF5FBFE940, 0x7FFF5FBFE920) = 0 0
socket(0x1E, 0x2, 0x0) = 4 0
close(0x4) = 0 0
select(0x5, 0x7FFF5FBFEEA0, 0x7FFF5FBFEE20, 0x7FFF5FBFEDA0, 0x7FFF5FBFEF40) = 0 0
select(0x5, 0x7FFF5FBFEE00, 0x7FFF5FBFED80, 0x7FFF5FBFED00, 0x7FFF5FBFEEA0) = 0 0
write(0x4, "\026\003\001\001\006\020\0", 0x136) = 310 0
dtrace: error on enabled probe ID 1770 (ID 18656: syscall::read:return): out of scratch space in action #12 at DIF offset 44
select(0x5, 0x7FFF5FBFEBA0, 0x7FFF5FBFEB20, 0x7FFF5FBFEAA0, 0x7FFF5FBFEC40) = 1 0
read(0x4, "\024\003\001\0", 0x5) = 5 0
read(0x4, "\001\0", 0x1) = 1 0
read(0x4, "\026\003\001\0", 0x5) = 5 0
read(0x4, "\177\226\217\004\0339\n\233D\216G\257s\240\332x[i\021\247\333f^\325\225=\345.\350XN/\0", 0x20) = 32 0
write(0x4, "\027\003\001\0", 0x5D) = 93 0
select(0x5, 0x7FFF5FBFEEA0, 0x7FFF5FBFEE20, 0x7FFF5FBFEDA0, 0x7FFF5FBFEF40) = 0 0
select(0x5, 0x7FFF5FBFEE00, 0x7FFF5FBFED80, 0x7FFF5FBFED00, 0x7FFF5FBFEEA0) = 0 0
select(0x5, 0x7FFF5FBFEEA0, 0x7FFF5FBFEE20, 0x7FFF5FBFEDA0, 0x7FFF5FBFEF40) = 0 0
select(0x5, 0x7FFF5FBFEE00, 0x7FFF5FBFED80, 0x7FFF5FBFED00, 0x7FFF5FBFEEA0) = 0 0
select(0x5, 0x7FFF5FBFEEA0, 0x7FFF5FBFEE20, 0x7FFF5FBFEDA0, 0x7FFF5FBFEF40) = 0 0
select(0x5, 0x7FFF5FBFEE00, 0x7FFF5FBFED80, 0x7FFF5FBFED00, 0x7FFF5FBFEEA0) = 0 0
select(0x5, 0x7FFF5FBFEEA0, 0x7FFF5FBFEE20, 0x7FFF5FBFEDA0, 0x7FFF5FBFEF40) = 0 0
select(0x5, 0x7FFF5FBFEE00, 0x7FFF5FBFED80, 0x7FFF5FBFED00, 0x7FFF5FBFEEA0) = 0 0
select(0x5, 0x7FFF5FBFEEA0, 0x7FFF5FBFEE20, 0x7FFF5FBFEDA0, 0x7FFF5FBFEF40) = 0 0
select(0x5, 0x7FFF5FBFEE00, 0x7FFF5FBFED80, 0x7FFF5FBFED00, 0x7FFF5FBFEEA0) = 0 0
select(0x5, 0x7FFF5FBFEEA0, 0x7FFF5FBFEE20, 0x7FFF5FBFEDA0, 0x7FFF5FBFEF40) = 0 0
select(0x5, 0x7FFF5FBFEE00, 0x7FFF5FBFED80, 0x7FFF5FBFED00, 0x7FFF5FBFEEA0) = 0 0
select(0x5, 0x7FFF5FBFEEA0, 0x7FFF5FBFEE20, 0x7FFF5FBFEDA0, 0x7FFF5FBFEF40) = 0 0
select(0x5, 0x7FFF5FBFEE00, 0x7FFF5FBFED80, 0x7FFF5FBFED00, 0x7FFF5FBFEEA0) = 0 0
select(0x5, 0x7FFF5FBFEEA0, 0x7FFF5FBFEE20, 0x7FFF5FBFEDA0, 0x7FFF5FBFEF40) = 0 0
select(0x5, 0x7FFF5FBFEE00, 0x7FFF5FBFED80, 0x7FFF5FBFED00, 0x7FFF5FBFEEA0) = 0 0
select(0x5, 0x7FFF5FBFEEA0, 0x7FFF5FBFEE20, 0x7FFF5FBFEDA0, 0x7FFF5FBFEF40) = 0 0
select(0x5, 0x7FFF5FBFEE00, 0x7FFF5FBFED80, 0x7FFF5FBFED00, 0x7FFF5FBFEEA0) = 0 0
write(0x4, "\025\003\001\0", 0x17) = 23 0
close(0x4) = 0 0
sigaction(0xD, 0x7FFF5FBFEF10, 0x7FFF5FBFEF40) = 0 0
write_nocancel(0x1, "CURL FAILED WITH ERROR CODE 28\n\0", 0x1F) = 31 0
write_nocancel(0x1, "ERROR: There has been an error with retrieving the price data. Check connection.\n\0", 0x51) = 81 0
MtGox requires you to send a User Agent string, or it won't process your request. Unfortunately, this isn't documented anywhere.
Update your code to pass along a user agent string (just copy the one your browser uses) and it should work.
Decided to use tradehill's API instead because it works.
https://api.tradehill.com/APIv1/USD/Trades
Thanks to omrib and nos.
精彩评论