postit2-formadd.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. /***************************************************************************
  2. * _ _ ____ _
  3. * Project ___| | | | _ \| |
  4. * / __| | | | |_) | |
  5. * | (__| |_| | _ <| |___
  6. * \___|\___/|_| \_\_____|
  7. *
  8. * Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
  9. *
  10. * This software is licensed as described in the file COPYING, which
  11. * you should have received as part of this distribution. The terms
  12. * are also available at https://curl.se/docs/copyright.html.
  13. *
  14. * You may opt to use, copy, modify, merge, publish, distribute and/or sell
  15. * copies of the Software, and permit persons to whom the Software is
  16. * furnished to do so, under the terms of the COPYING file.
  17. *
  18. * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
  19. * KIND, either express or implied.
  20. *
  21. * SPDX-License-Identifier: curl
  22. *
  23. ***************************************************************************/
  24. /* <DESC>
  25. * HTTP Multipart formpost with file upload and two additional parts.
  26. * </DESC>
  27. */
  28. /*
  29. * Example code that uploads a filename 'foo' to a remote script that accepts
  30. * "HTML form based" (as described in RFC 1738) uploads using HTTP POST.
  31. *
  32. * Warning: this example uses the deprecated form api. See "postit2.c"
  33. * for a similar example using the mime api.
  34. *
  35. * The imaginary form we fill in looks like:
  36. *
  37. * <form method="post" enctype="multipart/form-data" action="examplepost.cgi">
  38. * Enter file: <input type="file" name="sendfile" size="40">
  39. * Enter filename: <input type="text" name="filename" size="30">
  40. * <input type="submit" value="send" name="submit">
  41. * </form>
  42. */
  43. #include <stdio.h>
  44. #include <string.h>
  45. #include <curl/curl.h>
  46. int main(int argc, char *argv[])
  47. {
  48. CURL *curl;
  49. CURLcode res;
  50. struct curl_httppost *formpost = NULL;
  51. struct curl_httppost *lastptr = NULL;
  52. struct curl_slist *headerlist = NULL;
  53. static const char buf[] = "Expect:";
  54. curl_global_init(CURL_GLOBAL_ALL);
  55. /* Fill in the file upload field */
  56. curl_formadd(&formpost,
  57. &lastptr,
  58. CURLFORM_COPYNAME, "sendfile",
  59. CURLFORM_FILE, "postit2-formadd.c",
  60. CURLFORM_END);
  61. /* Fill in the filename field */
  62. curl_formadd(&formpost,
  63. &lastptr,
  64. CURLFORM_COPYNAME, "filename",
  65. CURLFORM_COPYCONTENTS, "postit2-formadd.c",
  66. CURLFORM_END);
  67. /* Fill in the submit field too, even if this is rarely needed */
  68. curl_formadd(&formpost,
  69. &lastptr,
  70. CURLFORM_COPYNAME, "submit",
  71. CURLFORM_COPYCONTENTS, "send",
  72. CURLFORM_END);
  73. curl = curl_easy_init();
  74. /* initialize custom header list (stating that Expect: 100-continue is not
  75. wanted */
  76. headerlist = curl_slist_append(headerlist, buf);
  77. if(curl) {
  78. /* what URL that receives this POST */
  79. curl_easy_setopt(curl, CURLOPT_URL, "https://example.com/examplepost.cgi");
  80. if((argc == 2) && (!strcmp(argv[1], "noexpectheader")))
  81. /* only disable 100-continue header if explicitly requested */
  82. curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headerlist);
  83. curl_easy_setopt(curl, CURLOPT_HTTPPOST, formpost);
  84. /* Perform the request, res gets the return code */
  85. res = curl_easy_perform(curl);
  86. /* Check for errors */
  87. if(res != CURLE_OK)
  88. fprintf(stderr, "curl_easy_perform() failed: %s\n",
  89. curl_easy_strerror(res));
  90. /* always cleanup */
  91. curl_easy_cleanup(curl);
  92. /* then cleanup the formpost chain */
  93. curl_formfree(formpost);
  94. /* free slist */
  95. curl_slist_free_all(headerlist);
  96. }
  97. return 0;
  98. }