Back to Alamofire

MultipartFormData

docs/Classes/MultipartFormData.html

5.12.09.2 KB
Original Source

MultipartFormData

open class MultipartFormData

Constructs multipart/form-data for uploads within an HTTP or HTTPS body. There are currently two ways to encode multipart form data. The first way is to encode the data directly in memory. This is very efficient, but can lead to memory issues if the dataset is too large. The second way is designed for larger datasets and will write all the data to a single file on disk with all the proper boundary segmentation. The second approach MUST be used for larger datasets such as video content, otherwise your app may run out of memory when trying to encode the dataset.

For more information on multipart/form-data in general, please refer to the RFC-2388 and RFC-2045 specs as well and the w3 form documentation.

Properties

`

                encodingMemoryThreshold
                `

Default memory threshold used when encoding MultipartFormData, in bytes.

Declaration

Swift

public static let encodingMemoryThreshold: UInt64

`

                contentType
                `

The Content-Type header value containing the boundary used to generate the multipart/form-data.

Declaration

Swift

open lazy var contentType: String { get set }

`

                contentLength
                `

The content length of all body parts used to generate the multipart/form-data not including the boundaries.

Declaration

Swift

public var contentLength: UInt64 { get }

`

                boundary
                `

The boundary used to separate the body parts in the encoded form data.

Declaration

Swift

public let boundary: String

Lifecycle

`

                init(fileManager:boundary:)
                `

Creates an instance.

Declaration

Swift

public init(fileManager: FileManager = .default, boundary: String? = nil)

Parameters

| fileManager |

FileManager to use for file operations, if needed.

| | boundary |

Boundary String used to separate body parts.

|

Body Parts

`

                append(_:withName:fileName:mimeType:)
                `

Creates a body part from the data and appends it to the instance.

The body part data will be encoded using the following format:

  • Content-Disposition: form-data; name=#{name}; filename=#{filename} (HTTP Header)
  • Content-Type: #{mimeType} (HTTP Header)
  • Encoded file data
  • Multipart form boundary

Declaration

Swift

public func append(_ data: Data, withName name: String, fileName: String? = nil, mimeType: String? = nil)

Parameters

| data |

Data to encoding into the instance.

| | name |

Name to associate with the Data in the Content-Disposition HTTP header.

| | fileName |

Filename to associate with the Data in the Content-Disposition HTTP header.

| | mimeType |

MIME type to associate with the data in the Content-Type HTTP header.

|

`

                append(_:withName:)
                `

Creates a body part from the file and appends it to the instance.

The body part data will be encoded using the following format:

  • Content-Disposition: form-data; name=#{name}; filename=#{generated filename} (HTTP Header)
  • Content-Type: #{generated mimeType} (HTTP Header)
  • Encoded file data
  • Multipart form boundary

The filename in the Content-Disposition HTTP header is generated from the last path component of the fileURL. The Content-Type HTTP header MIME type is generated by mapping the fileURL extension to the system associated MIME type.

Declaration

Swift

public func append(_ fileURL: URL, withName name: String)

Parameters

| fileURL |

URL of the file whose content will be encoded into the instance.

| | name |

Name to associate with the file content in the Content-Disposition HTTP header.

|

`

                append(_:withName:fileName:mimeType:)
                `

Creates a body part from the file and appends it to the instance.

The body part data will be encoded using the following format:

  • Content-Disposition: form-data; name=#{name}; filename=#{filename} (HTTP Header)
  • Content-Type: #{mimeType} (HTTP Header)
  • Encoded file data
  • Multipart form boundary

Declaration

Swift

public func append(_ fileURL: URL, withName name: String, fileName: String, mimeType: String)

Parameters

| fileURL |

URL of the file whose content will be encoded into the instance.

| | name |

Name to associate with the file content in the Content-Disposition HTTP header.

| | fileName |

Filename to associate with the file content in the Content-Disposition HTTP header.

| | mimeType |

MIME type to associate with the file content in the Content-Type HTTP header.

|

`

                append(_:withLength:name:fileName:mimeType:)
                `

Creates a body part from the stream and appends it to the instance.

The body part data will be encoded using the following format:

  • Content-Disposition: form-data; name=#{name}; filename=#{filename} (HTTP Header)
  • Content-Type: #{mimeType} (HTTP Header)
  • Encoded stream data
  • Multipart form boundary

Declaration

Swift

public func append(_ stream: InputStream,
                   withLength length: UInt64,
                   name: String,
                   fileName: String,
                   mimeType: String)

Parameters

| stream |

InputStream to encode into the instance.

| | length |

Length, in bytes, of the stream.

| | name |

Name to associate with the stream content in the Content-Disposition HTTP header.

| | fileName |

Filename to associate with the stream content in the Content-Disposition HTTP header.

| | mimeType |

MIME type to associate with the stream content in the Content-Type HTTP header.

|

`

                append(_:withLength:headers:)
                `

Creates a body part with the stream, length, and headers and appends it to the instance.

The body part data will be encoded using the following format:

  • HTTP headers
  • Encoded stream data
  • Multipart form boundary

Declaration

Swift

public func append(_ stream: InputStream, withLength length: UInt64, headers: HTTPHeaders)

Parameters

| stream |

InputStream to encode into the instance.

| | length |

Length, in bytes, of the stream.

| | headers |

HTTPHeaders for the body part.

|

Data Encoding

`

                encode()
                `

Encodes all appended body parts into a single Data value.

Note

This method will load all the appended body parts into memory all at the same time. This method should only be used when the encoded data will have a small memory footprint. For large data cases, please use the writeEncodedData(to:)) method.

Throws

An AFError if encoding encounters an error.

Declaration

Swift

public func encode() throws -> Data

Return Value

The encoded Data, if encoding is successful.

`

                writeEncodedData(to:)
                `

Writes all appended body parts to the given file URL.

This process is facilitated by reading and writing with input and output streams, respectively. Thus, this approach is very memory efficient and should be used for large body part data.

Throws

An AFError if encoding encounters an error.

Declaration

Swift

public func writeEncodedData(to fileURL: URL) throws

Parameters

| fileURL |

File URL to which to write the form data.

|