Annotation of embedaddon/curl/docs/libcurl/curl_formadd.3, revision 1.1

1.1     ! misho       1: .\" **************************************************************************
        !             2: .\" *                                  _   _ ____  _
        !             3: .\" *  Project                     ___| | | |  _ \| |
        !             4: .\" *                             / __| | | | |_) | |
        !             5: .\" *                            | (__| |_| |  _ <| |___
        !             6: .\" *                             \___|\___/|_| \_\_____|
        !             7: .\" *
        !             8: .\" * Copyright (C) 1998 - 2020, 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.haxx.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: .\" **************************************************************************
        !            22: .TH curl_formadd 3 "March 23, 2020" "libcurl 7.70.0" "libcurl Manual"
        !            23: 
        !            24: .SH NAME
        !            25: curl_formadd - add a section to a multipart/formdata HTTP POST
        !            26: .SH SYNOPSIS
        !            27: .B #include <curl/curl.h>
        !            28: .sp
        !            29: .BI "CURLFORMcode curl_formadd(struct curl_httppost ** " firstitem,
        !            30: .BI "struct curl_httppost ** " lastitem, " ...);"
        !            31: .ad
        !            32: .SH DESCRIPTION
        !            33: This function is deprecated. Do not use! See \fIcurl_mime_init(3)\fP instead!
        !            34: 
        !            35: curl_formadd() is used to append sections when building a multipart/formdata
        !            36: HTTP POST (sometimes referred to as RFC2388-style posts). Append one section
        !            37: at a time until you've added all the sections you want included and then you
        !            38: pass the \fIfirstitem\fP pointer as parameter to \fICURLOPT_HTTPPOST(3)\fP.
        !            39: \fIlastitem\fP is set after each \fIcurl_formadd(3)\fP call and on repeated
        !            40: invokes it should be left as set to allow repeated invokes to find the end of
        !            41: the list faster.
        !            42: 
        !            43: After the \fIlastitem\fP pointer follow the real arguments.
        !            44: 
        !            45: The pointers \fIfirstitem\fP and \fIlastitem\fP should both be pointing to
        !            46: NULL in the first call to this function. All list-data will be allocated by
        !            47: the function itself. You must call \fIcurl_formfree(3)\fP on the
        !            48: \fIfirstitem\fP after the form post has been done to free the resources.
        !            49: 
        !            50: Using POST with HTTP 1.1 implies the use of a "Expect: 100-continue" header.
        !            51: You can disable this header with \fICURLOPT_HTTPHEADER(3)\fP as usual.
        !            52: 
        !            53: First, there are some basics you need to understand about multipart/formdata
        !            54: posts. Each part consists of at least a NAME and a CONTENTS part. If the part
        !            55: is made for file upload, there are also a stored CONTENT-TYPE and a FILENAME.
        !            56: Below, we'll discuss what options you use to set these properties in the
        !            57: parts you want to add to your post.
        !            58: 
        !            59: The options listed first are for making normal parts. The options from
        !            60: \fICURLFORM_FILE\fP through \fICURLFORM_BUFFERLENGTH\fP are for file upload
        !            61: parts.
        !            62: .SH OPTIONS
        !            63: .IP CURLFORM_COPYNAME
        !            64: followed by a string which provides the \fIname\fP of this part. libcurl
        !            65: copies the string so your application doesn't need to keep it around after
        !            66: this function call. If the name isn't NUL-terminated, you must set its length
        !            67: with \fBCURLFORM_NAMELENGTH\fP. The \fIname\fP is not allowed to contain
        !            68: zero-valued bytes. The copied data will be freed by \fIcurl_formfree(3)\fP.
        !            69: .IP CURLFORM_PTRNAME
        !            70: followed by a string which provides the \fIname\fP of this part. libcurl
        !            71: will use the pointer and refer to the data in your application, so you
        !            72: must make sure it remains until curl no longer needs it. If the name
        !            73: isn't NUL-terminated, you must set its length with \fBCURLFORM_NAMELENGTH\fP.
        !            74: The \fIname\fP is not allowed to contain zero-valued bytes.
        !            75: .IP CURLFORM_COPYCONTENTS
        !            76: followed by a pointer to the contents of this part, the actual data
        !            77: to send away. libcurl copies the provided data, so your application doesn't
        !            78: need to keep it around after this function call. If the data isn't null
        !            79: terminated, or if you'd like it to contain zero bytes, you must
        !            80: set the length of the name with \fBCURLFORM_CONTENTSLENGTH\fP. The copied
        !            81: data will be freed by \fIcurl_formfree(3)\fP.
        !            82: .IP CURLFORM_PTRCONTENTS
        !            83: followed by a pointer to the contents of this part, the actual data
        !            84: to send away. libcurl will use the pointer and refer to the data in your
        !            85: application, so you must make sure it remains until curl no longer needs it.
        !            86: If the data isn't NUL-terminated, or if you'd like it to contain zero bytes,
        !            87: you must set its length  with \fBCURLFORM_CONTENTSLENGTH\fP.
        !            88: .IP CURLFORM_CONTENTLEN
        !            89: followed by a curl_off_t value giving the length of the contents. Note that
        !            90: for \fICURLFORM_STREAM\fP contents, this option is mandatory.
        !            91: 
        !            92: If you pass a 0 (zero) for this option, libcurl will instead do a strlen() on
        !            93: the contents to figure out the size. If you really want to send a zero byte
        !            94: content then you must make sure strlen() on the data pointer returns zero.
        !            95: 
        !            96: (Option added in 7.46.0)
        !            97: .IP CURLFORM_CONTENTSLENGTH
        !            98: (This option is deprecated. Use \fICURLFORM_CONTENTLEN\fP instead!)
        !            99: 
        !           100: followed by a long giving the length of the contents. Note that for
        !           101: \fICURLFORM_STREAM\fP contents, this option is mandatory.
        !           102: 
        !           103: If you pass a 0 (zero) for this option, libcurl will instead do a strlen() on
        !           104: the contents to figure out the size. If you really want to send a zero byte
        !           105: content then you must make sure strlen() on the data pointer returns zero.
        !           106: .IP CURLFORM_FILECONTENT
        !           107: followed by a filename, causes that file to be read and its contents used
        !           108: as data in this part. This part does \fInot\fP automatically become a file
        !           109: upload part simply because its data was read from a file.
        !           110: 
        !           111: The specified file needs to kept around until the associated transfer is done.
        !           112: .IP CURLFORM_FILE
        !           113: followed by a filename, makes this part a file upload part. It sets the
        !           114: \fIfilename\fP field to the basename of the provided filename, it reads the
        !           115: contents of the file and passes them as data and sets the content-type if the
        !           116: given file match one of the internally known file extensions.  For
        !           117: \fBCURLFORM_FILE\fP the user may send one or more files in one part by
        !           118: providing multiple \fBCURLFORM_FILE\fP arguments each followed by the filename
        !           119: (and each \fICURLFORM_FILE\fP is allowed to have a
        !           120: \fICURLFORM_CONTENTTYPE\fP).
        !           121: 
        !           122: The given upload file has to exist in its full in the file system already when
        !           123: the upload starts, as libcurl needs to read the correct file size beforehand.
        !           124: 
        !           125: The specified file needs to kept around until the associated transfer is done.
        !           126: .IP CURLFORM_CONTENTTYPE
        !           127: is used in combination with \fICURLFORM_FILE\fP. Followed by a pointer to a
        !           128: string which provides the content-type for this part, possibly instead of an
        !           129: internally chosen one.
        !           130: .IP CURLFORM_FILENAME
        !           131: is used in combination with \fICURLFORM_FILE\fP. Followed by a pointer to a
        !           132: string, it tells libcurl to use the given string as the \fIfilename\fP in the
        !           133: file upload part instead of the actual file name.
        !           134: .IP CURLFORM_BUFFER
        !           135: is used for custom file upload parts without use of \fICURLFORM_FILE\fP.  It
        !           136: tells libcurl that the file contents are already present in a buffer.  The
        !           137: parameter is a string which provides the \fIfilename\fP field in the content
        !           138: header.
        !           139: .IP CURLFORM_BUFFERPTR
        !           140: is used in combination with \fICURLFORM_BUFFER\fP. The parameter is a pointer
        !           141: to the buffer to be uploaded. This buffer must not be freed until after
        !           142: \fIcurl_easy_cleanup(3)\fP is called. You must also use
        !           143: \fICURLFORM_BUFFERLENGTH\fP to set the number of bytes in the buffer.
        !           144: .IP CURLFORM_BUFFERLENGTH
        !           145: is used in combination with \fICURLFORM_BUFFER\fP. The parameter is a
        !           146: long which gives the length of the buffer.
        !           147: .IP CURLFORM_STREAM
        !           148: Tells libcurl to use the \fICURLOPT_READFUNCTION(3)\fP callback to get
        !           149: data. The parameter you pass to \fICURLFORM_STREAM\fP is the pointer passed on
        !           150: to the read callback's fourth argument. If you want the part to look like a
        !           151: file upload one, set the \fICURLFORM_FILENAME\fP parameter as well. Note that
        !           152: when using \fICURLFORM_STREAM\fP, \fICURLFORM_CONTENTSLENGTH\fP must also be
        !           153: set with the total expected length of the part unless the formpost is sent
        !           154: chunked encoded. (Option added in libcurl 7.18.2)
        !           155: .IP CURLFORM_ARRAY
        !           156: Another possibility to send options to curl_formadd() is the
        !           157: \fBCURLFORM_ARRAY\fP option, that passes a struct curl_forms array pointer as
        !           158: its value. Each curl_forms structure element has a CURLformoption and a char
        !           159: pointer. The final element in the array must be a CURLFORM_END. All available
        !           160: options can be used in an array, except the CURLFORM_ARRAY option itself!  The
        !           161: last argument in such an array must always be \fBCURLFORM_END\fP.
        !           162: .IP CURLFORM_CONTENTHEADER
        !           163: specifies extra headers for the form POST section.  This takes a curl_slist
        !           164: prepared in the usual way using \fBcurl_slist_append\fP and appends the list
        !           165: of headers to those libcurl automatically generates. The list must exist while
        !           166: the POST occurs, if you free it before the post completes you may experience
        !           167: problems.
        !           168: 
        !           169: When you've passed the HttpPost pointer to \fIcurl_easy_setopt(3)\fP (using
        !           170: the \fICURLOPT_HTTPPOST(3)\fP option), you must not free the list until after
        !           171: you've called \fIcurl_easy_cleanup(3)\fP for the curl handle.
        !           172: 
        !           173: See example below.
        !           174: .SH AVAILABILITY
        !           175: Deprecated in 7.56.0. Before this release, field names were allowed to
        !           176: contain zero-valued bytes. The pseudo-filename "-" to read stdin is
        !           177: discouraged although still supported, but data is not read before being
        !           178: actually sent: the effective data size can then not be automatically
        !           179: determined, resulting in a chunked encoding transfer. Backslashes and
        !           180: double quotes in field and file names are now escaped before transmission.
        !           181: .SH RETURN VALUE
        !           182: 0 means everything was ok, non-zero means an error occurred corresponding
        !           183: to a CURL_FORMADD_* constant defined in
        !           184: .I <curl/curl.h>
        !           185: .SH EXAMPLE
        !           186: .nf
        !           187: 
        !           188:  struct curl_httppost* post = NULL;
        !           189:  struct curl_httppost* last = NULL;
        !           190:  char namebuffer[] = "name buffer";
        !           191:  long namelength = strlen(namebuffer);
        !           192:  char buffer[] = "test buffer";
        !           193:  char htmlbuffer[] = "<HTML>test buffer</HTML>";
        !           194:  long htmlbufferlength = strlen(htmlbuffer);
        !           195:  struct curl_forms forms[3];
        !           196:  char file1[] = "my-face.jpg";
        !           197:  char file2[] = "your-face.jpg";
        !           198:  /* add null character into htmlbuffer, to demonstrate that
        !           199:     transfers of buffers containing null characters actually work
        !           200:  */
        !           201:  htmlbuffer[8] = '\\0';
        !           202: 
        !           203:  /* Add simple name/content section */
        !           204:  curl_formadd(&post, &last, CURLFORM_COPYNAME, "name",
        !           205:               CURLFORM_COPYCONTENTS, "content", CURLFORM_END);
        !           206: 
        !           207:  /* Add simple name/content/contenttype section */
        !           208:  curl_formadd(&post, &last, CURLFORM_COPYNAME, "htmlcode",
        !           209:               CURLFORM_COPYCONTENTS, "<HTML></HTML>",
        !           210:               CURLFORM_CONTENTTYPE, "text/html", CURLFORM_END);
        !           211: 
        !           212:  /* Add name/ptrcontent section */
        !           213:  curl_formadd(&post, &last, CURLFORM_COPYNAME, "name_for_ptrcontent",
        !           214:               CURLFORM_PTRCONTENTS, buffer, CURLFORM_END);
        !           215: 
        !           216:  /* Add ptrname/ptrcontent section */
        !           217:  curl_formadd(&post, &last, CURLFORM_PTRNAME, namebuffer,
        !           218:               CURLFORM_PTRCONTENTS, buffer, CURLFORM_NAMELENGTH,
        !           219:               namelength, CURLFORM_END);
        !           220: 
        !           221:  /* Add name/ptrcontent/contenttype section */
        !           222:  curl_formadd(&post, &last, CURLFORM_COPYNAME, "html_code_with_hole",
        !           223:               CURLFORM_PTRCONTENTS, htmlbuffer,
        !           224:               CURLFORM_CONTENTSLENGTH, htmlbufferlength,
        !           225:               CURLFORM_CONTENTTYPE, "text/html", CURLFORM_END);
        !           226: 
        !           227:  /* Add simple file section */
        !           228:  curl_formadd(&post, &last, CURLFORM_COPYNAME, "picture",
        !           229:               CURLFORM_FILE, "my-face.jpg", CURLFORM_END);
        !           230: 
        !           231:  /* Add file/contenttype section */
        !           232:  curl_formadd(&post, &last, CURLFORM_COPYNAME, "picture",
        !           233:               CURLFORM_FILE, "my-face.jpg",
        !           234:               CURLFORM_CONTENTTYPE, "image/jpeg", CURLFORM_END);
        !           235: 
        !           236:  /* Add two file section */
        !           237:  curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures",
        !           238:               CURLFORM_FILE, "my-face.jpg",
        !           239:               CURLFORM_FILE, "your-face.jpg", CURLFORM_END);
        !           240: 
        !           241:  /* Add two file section using CURLFORM_ARRAY */
        !           242:  forms[0].option = CURLFORM_FILE;
        !           243:  forms[0].value  = file1;
        !           244:  forms[1].option = CURLFORM_FILE;
        !           245:  forms[1].value  = file2;
        !           246:  forms[2].option  = CURLFORM_END;
        !           247: 
        !           248:  /* Add a buffer to upload */
        !           249:  curl_formadd(&post, &last,
        !           250:               CURLFORM_COPYNAME, "name",
        !           251:               CURLFORM_BUFFER, "data",
        !           252:               CURLFORM_BUFFERPTR, record,
        !           253:               CURLFORM_BUFFERLENGTH, record_length,
        !           254:               CURLFORM_END);
        !           255: 
        !           256:  /* no option needed for the end marker */
        !           257:  curl_formadd(&post, &last, CURLFORM_COPYNAME, "pictures",
        !           258:               CURLFORM_ARRAY, forms, CURLFORM_END);
        !           259:  /* Add the content of a file as a normal post text value */
        !           260:  curl_formadd(&post, &last, CURLFORM_COPYNAME, "filecontent",
        !           261:               CURLFORM_FILECONTENT, ".bashrc", CURLFORM_END);
        !           262:  /* Set the form info */
        !           263:  curl_easy_setopt(curl, CURLOPT_HTTPPOST, post);
        !           264: 
        !           265: .SH "SEE ALSO"
        !           266: .BR curl_easy_setopt "(3),"
        !           267: .BR curl_formfree "(3),"
        !           268: .BR curl_mime_init "(3)"

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>