热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

C++实现含附件的邮件发送功能

这篇文章主要为大家详细介绍了C++实现含附件的邮件发送功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

C++实现邮件发送程序在vs2013测试通过,一共3个文件,发邮件的程序封装为Csmtp 类。

1.测试用的主函数

//
#include "Csmtp.h"
#pragma comment(lib, "Kernel32.lib") 

int main()
{ 

 Csmtp mail(
  25,
  "smtp.126.com",
  "username@126.com",// 来源邮箱
  "pwd",
  "username@126.com" //目标邮箱
  );

 if (!mail.CReateSocket())
 {
  cout <<"ReateSocket failed!" <

2.Csmtp类定义

#include  
#include  
#include 
#include  

#include  //适用平台 Windows

#pragma comment(lib, "ws2_32.lib") /*链接ws2_32.lib动态链接库*/ 
 // POP3服务器(端口:110) Csmtp服务器(端口:25) 
using namespace std;
class Csmtp 
{ 

 int port; 
 string domain; 
 string user; 
 string pass; 
 string target; 
 string title; //邮件标题
 string content; //邮件内容


 HOSTENT* pHostent;
 SOCKET sockClient; //客户端的套接字
 vector  filename; //存储附件名的向量

public: 

 Csmtp( 
  int _port, //端口25
  string _domain,  //域名
  string _user,  //发送者的邮箱
  string _pass,  //密码
  string _target)  //目标邮箱
 :port(_port),domain(_domain),user(_user),pass(_pass), target(_target){};//内容 
 bool CReateSocket();
 void setTitle(string tem){title = tem;}
 void setContent(string tem){cOntent= tem;}

 int SendAttachment(SOCKET &sockClient);
 int SendMail();
 void addfile(string str){filename.push_back(str);}

}; 

3. Csmtp 类的实现

#include "Csmtp.h"
//#include //异常类
static const char base64Char[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; 
char* base64Encode(char const* origSigned, unsigned origLength) 
{ 
 unsigned char const* orig = (unsigned char const*)origSigned; // in case any input bytes have the MSB set 
 if (orig == NULL) return NULL; 

 unsigned const numOrig24BitValues = origLength / 3; 
 bool havePadding = origLength > numOrig24BitValues * 3; 
 bool havePadding2 = origLength == numOrig24BitValues * 3 + 2; 
 unsigned const numResultBytes = 4 * (numOrig24BitValues + havePadding); 
 char* result = new char[numResultBytes + 3]; // allow for trailing '/0' 

 // Map each full group of 3 input bytes into 4 output base-64 characters: 
 unsigned i; 
 for (i = 0; i > 2) & 0x3F]; 
  result[4 * i + 1] = base64Char[(((orig[3 * i] & 0x3) <<4) | (orig[3 * i + 1] >> 4)) & 0x3F]; 
  result[4 * i + 2] = base64Char[((orig[3 * i + 1] <<2) | (orig[3 * i + 2] >> 6)) & 0x3F]; 
  result[4 * i + 3] = base64Char[orig[3 * i + 2] & 0x3F]; 
 } 

 // Now, take padding into account. (Note: i == numOrig24BitValues) 
 if (havePadding) 
 { 
  result[4 * i + 0] = base64Char[(orig[3 * i] >> 2) & 0x3F]; 
  if (havePadding2) 
  { 
   result[4 * i + 1] = base64Char[(((orig[3 * i] & 0x3) <<4) | (orig[3 * i + 1] >> 4)) & 0x3F]; 
   result[4 * i + 2] = base64Char[(orig[3 * i + 1] <<2) & 0x3F]; 
  } 
  else 
  { 
   result[4 * i + 1] = base64Char[((orig[3 * i] & 0x3) <<4) & 0x3F]; 
   result[4 * i + 2] = '='; 
  } 
  result[4 * i + 3] = '='; 
 } 

 result[numResultBytes] = '\0'; 
 return result; 
} 


int Csmtp::SendAttachment(SOCKET &sockClient) /*发送附件*/ 
{ 
 for (std::vector::iterator iter = filename.begin();iter != filename.end(); iter++) 
 { 
  cout <<"Attachment is sending··· " <h_addr_list[i]!=NULL;i++) 
  {
   string tem = inet_ntoa(*(struct in_addr *)pHost->h_addr_list[i]);
   ip_list += tem;
   ip_list += "\n";
  } 
 } 
 else 
 { 
  cout<<"获取主机信息失败..."<h_addr_list[0]); //得到smtp服务器的网络字节序的ip地址  



 addrServer.sin_family = AF_INET; 
 addrServer.sin_port = htons(port); //连接端口25 
 //int connect (SOCKET s , const struct sockaddr FAR *name , int namelen );
 err = connect(sockClient, (SOCKADDR*)&addrServer, sizeof(SOCKADDR)); //向服务器发送请求 
 cout<<"connect:"<\r\nrcpt to:<"+target+">\r\n";
 send(sockClient, message.c_str(), message.length(), 0); 
 buff[recv(sockClient, buff, 500, 0)]='\0';
 //cout<<"mail from: "<

容易理解的简化版可以点击->这里

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • 本文介绍了如何找到并终止在8080端口上运行的进程的方法,通过使用终端命令lsof -i :8080可以获取在该端口上运行的所有进程的输出,并使用kill命令终止指定进程的运行。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 本文讲述了作者通过点火测试男友的性格和承受能力,以考验婚姻问题。作者故意不安慰男友并再次点火,观察他的反应。这个行为是善意的玩人,旨在了解男友的性格和避免婚姻问题。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
author-avatar
dfadsgafg4
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有