Antichat снова доступен.
Форум Antichat (Античат) возвращается и снова открыт для пользователей.
Здесь обсуждаются безопасность, программирование, технологии и многое другое.
Сообщество снова собирается вместе.
Новый адрес: forum.antichat.xyz
 |
|

19.01.2009, 01:05
|
|
Участник форума
Регистрация: 06.05.2008
Сообщений: 161
Провел на форуме: 1289087
Репутация:
59
|
|
Кто нибудь работал с curl под C++?
Как там можно получить ответ сервера в буфер\файл?
curl_easy_perform(test);
Получается исходный код страницы и выводит на экран. А мне надо что бы он выводил в буфер, что бы потом это все дело записать в файл.
На пхп это вроде будет curl_exec, но в С++ такого нет.
|
|
|

19.01.2009, 08:54
|
|
Постоянный
Регистрация: 04.11.2007
Сообщений: 303
Провел на форуме: 811764
Репутация:
119
|
|
Вот, нашел что-то...надеюсь поможет:
http://forum.antichat.ru/showthread.php?p=586452
http://forum.web-hack.ru/index.php?act=ST&f=16&t=49623&go=1
|
|
|

19.01.2009, 11:58
|
|
Познавший АНТИЧАТ
Регистрация: 12.05.2007
Сообщений: 1,235
Провел на форуме: 2238549
Репутация:
1318
|
|
Ознакомься с функцией curl_easy_setopt и параметрами CURLOPT_WRITEFUNCTION и CURLOPT_READFUNCTION. Именно они определяют CALLBACK-функции, которые вызываются библиотекой курл, когда есть данные для чтения и записи. И вообще, начинай изучение какой-либо технологии с документации http://curl.haxx.se/libcurl/c/ тогда 99% вопросов отпадут сами собой.
|
|
|

19.01.2009, 14:21
|
|
Leaders of Antichat - Level 4
Регистрация: 11.11.2005
Сообщений: 391
Провел на форуме: 7084941
Репутация:
2277
|
|
Сообщение от n4e/\@
Кто нибудь работал с curl под C++?
Как там можно получить ответ сервера в буфер\файл?
curl_easy_perform(test);
Получается исходный код страницы и выводит на экран. А мне надо что бы он выводил в буфер, что бы потом это все дело записать в файл.
На пхп это вроде будет curl_exec, но в С++ такого нет.
да работали, и всё норм работает 
а вот пример с документации
Код:
#include <stdio.h>
#include <curl/curl.h>
#include <curl/types.h>
#include <curl/easy.h>
struct MemoryStruct {
char *memory;
size_t size;
};
void *myrealloc(void *ptr, size_t size)
{
/* There might be a realloc() out there that doesn’t like reallocing
NULL pointers, so we take care of it here */
if(ptr)
return realloc(ptr, size);
else
return malloc(size);
}
size_t
WriteMemoryCallback(void *ptr, size_t size, size_t nmemb, void *data)
{
size_t realsize = size * nmemb;
struct MemoryStruct *mem = (struct MemoryStruct *)data;
mem->memory = (char *)myrealloc(mem->memory, mem->size + realsize + 1);
if (mem->memory) {
memcpy(&(mem->memory[mem->size]), ptr, realsize);
mem->size += realsize;
mem->memory[mem->size] = 0;
}
return realsize;
}
int main(int argc, char **argv)
{
CURL *curl_handle;
struct MemoryStruct chunk;
chunk.memory=NULL; /* we expect realloc(NULL, size) to work */
chunk.size = 0; /* no data at this point */
curl_global_init(CURL_GLOBAL_ALL);
/* init the curl session */
curl_handle = curl_easy_init();
/* specify URL to get */
curl_easy_setopt(curl_handle, CURLOPT_URL, “http://cool.haxx.se/”);
/* send all data to this function */
curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
/* we pass our ‘chunk’ struct to the callback function */
curl_easy_setopt(curl_handle, CURLOPT_WRITEDATA, (void *)&chunk);
/* some servers don’t like requests that are made without a user-agent
field, so we provide one */
curl_easy_setopt(curl_handle, CURLOPT_USERAGENT, “libcurl-agent/1.0″);
/* get it! */
curl_easy_perform(curl_handle);
/* cleanup curl stuff */
curl_easy_cleanup(curl_handle);
/*
* Now, our chunk.memory points to a memory block that is chunk.size
* bytes big and contains the remote file.
*
* Do something nice with it!
*
* You should be aware of the fact that at this point we might have an
* allocated data block, and nothing has yet deallocated that data. So when
* you’re done with it, you should free() it as a nice application.
*/
return 0;
}
по образу и подобию сделаешь свое)
|
|
|

23.01.2009, 23:00
|
|
Познающий
Регистрация: 27.09.2008
Сообщений: 57
Провел на форуме: 265628
Репутация:
23
|
|
Доброго времени суток, появился такой вопросец:
Нужно чтобы при запуске программы на панели задач(там где "Пуск"), к примеру, появлялось текстовое поле(что-то типа рекламного поиска во многих прогах), как это можно реализовать?
|
|
|

28.01.2009, 18:22
|
|
Познавший АНТИЧАТ
Регистрация: 01.06.2008
Сообщений: 1,047
Провел на форуме: 5321514
Репутация:
3313
|
|
Нужна функция, которая разбивает строку(char *) через разделитель, и возвращает подстроку по индексу.
char * getSubstr(char * str, const char separator, int index);
Сам написать не могу 
|
|
|

28.01.2009, 19:51
|
|
Pagan Heart
Регистрация: 12.08.2004
Сообщений: 3,791
Провел на форуме: 6490435
Репутация:
2290
|
|
Ну так сделай split по разделителю и возьми нужнй элемент
|
|
|

28.01.2009, 23:21
|
|
Постоянный
Регистрация: 05.05.2006
Сообщений: 743
Провел на форуме: 2982851
Репутация:
107
|
|
существует аналог ф-ции lseek для символьных массивов данных?То есть что бы можно было получить указатель на чтение в таком массиве через заданное кол-во байт.
|
|
|

29.01.2009, 17:01
|
|
Новичок
Регистрация: 23.07.2008
Сообщений: 28
Провел на форуме: 104504
Репутация:
1
|
|
Всем доброго времени суток! Возникла такая проблемка с объявлением двумерного массива в Visual Studio 2008:
int c1[2][2]={{6,7},{1,2}};
Выдает следующее:
error C2059: syntax error : '{'
error C2334: unexpected token(s) preceding '{'; skipping apparent function body
Вроде массив объявил верно, GCC под линуксом компилирует без проблем.
|
|
|

29.01.2009, 17:11
|
|
Познавший АНТИЧАТ
Регистрация: 12.05.2007
Сообщений: 1,235
Провел на форуме: 2238549
Репутация:
1318
|
|
Неправда, такое откомпилится любым компилятором... Или у тебя что-то там ещё имеет неправильный синтаксис, либо я не знаю...
|
|
|
|
 |
|
|
Здесь присутствуют: 1 (пользователей: 0 , гостей: 1)
|
|
|
|