1

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);
4

1 に答える 1

4

curl_formaddのオプションCURLFORM_CONTENTTYPEを探しています。

于 2013-02-04T12:46:08.843 に答える