Webサーバーにファイルをアップロードするためのlibcurlを含む次のCコードがあります。アップロードする必要がある唯一の問題は、「Content-Type:application / vnd.ms-excel」ですが、「Content-Type:application/」になります。 octet-stream」、ヘッダーで試しましたが、今は運がいいです。PHPではcurlを使用するのは簡単ですが、私はそれを実行して問題curl_setopt($ch, CURLOPT_POSTFIELDS, array("importfile" => "@".$file_path . ";type=application/vnd.ms-excel"
なく動作します。何か助けはありますか?アイデア?
#include <stdio.h>
#include <string.h>
#include <curl/curl.h>
int main(int argc, char *argv[])
{
CURL *curl;
CURLcode res;
struct curl_httppost *formpost=NULL;
struct curl_httppost *lastptr=NULL;
struct curl_slist *headerlist=NULL;
static const char buf[] = "Expect:";
curl_global_init(CURL_GLOBAL_ALL);
curl_formadd(&formpost, &lastptr, CURLFORM_COPYNAME, "importfile", CURLFORM_FILE, "document.csv", CURLFORM_END);
curl_formadd(&formpost, &lastptr, CURLFORM_COPYNAME, "action", CURLFORM_COPYCONTENTS, "upload", CURLFORM_END);
curl = curl_easy_init();
headerlist = curl_slist_append(headerlist, buf);
if(curl) {
curl_easy_setopt(curl, CURLOPT_URL, "http://www.myhost.com/upload/upload.php");
if ( (argc == 2) && (!strcmp(argv[1], "noexpectheader")) )
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headerlist);
curl_easy_setopt(curl, CURLOPT_HTTPPOST, formpost);
res = curl_easy_perform(curl);
if(res != CURLE_OK)
fprintf(stderr, "curl_easy_perform() failed: %s\n",
curl_easy_strerror(res));
curl_easy_cleanup(curl);
curl_formfree(formpost);
curl_slist_free_all (headerlist);
}
return 0;
}
HEADERを「Content-Type:application / vnd.ms-excel」として追加しようとしましたが、正しくありません。次のようになります。
Content-Type: application/vnd.ms-excel
ヘッダーにありますが、私は持っている必要があります:
------WebbbbFormBoundaryXaI1UTNwqAyKWvLT
Content-Disposition: form-data; name="importfile"; filename="document.csv"
Content-Type: application/vnd.ms-excel
代わりに私は得る:
------WebbbbFormBoundaryXaI1UTNwqAyKWvLT
Content-Disposition: form-data; name="importfile"; filename="document.csv"
Content-Type: application/octet-stream
助けてくれてありがとう、答えは:
curl_formadd(&formpost, &lastptr, CURLFORM_COPYNAME, "importfile", CURLFORM_FILE, "document.csv", CURLFORM_CONTENTTYPE, "application/vnd.ms-excel", CURLFORM_END);