Создание нового каталога с помощью libcurl

0

Я возился с libcurl, и пока это приятно. У меня есть несколько вещей, которые меня сбивают с толку. Мне нужно создать каталог для удаленного сервера, и вот проблемы

  1. Что я могу передать в CURLOPT_URL? Является ли это корневым URL-адресом или полным каталогом?

  2. Я хочу эффект ряби в создании каталога, который, если у меня есть diectory/abc/def/ghi, тогда они должны быть созданы, если они не существуют. Я пробовал CURLOPT_FTP_CREATE_MISSING_DIRS, но не работает.

  3. Пробовал MKD, он терпит неудачу, и я не могу точно сказать, почему. Ниже приведены соответствующий код и журнал из приложения.

КОД

CURL* handle = curl_easy_init();

SetHandleOptions(handle); //set options

CURLcode res;
wxString uploadUrl =....;//full URL with path like ftp.xyz.com/public_html/dir1/
wxString command1 = "MKD "+uploadUrl;
wxString command2 = "CWD "+uploadUrl;
struct curl_slist *headers = NULL;
headers = curl_slist_append(headers, command1.c_str());
headers = curl_slist_append(headers, command2.c_str());
curl_easy_setopt(handle, CURLOPT_QUOTE, headers);
const char* uploadUrlStr = uploadUrl.c_str();

if(handle)
{
    //do file upload here
    /* upload to this place */
    curl_easy_setopt(handle, CURLOPT_URL, uploadUrlStr);
    /* enable verbose for easier tracing */
    curl_easy_setopt(handle, CURLOPT_VERBOSE, 1L);
    curl_easy_setopt(handle, CURLOPT_FTP_CREATE_MISSING_DIRS, 1L);
    curl_easy_setopt(handle, CURLOPT_QUOTE, headers);

    res = curl_easy_perform(handle);

    if(res==CURLE_OK)
    {
        SendMessage(_("Successfully Created Directory: ")+uploadUrl, HERROR_TYPE_WARNING);
    }
    else
    {
        //send error message
        wxString str(curl_easy_strerror(res));
        SendMessage(str);
    }
    /* always cleanup */
    curl_easy_cleanup(handle);

}
else
{
    SendMessage(_("Could Not Connect to Server: Invalid Handle"), HERROR_TYPE_CRITICAL);
}

curl_slist_free_all(headers);

ЖУРНАЛ

----------Wed Dec 18 01:33:15 2013---------- 
Changing Directory to / [01:33:20]
Successfully logged In [01:33:21]
No error [01:33:24]
Starting Files List Fetching... [01:33:24]
No error [01:33:26]
 [01:33:32]
IDN support not present, can't parse Unicode domains
 [01:33:32]
About to connect() to ftp.hosanna.site40.net port 21 (#2)
 [01:33:33]
  Trying 31.170.162.203...
 [01:33:33]
Adding handle: conn: 0x7fffd0013110
 [01:33:33]
Adding handle: send: 0
 [01:33:33]
Adding handle: recv: 0
 [01:33:33]
Curl_addHandleToPipeline: length: 1
 [01:33:33]
- Conn 2 (0x7fffd0013110) send_pipe: 1, recv_pipe: 0
 [01:33:33]
 [01:33:33]
 [01:33:33]
Closing connection 3
 [01:33:33]
Couldn't resolve host name [01:33:33]
Connected to ftp.hosanna.site40.net (31.170.162.203) port 21 (#2)
 [01:33:34]
220---------- Welcome to Pure-FTPd [privsep] ----------
220-You are user number 9 of 500 allowed.
220-Local time is now 17:33. Server port: 21.
220-This is a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:35]
220-You are user number 9 of 500 allowed.
220-Local time is now 17:33. Server port: 21.
220-This is a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:35]
220-Local time is now 17:33. Server port: 21.
220-This is a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:35]
220-This is a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:35]
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:35]
USER xxxxxx
 [01:33:35]
331 User xxxxxx OK. Password required
tes of inactivity.
-You are user number 9 of 500 allowed.
220-Local time is now 17:33. Server port: 21.
220-This is a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:35]
PASS xxxxxx
 [01:33:35]
230-OK. Current restricted directory is /
230-124 files used (1%) - authorized: 10000 files
230 3051 Kbytes used (0%) - authorized: 1536000 Kb

220-This is a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:36]
230-124 files used (1%) - authorized: 10000 files
230 3051 Kbytes used (0%) - authorized: 1536000 Kb

220-This is a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:36]
230 3051 Kbytes used (0%) - authorized: 1536000 Kb

220-This is a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:36]
PWD
 [01:33:36]
257 "/" is your current location
ized: 1536000 Kb
files used (1%) - authorized: 10000 files
230 3051 Kbytes used (0%) - authorized: 1536000 Kb
 [01:33:37]
Entry path is '/'
 [01:33:37]
MKD ftp://ftp.hosanna.site40.net/public_html/Zulu names and meanings
 [01:33:37]
ftp_perform ends with SECONDARY: 0
 [01:33:37]
550-Can't create directory: No such file or directory
550-124 files used (1%) - authorized: 10000 files
550 3051 Kbytes used (0%) - authorized: 1536000 Kb
 a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:37]
550-124 files used (1%) - authorized: 10000 files
550 3051 Kbytes used (0%) - authorized: 1536000 Kb
 a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:37]
550 3051 Kbytes used (0%) - authorized: 1536000 Kb
 a private system - No anonymous login
220 You will be disconnected after 3 minutes of inactivity.
 [01:33:37]
QUOT command failed with 550
 [01:33:37]
Closing connection 2
 [01:33:37]
Quote command returned error [01:33:37]
Теги:
ftp
libcurl

1 ответ

1
Лучший ответ

Убедитесь, что пути находятся в форме /public_html/somedir, а не ftp://ftp.somesite.com/public_html/somedir

Вот что случилось с моим кодом. Поэтому я решил удалить URL. Я считаю, что должен быть раздел о libcurl, объясняющий формат ожидаемых URL-адресов. Я буду вносить свой вклад, когда я полностью пойму это!

Ещё вопросы

Сообщество Overcoder
Наверх
Меню