Chilkat
HOME
Android™
ASP
Visual Basic
VB.NET
C#
iOS (IPhone)
Objective-C
C++
C
MFC
Delphi
FoxPro
Java
Perl
PHP Extension
PHP ActiveX
Python
PowerShell
Ruby
SQL Server
VBScript
Using SmtpSendRawCommand to Change PasswordDemonstrates how to use the SmtpSendRawCommand method to change the SMTP user account's password for an SMTP server that supports the non-standard CPWD command. Note: The SmtpSendRawCommand method is not yet released. To get a pre-release, send email to support@chilkatsoft.com.
' The mailman object is used for sending and receiving email. Dim mailman As New ChilkatMailMan2 ' Any string argument automatically begins the 30-day trial. Dim success As Long success = mailman.UnlockComponent("30-day trial") If (success <> 1) Then Text1.Text = Text1.Text & mailman.LastErrorText & vbCrLf Exit Sub End If ' Set the SMTP server. mailman.SmtpHost = "smtp.chilkatsoft.com" ' Set the SMTP login/password (if required) mailman.SmtpUsername = "myUsername" mailman.SmtpPassword = "myPassword" ' Connect and authenticate: success = mailman.OpenSmtpConnection() If (success <> 1) Then Text1.Text = Text1.Text & mailman.LastErrorText & vbCrLf Exit Sub End If Dim strCharset As String strCharset = "ansi" Dim bEncodeBase64 As Long ' Send the CPWD command and get the response. ' Do not include a trailing CRLF (carriage-return line-feed) in the command string. Dim strResponse As String bEncodeBase64 = False strResponse = mailman.SmtpSendRawCommand("CPWD",strCharset,bEncodeBase64) If (strResponse = vbNullString ) Then Text1.Text = Text1.Text & mailman.LastErrorText & vbCrLf Exit Sub End If ' Expecting a 334 response... If (mailman.LastSmtpStatus <> 334) Then Text1.Text = Text1.Text & strResponse & vbCrLf Exit Sub End If ' Now send the existing login/password, base64-encoded: bEncodeBase64 = True ' Send the existing login: strResponse = mailman.SmtpSendRawCommand("mySmtpLogin",strCharset,bEncodeBase64) If (strResponse = vbNullString ) Then Text1.Text = Text1.Text & mailman.LastErrorText & vbCrLf Exit Sub End If ' Expecting a 334 response... If (mailman.LastSmtpStatus <> 334) Then Text1.Text = Text1.Text & strResponse & vbCrLf Exit Sub End If ' Send the existing password: strResponse = mailman.SmtpSendRawCommand("mySmtpPassword",strCharset,bEncodeBase64) If (strResponse = vbNullString ) Then Text1.Text = Text1.Text & mailman.LastErrorText & vbCrLf Exit Sub End If ' Expecting a 334 response... If (mailman.LastSmtpStatus <> 334) Then Text1.Text = Text1.Text & strResponse & vbCrLf Exit Sub End If ' Send the new password: strResponse = mailman.SmtpSendRawCommand("myNewSmtpPassword",strCharset,bEncodeBase64) If (strResponse = vbNullString ) Then Text1.Text = Text1.Text & mailman.LastErrorText & vbCrLf Exit Sub End If ' Expecting a 250 response... If (mailman.LastSmtpStatus <> 250) Then Text1.Text = Text1.Text & strResponse & vbCrLf Exit Sub End If MsgBox "SMTP password changed!" success = mailman.CloseSmtpConnection() If (success <> 1) Then MsgBox "Connection to SMTP server not closed cleanly." End If |
© 2000-2012 Chilkat Software, Inc. All Rights Reserved.