Void __fast call TForm1: N_OpenClick (TObject *Sender)
{
AnsiString ConnStr;
Try {ADOTable1->Active = false;
OpenDialog1->InitialDir =".\\" ; //初始化打开对话框
OpenDialog1->Filter = "MDB邮件列表文件 (*.mdb)|*.mdb|所有文件 (*.*)|*.*";
OpenDialog1->DefaultExt = String("mdb");
if(OpenDialog1->Execute ())//动态指定数据源
{
ConnStr=" Provider=Microsoft.Jet.OLEDB.4.0; Jet OLEDB: Database Password =" + MaskEdit1->Text. Trim () + "; Data Source = " + OpenDialog1-> Filename. Trim () +"; Persist Security Info=True";
ADOTable1->Connection String =ConnStr.Trim ();
ADOTable1->Active=true;
}
Catch (Exception &exception)
{
Application->Show Exception (&exception);
}
}
注意代码中加粗的部分是必须的,在访问有密码保护的Access2000数据库时必须以独占方式打开,如果没有加粗部分的代码,则连接数据库时会提示错误。
3、使用TIdSMTP组件实现群发
在C++Builder6.0中新增加了一套INDY组件,这是一套开放源代码、功能强大的Internet组件,目前该套组件的最新版本是INDY10, 虽然在6.0以前的C++Builder版本中未集成这套组件,但是可以到INDY的网站http://www.indyproject.org/ 上下载源代码进行安装。INDY中的TIdSMTP组件符合RFC821、RFC1869和RFC2544的规范,利用TIdSMTP组件我们能够轻松的实现与SMTP服务器的认证连接、邮件的发送和回执请求。下表是要实现邮件群发,将使用到TIdSMTP组件的基本属性和方法:
表1 TIdSMTP组件的基本属性和方法
属性名 | 功能描述 |
Host | SMTP服务器地址,可以使用IP地址或域名,如:Smtp.sohu.com |
Port | 与SMTP服务器建立TCP连接使用的端口,一般为25 |
Authentication Type | 与SMTP服务器认证的类型,目前版本只提供LOGIN方式 |
UserID | 邮箱用户名 |
Password | 邮箱密码 |
方法名 | 功能描述 |
Connect () | 连接SMTP服务器 |
Disconnect () | 关闭SMTP会话 |
Send (Amsg: IdMessage) | 发送邮件 |
Connected () | 判断是否与SMTP服务器连接 |
Disconnected () | 判断是否与SMTP服务器断开连接 |
属性名 | 功能描述 |
Content Type | 邮件内容的类型,如:text/html等 |
Subject | 邮件主题 |
ody | B邮件正文 |
From->Name | 发件人姓名 |
Recipients->Email | Addresses 收件人EMAIL地址 |
Void __fast call TForm1: SEND_BTNClick (TObject *Sender)
{
Int recnum, k; AnsiString addr;
IdSMTP1->Host = ComboBoxaddr->Text. Trim ();//设定SMTP服务器地址和端口号
IdSMTP1->Port =25;
if(CheckBox_AUTH->Checked ==true) //判断并设置SMTP服务器是否需要认证
{
IdSMTP1->Authentication Type = at Login;
IdSMTP1->UserId = Edit name->Text. Trim ();
IdSMTP1->Password=MaskEdit_pass->Text. Trim ();}
IdMessage1->Content Type = "text/html"; //根据用户填写的信息创建邮件
IdMessage1->Subject =Edit3->Text. Trim ();0
… …
ADOTable1->First(); //循环读取邮件地址并发送实现群发
Recnum= ADOTable1->Record Count;
For (k=0;k<=recnum-1; k++)
{
Addr=Trim (ADOTable1->Field Byname ("Email")->AsString) ;
IdMessage1->Recipients->Email Addresses =addr
If (! IdSMTP1->Connected ())
{
Try
{IdSMTP1->Connect ();}
Catch (Exception &e)
{Application->Message Box(e.Message, "连接SMTP服务器失败", MB_ICONWARNING); }
}
If (IdSMTP1->Connected ())
{
Try
{IdSMTP1->Send (IdMessage1);}
Catch (Exception &e)
{Application->Message Box(e.Message, "发送失败", MB_ICONWARNING); }
}
ADOTable1->Next ();}
Application->Message Box ("发送完成!","邮件系统",MB_OK);
…
}
自由广告区 |
分类导航 |
邮件新闻资讯: IT业界 | 邮件服务器 | 邮件趣闻 | 移动电邮 电子邮箱 | 反垃圾邮件|邮件客户端|网络安全 行业数据 | 邮件人物 | 网站公告 | 行业法规 网络技术: 邮件原理 | 网络协议 | 网络管理 | 传输介质 线路接入 | 路由接口 | 邮件存储 | 华为3Com CISCO技术 | 网络与服务器硬件 操作系统: Windows 9X | Linux&Uinx | Windows NT Windows Vista | FreeBSD | 其它操作系统 邮件服务器: 程序与开发 | Exchange | Qmail | Postfix Sendmail | MDaemon | Domino | Foxmail KerioMail | JavaMail | Winwebmail |James Merak&VisNetic | CMailServer | WinMail 金笛邮件系统 | 其它 | 反垃圾邮件: 综述| 客户端反垃圾邮件|服务器端反垃圾邮件 邮件客户端软件: Outlook | Foxmail | DreamMail| KooMail The bat | 雷鸟 | Eudora |Becky! |Pegasus IncrediMail |其它 电子邮箱: 个人邮箱 | 企业邮箱 |Gmail 移动电子邮件:服务器 | 客户端 | 技术前沿 邮件网络安全: 软件漏洞 | 安全知识 | 病毒公告 |防火墙 攻防技术 | 病毒查杀| ISA | 数字签名 邮件营销: Email营销 | 网络营销 | 营销技巧 |营销案例 邮件人才:招聘 | 职场 | 培训 | 指南 | 职场 解决方案: 邮件系统|反垃圾邮件 |安全 |移动电邮 |招标 产品评测: 邮件系统 |反垃圾邮件 |邮箱 |安全 |客户端 |