Is Content-Transfer-Encoding an HTTP header?

前端 未结 2 1038
星月不相逢
星月不相逢 2020-12-01 06:19

I\'m writing a web service that returns a base64-encoded PDF file, so my plan is to add two headers to the response:

Content-Type: application/pdf
Content-Tr         


        
2条回答
  •  北海茫月
    2020-12-01 06:28

    According to RFC 1341 (made obsolete by RFC 2045):

    A Content-Transfer-Encoding header field, which can be used to specify an auxiliary encoding that was applied to the data in order to allow it to pass through mail transport mechanisms which may have data or character set limitations.

    and later:

    Many Content-Types which could usefully be transported via email are represented, in their "natural" format, as 8-bit character or binary data. Such data cannot be transmitted over some transport protocols. For example, RFC 821 restricts mail messages to 7-bit US-ASCII data with 1000 character lines.

    It is necessary, therefore, to define a standard mechanism for re-encoding such data into a 7-bit short-line format. (...) The Content-Transfer-Encoding field is used to indicate the type of transformation that has been used in order to represent the body in an acceptable manner for transport.

    Since you have a webservice, which has nothing in common with emails, you shouldn't use this header.

    You can use Content-Encoding header which indicates that transferred data has been compressed (gzip value).

    I think that in your case

    Content-Type: application/pdf
    

    is enough. Additionally, you can set Content-Length header, but in my opinion, if you are building webservice (it's not http server / proxy server) Content-Type is enough. Please bear in mind that some specific headers (e.g. Transfer-Encoding) if not used appropriately, may cause unexpected communication issues, so if you are not 100% sure about usage of some header - if you really need it or not - just don't use it.

提交回复
热议问题