1 c: Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al. 2 SPDX-License-Identifier: curl 3 Long: form 4 Short: F 5 Arg: <name=content> 6 Help: Specify multipart MIME data 7 Protocols: HTTP SMTP IMAP 8 Mutexed: data head upload-file 9 Category: http upload 10 Example: --form "name=curl" --form "file=@loadthis" $URL 11 Added: 5.0 12 See-also: data form-string form-escape 13 Multi: append 14 --- 15 For HTTP protocol family, this lets curl emulate a filled-in form in which a 16 user has pressed the submit button. This causes curl to POST data using the 17 Content-Type multipart/form-data according to RFC 2388. 18 19 For SMTP and IMAP protocols, this is the means to compose a multipart mail 20 message to transmit. 21 22 This enables uploading of binary files etc. To force the 'content' part to be 23 a file, prefix the file name with an @ sign. To just get the content part from 24 a file, prefix the file name with the symbol <. The difference between @ and < 25 is then that @ makes a file get attached in the post as a file upload, while 26 the < makes a text field and just get the contents for that text field from a 27 file. 28 29 Tell curl to read content from stdin instead of a file by using - as 30 filename. This goes for both @ and < constructs. When stdin is used, the 31 contents is buffered in memory first by curl to determine its size and allow a 32 possible resend. Defining a part's data from a named non-regular file (such as 33 a named pipe or similar) is not subject to buffering and is instead read at 34 transmission time; since the full size is unknown before the transfer starts, 35 such data is sent as chunks by HTTP and rejected by IMAP. 36 37 Example: send an image to an HTTP server, where 'profile' is the name of the 38 form-field to which the file **portrait.jpg** is the input: 39 40 curl -F profile=@portrait.jpg https://example.com/upload.cgi 41 42 Example: send your name and shoe size in two text fields to the server: 43 44 curl -F name=John -F shoesize=11 https://example.com/ 45 46 Example: send your essay in a text field to the server. Send it as a plain 47 text field, but get the contents for it from a local file: 48 49 curl -F "story=<hugefile.txt" https://example.com/ 50 51 You can also tell curl what Content-Type to use by using 'type=', in a manner 52 similar to: 53 54 curl -F "web=@index.html;type=text/html" example.com 55 56 or 57 58 curl -F "name=daniel;type=text/foo" example.com 59 60 You can also explicitly change the name field of a file upload part by setting 61 filename=, like this: 62 63 curl -F "file=@localfile;filename=nameinpost" example.com 64 65 If filename/path contains ',' or ';', it must be quoted by double-quotes like: 66 67 curl -F "file=@\\"local,file\\";filename=\\"name;in;post\\"" example.com 68 69 or 70 71 curl -F 'file=@"local,file";filename="name;in;post"' example.com 72 73 Note that if a filename/path is quoted by double-quotes, any double-quote 74 or backslash within the filename must be escaped by backslash. 75 76 Quoting must also be applied to non-file data if it contains semicolons, 77 leading/trailing spaces or leading double quotes: 78 79 curl -F 'colors="red; green; blue";type=text/x-myapp' example.com 80 81 You can add custom headers to the field by setting headers=, like 82 83 curl -F "submit=OK;headers=\\"X-submit-type: OK\\"" example.com 84 85 or 86 87 curl -F "submit=OK;headers=@headerfile" example.com 88 89 The headers= keyword may appear more that once and above notes about quoting 90 apply. When headers are read from a file, Empty lines and lines starting 91 with '#' are comments and ignored; each header can be folded by splitting 92 between two words and starting the continuation line with a space; embedded 93 carriage-returns and trailing spaces are stripped. 94 Here is an example of a header file contents: 95 96 # This file contain two headers. 97 X-header-1: this is a header 98 99 # The following header is folded. 100 X-header-2: this is 101 another header 102 103 To support sending multipart mail messages, the syntax is extended as follows: 104 .br 105 - name can be omitted: the equal sign is the first character of the argument, 106 .br 107 - if data starts with '(', this signals to start a new multipart: it can be 108 followed by a content type specification. 109 .br 110 - a multipart can be terminated with a '=)' argument. 111 112 Example: the following command sends an SMTP mime email consisting in an 113 inline part in two alternative formats: plain text and HTML. It attaches a 114 text file: 115 116 curl -F '=(;type=multipart/alternative' \\ 117 -F '=plain text message' \\ 118 -F '= <body>HTML message</body>;type=text/html' \\ 119 -F '=)' -F '=@textfile.txt' ... smtp://example.com 120 121 Data can be encoded for transfer using encoder=. Available encodings are 122 *binary* and *8bit* that do nothing else than adding the corresponding 123 Content-Transfer-Encoding header, *7bit* that only rejects 8-bit characters 124 with a transfer error, *quoted-printable* and *base64* that encodes data 125 according to the corresponding schemes, limiting lines length to 76 126 characters. 127 128 Example: send multipart mail with a quoted-printable text message and a 129 base64 attached file: 130 131 curl -F '=text message;encoder=quoted-printable' \\ 132 -F '=@localfile;encoder=base64' ... smtp://example.com 133 134 See further examples and details in the MANUAL. 135