Classic ASP
Classic ASP
Insert Email into GMail Folder
See more GMail REST API Examples
Directly inserts a message into only this user's mailbox similar to IMAP APPEND, bypassing most scanning and classification. Does not send a message.This example will create a Chilkat Email object and upload/insert it into GMail. Then adds the "INBOX" label to the email to make it appear in INBOX
Chilkat Classic ASP Downloads
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0
' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
set email = Server.CreateObject("Chilkat.Email")
' This example chooses to load an email from a file.
success = email.LoadEml("qa_data/eml/testEmail.eml")
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( email.LastErrorText) & "</pre>"
Response.End
End If
' Get the email as MIME.
set sbMime = Server.CreateObject("Chilkat.StringBuilder")
success = email.GetMimeSb(sbMime)
set http = Server.CreateObject("Chilkat.Http")
set resp = Server.CreateObject("Chilkat.HttpResponse")
http.AuthToken = "GMAIL-ACCESS-TOKEN"
' Upload to GMail (does not send, but just inserts).
' IMPORTANT: After uploading/inserting, you won't see the message in the Inbox.
' In your web browser, if you go to "All Mail", you will see it.
url = "https://www.googleapis.com/upload/gmail/v1/users/me/messages?uploadType=media"
http.UncommonOptions = "SendGzipped"
success = http.HttpSb("POST",url,sbMime,"utf-8","message/rfc822",resp)
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( http.LastErrorText) & "</pre>"
Response.End
End If
http.UncommonOptions = ""
' A status code of 200 indicates success.
Response.Write "<pre>" & Server.HTMLEncode( "Response status code: " & resp.StatusCode) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Response body:") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( resp.BodyStr) & "</pre>"
' The response body contains JSON.
' A sample successful JSON response:
' {
' "id": "166f583051d36144",
' "threadId": "166f5529e079a456"
' }
set json = Server.CreateObject("Chilkat.JsonObject")
success = json.Load(resp.BodyStr)
id = json.StringOf("id")
' Add the Inbox label to the inserted email so that it appears in Inbox.
Response.Write "<pre>" & Server.HTMLEncode( "---- Adding the Inbox label to the newly inserted email. ----") & "</pre>"
' Create the following JSON to be sent in a POST to modify labels for this message.
' {
' "addLabelIds": [
' "INBOX"
' ]
' }
set json2 = Server.CreateObject("Chilkat.JsonObject")
success = json2.UpdateString("addLabelIds[0]","INBOX")
success = http.SetUrlVar("id",id)
url = "https://www.googleapis.com/gmail/v1/users/me/messages/{$id}/modify"
success = http.HttpJson("POST",url,json2,"application/json",resp)
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( http.LastErrorText) & "</pre>"
Response.End
End If
' A status code of 200 indicates success.
Response.Write "<pre>" & Server.HTMLEncode( "Response status code: " & resp.StatusCode) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Response body:") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( resp.BodyStr) & "</pre>"
' The response body contains JSON.
' A sample successful JSON response:
' {
' "id": "166f583051d36144",
' "threadId": "166f583051d36144",
' "labelIds": [
' "INBOX"
' ]
' }
%>
</body>
</html>