Chilkat Examples

ChilkatHOME.NET Core C#Android™AutoItCC#C++Chilkat2-PythonCkPythonClassic ASPDataFlexDelphi ActiveXDelphi DLLGoJavaLianjaMono C#Node.jsObjective-CPHP ActiveXPHP ExtensionPerlPowerBuilderPowerShellPureBasicRubySQL ServerSwift 2Swift 3,4,5...TclUnicode CUnicode C++VB.NETVBScriptVisual Basic 6.0Visual FoxProXojo Plugin

C++ Examples

Web API Categories

ASN.1
AWS KMS
AWS Misc
Amazon EC2
Amazon Glacier
Amazon S3
Amazon S3 (new)
Amazon SES
Amazon SNS
Amazon SQS
Async
Azure Cloud Storage
Azure Key Vault
Azure Service Bus
Azure Table Service
Base64
Bounced Email
Box
CAdES
CSR
CSV
Certificates
Cloud Signature CSC
Code Signing
Compression
DKIM / DomainKey
DNS
DSA
Diffie-Hellman
Digital Signatures
Dropbox
Dynamics CRM
EBICS
ECC
Ed25519
Email Object
Encryption
FTP
FileAccess
Firebase
GMail REST API
GMail SMTP/IMAP/POP
Geolocation
Google APIs
Google Calendar
Google Cloud SQL
Google Cloud Storage
Google Drive
Google Photos
Google Sheets
Google Tasks
Gzip
HTML-to-XML/Text
HTTP

HTTP Misc
IMAP
JSON
JSON Web Encryption (JWE)
JSON Web Signatures (JWS)
JSON Web Token (JWT)
Java KeyStore (JKS)
MHT / HTML Email
MIME
MS Storage Providers
Microsoft Graph
Misc
NTLM
OAuth1
OAuth2
OIDC
Office365
OneDrive
OpenSSL
Outlook
Outlook Calendar
Outlook Contact
PDF Signatures
PEM
PFX/P12
PKCS11
POP3
PRNG
REST
REST Misc
RSA
SCP
SCard
SFTP
SMTP
SSH
SSH Key
SSH Tunnel
ScMinidriver
SharePoint
SharePoint Online
Signing in the Cloud
Socket/SSL/TLS
Spider
Stream
Tar Archive
ULID/UUID
Upload
WebSocket
XAdES
XML
XML Digital Signatures
XMP
Zip
curl
uncategorized

 

 

 

(C++) MIME Content-Disposition Header Field

Explains the Content-Disposition header field and the properties used for setting or updating.

Chilkat C/C++ Library Downloads

MS Visual C/C++

Linux/CentOS C/C++

Alpine Linux C/C++

MAC OS X C/C++

armhf/aarch64 C/C++

C++ Builder

iOS C/C++

Android C/C++

Solaris C/C++

MinGW C/C++

#include <CkMime.h>

void ChilkatSample(void)
    {
    // The Content-Disposition header field provides a suggestion to the receiver for how the content is to be processed.
    // The standard dispositions are "inline" and "attachment".  

    // A disposition of "attachment" indicates the content is something to be saved to a file and not processed (such as rendering for viewing inline).
    // A disposition of "inline" indicates the content should be processed (displayed) inline with the other parts of the MIME message.

    // For example, an email client could handle a JPG image based on the disposition.  If the disposition is "attachment",
    // the email client (such as Thunderbird, GMail, or Outlook) might simply list the JPG image as one of the email's attachments,
    // but won't display the JPG image.  If the disposition is "inline", the email client might display the JPG image, but not list
    // it as an attachment.

    // The Content-Disposition header field can also include a "filename" attribute.  This is the suggested default filename if the content
    // is to be saved to a file.

    bool success;
    CkMime mime;

    // The Content-Disposition header field can be set or modified in two ways.
    // 1) By setting the Disposition and Filename properties.

    // 2) By setting the entire contents of the Content-Disposition header with the SetHeaderField method.
    //    Setting the Content-Disposition header automatically updates the Disposition and Filename properties.

    // For example:
    mime.put_Disposition("attachment");
    mime.put_Filename("ghost.jpg");

    // The Content-Disposition header field contains this:
    //     Content-Disposition: attachment; filename="ghost.jpg"
    std::cout << mime.getEntireHead() << "\r\n";
    std::cout << "-" << "\r\n";

    // If we set the entire header field..
    mime.SetHeaderField("Content-Disposition","attachment; filename=\"zombie.jpg\"");
    // The Content-Disposition header field now contains this:
    //     Content-Disposition: attachment; filename="zombie.jpg"
    std::cout << mime.getEntireHead() << "\r\n";
    std::cout << "-" << "\r\n";

    // Notice how the Filename property has been updated
    std::cout << "Filename property: " << mime.filename() << "\r\n";
    std::cout << "-" << "\r\n";

    // To change a particular attribute value, set the property.
    mime.put_Filename("skeleton.jpg");
    std::cout << mime.getEntireHead() << "\r\n";
    std::cout << "-" << "\r\n";

    // To remove the filename from the Content-Disposition header,
    // set the property to an empty string.
    mime.put_Filename("");
    std::cout << mime.getEntireHead() << "\r\n";
    std::cout << "-" << "\r\n";
    }

 

© 2000-2024 Chilkat Software, Inc. All Rights Reserved.