首页 > 编程 > C++ > 正文

C++实现邮件群发的方法

2020-05-23 14:19:15
字体:
来源:转载
供稿:网友

这篇文章主要介绍了C++实现邮件群发的方法,较为详细的分析了邮件发送的原理与C++相关实现技巧,非常具有实用价值,需要的朋友可以参考下

本文实例讲述了C++实现邮件群发的方法。分享给大家供大家参考。具体如下:

关于生成随机QQ邮箱不精确的问题,在之后版本打算另写一个采集器插件进行帐号采集,所以,这个软件只用来进行内容发送,邮箱进行随机生成

如果你已经有采集来的QQ号,请复制到SendList.txt 替换内容即可

可以直接复制HTML代码到邮件内容,保存即可。目前邮件内容最大设置为10000字节,如果有增大的必要,欢迎提交留言。

这是我学习后VC编程中涉及到多线程,socket,及一些WINDOWS API的宗合应用

使用说明:

一、SMTP设置

1、SMTP设置中,收件箱地址:填写邮箱地址为帐号测试邮箱,可以填写你自己的邮箱作为接收测试。打星号为必填。邮箱帐号及密码,是即将用于群发的帐号和密码

2、群发发送时间间隔,默认为零,可以选择填写发送间隔时间,单位为秒,防止多次快速发送相同内容被停用。

3、勾选邮件标题后插入系统时间,可以在标题上加上系统时间

4、导入群发列表,勾选后,可以点击群发,暂停,继续。(群发列表为程序目录中SendList.txt)如果你有邮箱采集软件,可以把彩集的邮箱地址按照格式,一行一个,放入其中),没有的话,可以点击“收件箱”页面生成随机QQ邮箱

二、邮件内容

1、填写邮件标题,邮件内容可以为纯文本,也可以是HTML代码,附件目前只支持TXT文本。

2、群发前,请测试邮件内容,是否完整。附件是否正常接收。

三、收件箱

1、收件箱中顺序生成QQ邮箱,请不要超过6位数QQ号,位数过大,生成时间过长,容易造成假死。

2、群发前,先生成QQ邮箱列表。如果你有采集邮箱帐号,可以按格式放入SendList.txt 中

版本更新说明:

1、可增加多个附件。

2、修复标题插入日期造成程序崩溃的BUG。

3、增加发送间隔时间选项。

4、支持HTML代码

5、增加干预码

 

 
  1. #include "stdafx.h" 
  2. #include <windows.h> 
  3. #include <windowsx.h> 
  4. #include "Resource.h" 
  5. #include "TabDlg1.h" 
  6. #include "winsock2.h" 
  7. #define MAXSTRING 10000 
  8. static int flag=0; //标记是否群发 
  9. TCHAR* pTitle = NULL; //指向标题文件内容的指针 
  10. HANDLE hThread=NULL; //线程返回句柄 
  11. long i=0; //列表控件“行”计数 
  12. static long sendNum=1; //发送邮件数量 
  13. #pragma comment(lib,"WSOCK32.LIB") 
  14. extern TCHAR tcRunPath[MAX_PATH]; //程序当前路径目录 
  15. extern TCHAR shortPath[MAX_PATH]; //文件路径,TAB2中的全局变量 
  16. extern TCHAR titlePath[256]; //邮件标题文件路径 
  17. extern TCHAR mtPath[256]; //邮件内容文件路径 
  18. extern TCHAR sendListPath[MAX_PATH]; //发送列表文件路径 
  19. extern BOOL attach; //是否添加了附件 
  20. extern TCHAR file[MAXSTRING]; //附件部份代码 
  21. BOOL WINAPI TAB1_Proc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam) 
  22. switch(uMsg) 
  23. HANDLE_MSG(hWnd, WM_INITDIALOG, TAB1_OnInitDialog); 
  24. HANDLE_MSG(hWnd, WM_COMMAND, TAB1_OnCommand); 
  25. HANDLE_MSG(hWnd,WM_CLOSE, TAB1_OnClose); 
  26. return FALSE; 
  27. BOOL TAB1_OnInitDialog(HWND hwnd, HWND hwndFocus, LPARAM lParam) 
  28. InitLVColumn(hwnd); 
  29. InitComboBox(hwnd); 
  30. return TRUE; 
  31. void TAB1_OnCommand(HWND hwnd, int id, HWND hwndCtl, UINT codeNotify) 
  32. {  
  33. IsChecked(hwnd); //判断勾选框是否被勾选 
  34. IsRadioChecked(hwnd); //RADIO控件是否被选择 
  35. switch(id) 
  36. case IDC_MAIL_TEST: 
  37. {  
  38. if(IsDlgButtonChecked(hwnd,IDC_RADIO_QQ)!=BST_CHECKED && IsDlgButtonChecked(hwnd,IDC_RADIO_163)!=BST_CHECKED) 
  39. MessageBox(hwnd,TEXT("请选择发QQ邮箱或163信箱"),"",MB_OK); 
  40. return
  41. else 
  42. flag=0; 
  43. hThread=CreateThread(NULL,0,ThreadFunc,hwnd,0,0); 
  44. break
  45. case IDC_BUTTON_START: 
  46. {  
  47. if(IsDlgButtonChecked(hwnd,IDC_RADIO_QQ)!=BST_CHECKED && IsDlgButtonChecked(hwnd,IDC_RADIO_163)!=BST_CHECKED) 
  48. MessageBox(hwnd,TEXT("请选择发QQ邮箱或163信箱"),"",MB_OK); 
  49. return
  50. else 
  51. flag=1; 
  52. hThread=CreateThread(NULL,0,ThreadFunc,hwnd,0,0); 
  53. break
  54. case IDC_BUTTON_PAUSE: 
  55. {  
  56. if(NULL!=hThread) 
  57. SuspendThread(hThread);  
  58. else 
  59. return
  60. break
  61. case IDC_BUTTON_RESUME: 
  62. {  
  63. if(NULL!=hThread) 
  64. ResumeThread(hThread);  
  65. else 
  66. return
  67. break
  68. default
  69. break
  70. void TAB1_OnClose(HWND hwnd) 
  71. EndDialog(hwnd, 0); 
  72. int InitLVColumn(HWND hwnd) //列表初始化设置,视图选为报表视图 
  73. LVCOLUMN lvColumn; 
  74. MyLVColumn MyColumn[2] = {{TEXT("编号"), 0x30, LVCFMT_CENTER},{TEXT("邮箱帐号"), 0x99, LVCFMT_CENTER}}; 
  75. lvColumn.mask = LVCF_TEXT|LVCF_FMT|LVCF_WIDTH|LVCF_SUBITEM; 
  76. DWORD dwStyle =ListView_GetExtendedListViewStyle(GetDlgItem(hwnd, IDC_LIST)); //得到列表当前拓展风格 
  77. dwStyle |= LVS_EX_FULLROWSELECT; //选中某行使整行高亮(只适用与report风格的listctrl) 
  78. dwStyle |= LVS_EX_GRIDLINES; //网格线(只适用与report风格的listctrl) 
  79. // dwStyle |= LVS_EX_CHECKBOXES; //item前生成checkbox控件 
  80. ListView_SetExtendedListViewStyle(GetDlgItem(hwnd, IDC_LIST),dwStyle); //设置列表扩展风格 
  81. for(int i = 0; i < 2; i++) 
  82. lvColumn.pszText = MyColumn[i].szColumnName; 
  83. lvColumn.cx = MyColumn[i].cx; 
  84. lvColumn.fmt = MyColumn[i].fmt; 
  85. SendDlgItemMessage(hwnd, IDC_LIST, LVM_INSERTCOLUMN, i, (LPARAM)&lvColumn); 
  86.  
  87. return 0; 
  88. int InitComboBox(HWND hwnd)//窗口控件初始化设置 
  89. HWND hwndCombo=GetDlgItem(hwnd,IDC_COMBO_SLEEPTIME); 
  90. ComboBox_InsertString(hwndCombo,-1,TEXT("0")); 
  91. ComboBox_InsertString(hwndCombo,-1,TEXT("1")); 
  92. ComboBox_InsertString(hwndCombo,-1,TEXT("2")); 
  93. ComboBox_InsertString(hwndCombo,-1,TEXT("5")); 
  94. ComboBox_InsertString(hwndCombo,-1,TEXT("10")); 
  95. ComboBox_InsertString(hwndCombo,-1,TEXT("20")); 
  96. ComboBox_SetText(hwndCombo,TEXT("0")); 
  97. SetDlgItemText(hwnd,IDC_EDIT_MAILADD,TEXT("12345678@qq.com")); 
  98. ComboBox_InsertString(GetDlgItem(hwnd,IDC_COMBO_SMTP),0,TEXT("smtp.qq.com")); 
  99. ComboBox_InsertString(GetDlgItem(hwnd,IDC_COMBO_SMTP),1,TEXT("smtp.163.com")); 
  100. ComboBox_SetText(GetDlgItem(hwnd,IDC_COMBO_SMTP),TEXT("smtp.qq.com")); 
  101. SetDlgItemText(hwnd,IDC_EDIT_MAILPORT,TEXT("25"));  
  102. SetDlgItemText(hwnd,IDC_EDIT_USERNAME,TEXT("")); 
  103.  
  104. return 1; 
  105. int IsChecked(HWND hwnd) //checkbox未选中的设置为只读 
  106. if(IsDlgButtonChecked(hwnd,IDC_CHECK_QUNFA)!=BST_CHECKED) 
  107. EnableWindow(GetDlgItem(hwnd, IDC_BUTTON_START), false); 
  108. EnableWindow(GetDlgItem(hwnd, IDC_BUTTON_RESUME), false); 
  109. EnableWindow(GetDlgItem(hwnd, IDC_BUTTON_PAUSE), false); 
  110. return 0; 
  111. else 
  112. EnableWindow(GetDlgItem(hwnd, IDC_BUTTON_START), true); 
  113. EnableWindow(GetDlgItem(hwnd, IDC_BUTTON_RESUME), true); 
  114. EnableWindow(GetDlgItem(hwnd, IDC_BUTTON_PAUSE), true); 
  115. return 1; 
  116. return 0; 
  117. int IsRadioChecked(HWND hwnd) //RADIO控件被选中,则设置相应的SMTP 地址 
  118. if(IsDlgButtonChecked(hwnd,IDC_RADIO_QQ)==BST_CHECKED) 
  119. ComboBox_SetText(GetDlgItem(hwnd,IDC_COMBO_SMTP),TEXT("smtp.qq.com")); 
  120. return 1; 
  121. if(IsDlgButtonChecked(hwnd,IDC_RADIO_163)==BST_CHECKED) 
  122. ComboBox_SetText(GetDlgItem(hwnd,IDC_COMBO_SMTP),TEXT("smtp.163.com")); 
  123. return 2; 
  124. return 0; 
  125. TCHAR* readText1(HWND hwnd) //读取文件--邮件发送内容 
  126. int nLen = 0; 
  127. FILE *pF = fopen(titlePath , "r"); //打开文件 
  128. fseek(pF, 0, SEEK_END); //文件指针移到文件尾 
  129. nLen = ftell(pF); //得到当前指针位置, 即是文件的长度 
  130. rewind(pF); //文件指针恢复到文件头位置 
  131. pTitle = (char*) malloc(sizeof(char)*nLen+1);//动态申请空间, 为保存字符串结尾标志/0, 多申请一个字符的空间 
  132. if(!pTitle) 
  133. MessageBox(hwnd,TEXT("内存不够!"),"错误",MB_ICONWARNING); 
  134. exit(0); 
  135. nLen = fread(pTitle, sizeof(char), nLen, pF); 
  136. pTitle[nLen] = '/0'//添加字符串结尾标志 
  137. if(IsDlgButtonChecked(hwnd,IDC_CHECK_TITLE)==BST_CHECKED) //是否勾选在邮件标题 加入系统当前时间 
  138. SYSTEMTIME stLocal; 
  139. GetLocalTime(&stLocal); //得到系统当前时间 
  140. TCHAR strTime[256]; 
  141. ZeroMemory(strTime,sizeof(strTime)/sizeof(TCHAR)); 
  142. wsprintf(strTime,"%04u-%02u-%02u %02u:%02u:%02u",stLocal.wYear,stLocal.wMonth,stLocal.wDay,stLocal.wHour,stLocal.wMinute,stLocal.wSecond); 
  143. strcat(pTitle,strTime); //在标题后加入系统时间 
  144. fclose(pF); //关闭文件 
  145. TCHAR* pText = NULL; 
  146. pF = fopen(mtPath , "r"); //打开文件 
  147. fseek(pF, 0, SEEK_END);  
  148. nLen = ftell(pF);  
  149. rewind(pF);  
  150. pText = (char*) malloc(sizeof(char)*nLen+1); //动态申请空间, 为保存字符串结尾标志/0, 多申请一个字符的空间 
  151. if(!pText) 
  152. MessageBox(hwnd,TEXT("内存不够!"),"错误",MB_ICONWARNING); 
  153. exit(0); 
  154. nLen = fread(pText, sizeof(char), nLen, pF); 
  155. pText[nLen] = '/0'//添加字符串结尾标志 
  156. fclose(pF); //关闭文件 
  157. TCHAR chText[MAXSTRING];  
  158. TCHAR* encText=base64_encode(pText,strlen(pText));  
  159. strcpy(chText,encText); //BASE64加密结果 
  160. free(encText); //释放指针 
  161. free(pText); //释放空间 
  162. return chText; 
  163. DWORD WINAPI ThreadFunc(LPVOID lpParam)//发邮件线程 
  164. HWND hwnd=(HWND)lpParam; 
  165. TCHAR userName[256]; //用户帐号 
  166. TCHAR userPassWord[256]; //用户密码 
  167. GetDlgItemText(hwnd,IDC_EDIT_USERNAME,userName,sizeof(userName)/sizeof(TCHAR)); 
  168. GetDlgItemText(hwnd,IDC_EDIT_USERPASSWORD,userPassWord,sizeof(userPassWord)/sizeof(TCHAR)); 
  169. TCHAR *name=userName;  
  170. int i = 0;  
  171. int j = strlen(name);  
  172. TCHAR *encName = base64_encode(name, j); //给用户名base64加密编码  
  173. ZeroMemory(userName,sizeof(userName)/sizeof(TCHAR));  
  174. wsprintf(userName,"%s/n", encName); //在加编码后加入回车符 
  175. TCHAR *passWord=userPassWord;  
  176. int k = strlen(passWord);  
  177. TCHAR *encPassWord = base64_encode(passWord, k); //给用户密码base64加密编码  
  178. // int len = strlen(enc);  
  179. // TCHAR *dec = base64_decode(enc, len); //反编  
  180. ZeroMemory(userPassWord,sizeof(userPassWord)/sizeof(TCHAR));  
  181. wsprintf(userPassWord,"%s/n", encPassWord); 
  182. /*ZeroMemory(userName,sizeof(userName)/sizeof(TCHAR));  
  183. wsprintf(userName,"/ndecoded : %s", dec); 
  184. MessageBox(hwnd,userName,"",MB_OK);*/ //反编译用户名,如果需要,可以把用户名密码反编后发到指定邮箱。 
  185. free(encName); //释放指针 
  186. free(encPassWord); 
  187. //free(dec);  
  188. if(1==flag) //全局标记,点击群发还是测试,1为群发,0为测试 
  189. HANDLE wFile; 
  190. int szId; 
  191. TCHAR ch; 
  192. TCHAR szState[256]; 
  193. strcpy(sendListPath,tcRunPath); 
  194. strcat(sendListPath,"//SendList.txt"); //拼接全路径及文件名 
  195. TCHAR *sFileName=sendListPath; 
  196. FILE *fp=fopen(sFileName,"r"); 
  197. if(fp==NULL) 
  198. return FALSE; //打开文件失败,则返回,不读取 
  199. fseek(fp, 0, SEEK_END); 
  200. int length = ftell(fp); //length为0,则是空的 
  201. rewind(fp); //把指针移回文件头部 还可以用 fseek(fp, 0, SEEK_SET);效果一样 
  202. if(length==0) //判断文件如果为空,则关闭文件,返回, 
  203. fclose(fp); //要关闭打开的文件,不然退出时,无法保存 
  204. return FALSE; 
  205. while(!feof(fp)) 
  206. {  
  207. fscanf(fp,"%s/r/n",szState); 
  208. SocketQ(hwnd,userName,userPassWord,szState); 
  209. TCHAR sTime[256];  
  210. unsigned long iTime; 
  211. ComboBox_GetText(GetDlgItem(hwnd,IDC_COMBO_SLEEPTIME),sTime,sizeof(sTime)/sizeof(TCHAR)); 
  212. iTime=atoi(sTime); 
  213. iTime=iTime*1000; 
  214. Sleep(iTime); 
  215. }  
  216. fclose(fp); 
  217. else 
  218. Socket(hwnd,userName,userPassWord);  
  219. CloseHandle(hThread);  
  220. return 0; 
  221. void SocketQ(HWND hwnd,TCHAR userName[],TCHAR userPassWord[],TCHAR szState[])//传入加密的用户名跟密码连接163 
  222. /******************************************************************* 
  223. 使用Socket的程序在使用Socket之前必须调用WSAStartup函数。 
  224. 该函数的第一个参数指明程序请求使用的Socket版本, 
  225. 其中高位字节指明副版本、低位字节指明主版本; 
  226. 操作系统利用第二个参数返回请求的Socket的版本信息。 
  227. 当一个应用程序调用WSAStartup函数时,操作系统根据请求的Socket版本来搜索相应的Socket库, 
  228. 然后绑定找到的Socket库到该应用程序中。 
  229. 以后应用程序就可以调用所请求的Socket库中的其它Socket函数了。 
  230. 该函数执行成功后返回0。 
  231. *****************************************************************/ 
  232. TCHAR* pText; 
  233. pText = readText1(hwnd); 
  234. int WSA_return; 
  235. WSADATA wsaData;  
  236. WSA_return=WSAStartup(MAKEWORD(2,0),&wsaData); //初始化Socket库  
  237. SOCKET sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);//创建SOCKET 
  238. hostent* host = NULL;  
  239. SOCKADDR_IN sa; 
  240. sa.sin_family=AF_INET; //设置电线连接服务器端的端口 
  241. TCHAR cPort[100]; 
  242. GetDlgItemText(hwnd,IDC_EDIT_MAILPORT,cPort,sizeof(cPort)/sizeof(TCHAR)); 
  243. int iPort=atoi(cPort); 
  244. sa.sin_port = htons(iPort);  
  245. //sa.sin_addr.S_un.S_addr = inet_addr("123.58.178.203");//可以写死IP地址  
  246. HOSTENT *host_entry; //存放主机域名,如smtp.qq.com 
  247. TCHAR host_name[256]=""
  248. ZeroMemory(host_name,sizeof(host_name)/sizeof(TCHAR));  
  249. ComboBox_GetText(GetDlgItem(hwnd,IDC_COMBO_SMTP),host_name,sizeof(host_name)/sizeof(TCHAR)); 
  250. TCHAR str_ipAdd[256]; 
  251. if(WSA_return==0) 
  252. host_entry=gethostbyname(host_name); // 要解析的域名或主机名  
  253. if(host_entry!=NULL) 
  254. wsprintf(str_ipAdd,"%d.%d.%d.%d"
  255. (host_entry->h_addr_list[0][0]&0x00ff), 
  256. (host_entry->h_addr_list[0][1]&0x00ff), 
  257. (host_entry->h_addr_list[0][2]&0x00ff), 
  258. (host_entry->h_addr_list[0][3]&0x00ff)); 
  259.  
  260. sa.sin_addr.S_un.S_addr = inet_addr(str_ipAdd); //得到域名IP地址 
  261. if(connect(sock,(SOCKADDR *)&sa,sizeof(sa))==SOCKET_ERROR) 
  262. ShowError(); 
  263. return
  264. TCHAR buffer[256]; //对话过程  
  265. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR)); 
  266. int iRet=recv(sock,buffer,256,0); //接收问候语  
  267. if(SOCKET_ERROR==iRet) 
  268. ShowError();  
  269. return
  270. TCHAR Hello[] = "HELO SMTP/r/n"//注意不能忘了末尾的回车  
  271. send(sock,Hello,lstrlen(Hello),0);  
  272. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  273. iRet=recv(sock,buffer,256,0); 
  274. if(SOCKET_ERROR==iRet) 
  275. ShowError();  
  276. return
  277. TCHAR Ehlo[] = "EHLO SMTP/r/n";  
  278. send(sock,Ehlo,lstrlen(Ehlo),0);  
  279. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  280. iRet=recv(sock,buffer,256,0); 
  281. if(SOCKET_ERROR==iRet) 
  282. ShowError();  
  283. return
  284. TCHAR login[] = "AUTH LOGIN/r/n"//登陆命令 
  285. send(sock,login,lstrlen(login),0);  
  286. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  287. iRet=recv(sock,buffer,256,0); 
  288. if(SOCKET_ERROR==iRet) 
  289. ShowError();  
  290. return
  291. if(IsDlgButtonChecked(hwnd,IDC_RADIO_QQ)==BST_CHECKED) 
  292. strcat(userName,"/r/n"); 
  293. send(sock,userName,lstrlen(userName),0); //发送加密的用户名 
  294. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  295. iRet=recv(sock,buffer,256,0); 
  296. if(SOCKET_ERROR==iRet) 
  297. ShowError();  
  298. return
  299. strcat(userPassWord,"/r/n"); 
  300. send(sock,userPassWord,lstrlen(userPassWord),0); //发送加密的密码 
  301. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  302. iRet=recv(sock,buffer,256,0); 
  303. if(SOCKET_ERROR==iRet) 
  304. ShowError();  
  305. return
  306. if(IsDlgButtonChecked(hwnd,IDC_RADIO_163)==BST_CHECKED) 
  307. send(sock,userName,lstrlen(userName),0); //发送加密的用户名 
  308. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  309. iRet=recv(sock,buffer,256,0); 
  310. if(SOCKET_ERROR==iRet) 
  311. ShowError();  
  312. return
  313. send(sock,userPassWord,lstrlen(userPassWord),0); //发送加密的密码 
  314. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  315. iRet=recv(sock,buffer,256,0); 
  316. if(SOCKET_ERROR==iRet) 
  317. ShowError();  
  318. return
  319. TCHAR userF[256]; 
  320. TCHAR userL[256]; 
  321. TCHAR temp[256]; 
  322. GetDlgItemText(hwnd,IDC_EDIT_USERNAME,userF,sizeof(userF)/sizeof(TCHAR));  
  323. ComboBox_GetText(GetDlgItem(hwnd,IDC_COMBO_SMTP),temp,sizeof(host_name)/sizeof(TCHAR)); 
  324. strcat(userF,"@"); 
  325. strncpy(userL,temp+5,sizeof(userL)); 
  326. strcat(userF,userL); 
  327. TCHAR mailFrom[256]; 
  328. //MessageBox(hwnd,userF,"",MB_OK); 
  329. wsprintf(mailFrom,TEXT("MAIL FROM:<%s>/r/n"),userF); 
  330. send(sock,mailFrom,lstrlen(mailFrom),0); 
  331. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  332. iRet=recv(sock,buffer,256,0); 
  333. if(SOCKET_ERROR==iRet) 
  334. ShowError();  
  335. return
  336. TCHAR mailTo[256]; 
  337. wsprintf(mailTo,TEXT("RCPT TO:<%s>/r/n"),szState); 
  338. send(sock,mailTo,lstrlen(mailTo),0); 
  339. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  340. iRet=recv(sock,buffer,256,0); 
  341. if(SOCKET_ERROR==iRet) 
  342. ShowError();  
  343. return
  344. TCHAR dataCommad[]="DATA/r/n"
  345. send(sock,dataCommad,lstrlen(dataCommad),0);  
  346. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  347. iRet=recv(sock,buffer,256,0); 
  348. if(SOCKET_ERROR==iRet) 
  349. ShowError();  
  350. return
  351. //下面是发送正文及附件部份 
  352. TCHAR data[50000]; 
  353. TCHAR SetMailHead[1024]; //邮件头部信息 
  354. wsprintf(SetMailHead,TEXT("To:%s/r/nFrom:%s/r/nSubject: %s/r/n" 
  355. "Date:2012-8-24/r/nX-Mailer:Kevin's mailer/r/nMIME-Version:1.0/r/n" 
  356. "Content-Type: multipart/mixed;/r/n" 
  357. " boundary=/"----=_NextPart_5039E410_D41071F0_120ABDFB/";/r/n" 
  358. "This is a multi-part message in MIME format./r/n/r/n" 
  359. "------=_NextPart_5039E410_D41071F0_120ABDFB/r/n" 
  360. "Content-Type: multipart/alternative;/r/n" 
  361. " boundary=/"----=_NextPart_5039E410_D41071F0_53510C95/";/r/n/r/n" 
  362. "------=_NextPart_5039E410_D41071F0_53510C95/r/n" 
  363. "Content-Type: text/plain;/r charset=/"gb2312/"/r/n" 
  364. "Content-Transfer-Encoding: base64/r/n/r/n"),szState,userF,pTitle); 
  365. strcat(SetMailHead,pText); //邮件头部再加上正文文本内容 
  366. strcat(SetMailHead,TEXT("/r/n/r/n")); 
  367. strcpy(data,SetMailHead); 
  368. TCHAR SetMailHtml[1024]; //邮件HTML代码部份 
  369. wsprintf(SetMailHtml,TEXT("------=_NextPart_5039E410_D41071F0_53510C95/r/n" 
  370. "Content-Type: text/html;/r/n" 
  371. " charset=/"gb2312/"/r/n" 
  372. "Content-Transfer-Encoding: base64/r/n/r/n")); 
  373. strcat(SetMailHtml,pText); //加入邮件内容 
  374. strcat(SetMailHtml,TEXT("/r/n/r/n------=_NextPart_5039E410_D41071F0_53510C95--/r/n/r/n")); 
  375. strcat(data,SetMailHtml); 
  376. if(TRUE==attach) //判断是否添加了附件路径 
  377. strcat(data,file); //加入附件部份代码 
  378. strcat(data,TEXT("------=_NextPart_5039E410_D41071F0_120ABDFB--/r/n")); 
  379. send(sock,data,lstrlen(data),0); 
  380. TCHAR cN[]="/r/n./r/n"//邮件结束标志 
  381. send(sock,cN,lstrlen(cN),0); 
  382. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  383. iRet=recv(sock,buffer,256,0); 
  384. if(SOCKET_ERROR==iRet) 
  385. ShowError();  
  386. return
  387. TCHAR cQuit[] = "QUIT/r/n"//退出命令 
  388. send(sock,cQuit,lstrlen(cQuit),0);  
  389. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  390. iRet=recv(sock,buffer,256,0); 
  391. TCHAR cNum[256]; 
  392. if(SOCKET_ERROR==iRet) 
  393. ShowError();  
  394. return
  395. }  
  396. else 
  397. {  
  398. TCHAR str[256]; //输出已发送列表 
  399. wsprintf(str,"%i",sendNum); 
  400. LVITEM lvItem; 
  401. lvItem.mask = LVIF_TEXT; 
  402. lvItem.iSubItem = 0; 
  403. int ItemCount = ListView_GetItemCount(GetDlgItem(hwnd, IDC_LIST)); 
  404. lvItem.iItem = ItemCount;  
  405. lvItem.pszText = str; 
  406. SendDlgItemMessage(hwnd, IDC_LIST, LVM_INSERTITEM, 0, (LPARAM)&lvItem);  
  407. ListView_SetItemText(GetDlgItem(hwnd, IDC_LIST), i++, 1, szState);  
  408. sendNum++; 
  409. free(pTitle); //释放空间  
  410. closesocket(sock); //关闭SOCKET  
  411. WSACleanup(); 
  412. return
  413. void Socket(HWND hwnd,TCHAR userName[],TCHAR userPassWord[])//传入加密的用户名跟密码连接163 
  414. TCHAR* pText; 
  415. pText = readText1(hwnd); 
  416. int WSA_return; 
  417. WSADATA wsaData;  
  418. WSA_return=WSAStartup(MAKEWORD(2,0),&wsaData);//初始化Socket库 
  419. SOCKET sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); 
  420. hostent* host = NULL;  
  421. SOCKADDR_IN sa; 
  422. sa.sin_family=AF_INET; //设置电线连接服务器端的端口 
  423. TCHAR cPort[100]; 
  424. GetDlgItemText(hwnd,IDC_EDIT_MAILPORT,cPort,sizeof(cPort)/sizeof(TCHAR)); 
  425. int iPort=atoi(cPort); 
  426. sa.sin_port = htons(iPort);  
  427. HOSTENT *host_entry; 
  428. TCHAR host_name[256]=""
  429. ZeroMemory(host_name,sizeof(host_name)/sizeof(TCHAR));  
  430. ComboBox_GetText(GetDlgItem(hwnd,IDC_COMBO_SMTP),host_name,sizeof(host_name)/sizeof(TCHAR)); 
  431. TCHAR str_ipAdd[256]; 
  432. if(WSA_return==0) 
  433. {  
  434. host_entry=gethostbyname(host_name); // 即要解析的域名或主机名  
  435. if(host_entry!=NULL) 
  436. wsprintf(str_ipAdd,"%d.%d.%d.%d"
  437. (host_entry->h_addr_list[0][0]&0x00ff), 
  438. (host_entry->h_addr_list[0][1]&0x00ff), 
  439. (host_entry->h_addr_list[0][2]&0x00ff), 
  440. (host_entry->h_addr_list[0][3]&0x00ff)); 
  441.  
  442. sa.sin_addr.S_un.S_addr = inet_addr(str_ipAdd);  
  443. if(connect(sock,(SOCKADDR *)&sa,sizeof(sa))==SOCKET_ERROR) 
  444. ShowError(); 
  445. return;  
  446. TCHAR buffer[256]; //对话过程  
  447. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  448. int iRet=recv(sock,buffer,256,0); //接收问候语  
  449. if(SOCKET_ERROR==iRet) 
  450. ShowError();  
  451. return
  452. TCHAR Hello[] = "HELO SMTP/r/n"//注意不能忘了末尾的回车  
  453. send(sock,Hello,lstrlen(Hello),0);  
  454. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  455. iRet=recv(sock,buffer,256,0); 
  456. if(SOCKET_ERROR==iRet) 
  457. ShowError();  
  458. return
  459. TCHAR Ehlo[] = "EHLO SMTP/r/n";  
  460. send(sock,Ehlo,lstrlen(Ehlo),0);  
  461. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  462. iRet=recv(sock,buffer,256,0); 
  463. if(SOCKET_ERROR==iRet) 
  464. ShowError();  
  465. return
  466. TCHAR login[] = "AUTH LOGIN/r/n"//登陆命令 
  467. send(sock,login,lstrlen(login),0);  
  468. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  469. iRet=recv(sock,buffer,256,0); 
  470. if(SOCKET_ERROR==iRet) 
  471. ShowError();  
  472. return
  473. if(IsDlgButtonChecked(hwnd,IDC_RADIO_QQ)==BST_CHECKED) 
  474. strcat(userName,"/r/n"); 
  475. send(sock,userName,lstrlen(userName),0); //发送加密的用户名 
  476. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  477. iRet=recv(sock,buffer,256,0); 
  478. if(SOCKET_ERROR==iRet) 
  479. ShowError();  
  480. return
  481. strcat(userPassWord,"/r/n"); 
  482. send(sock,userPassWord,lstrlen(userPassWord),0); //发送加密的密码 
  483. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  484. iRet=recv(sock,buffer,256,0); 
  485. if(SOCKET_ERROR==iRet) 
  486. ShowError();  
  487. return
  488. if(IsDlgButtonChecked(hwnd,IDC_RADIO_163)==BST_CHECKED) 
  489. send(sock,userName,lstrlen(userName),0); //发送加密的用户名 
  490. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  491. iRet=recv(sock,buffer,256,0); 
  492. if(SOCKET_ERROR==iRet) 
  493. ShowError();  
  494. return
  495. send(sock,userPassWord,lstrlen(userPassWord),0); //发送加密的密码 
  496. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  497. iRet=recv(sock,buffer,256,0); 
  498. if(SOCKET_ERROR==iRet) 
  499. ShowError();  
  500. return
  501. TCHAR userF[256]; 
  502. TCHAR userL[256]; 
  503. TCHAR temp[256]; 
  504. GetDlgItemText(hwnd,IDC_EDIT_USERNAME,userF,sizeof(userF)/sizeof(TCHAR));  
  505. ComboBox_GetText(GetDlgItem(hwnd,IDC_COMBO_SMTP),temp,sizeof(host_name)/sizeof(TCHAR)); 
  506. strcat(userF,"@"); 
  507. strncpy(userL,temp+5,sizeof(userL)); 
  508. strcat(userF,userL); 
  509. TCHAR mailFrom[256]; 
  510. //MessageBox(hwnd,userF,"",MB_OK); 
  511. wsprintf(mailFrom,TEXT("MAIL FROM:<%s>/r/n"),userF); 
  512. send(sock,mailFrom,lstrlen(mailFrom),0); 
  513. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  514. iRet=recv(sock,buffer,256,0); 
  515. if(SOCKET_ERROR==iRet) 
  516. ShowError();  
  517. return
  518. TCHAR mailAdd[256]; 
  519. GetDlgItemText(hwnd,IDC_EDIT_MAILADD,mailAdd,sizeof(mailAdd)/sizeof(TCHAR)); 
  520. TCHAR mailTo[256]; 
  521. wsprintf(mailTo,TEXT("RCPT TO:<%s>/r/n"),mailAdd); 
  522. send(sock,mailTo,lstrlen(mailTo),0); 
  523. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  524. iRet=recv(sock,buffer,256,0); 
  525. if(SOCKET_ERROR==iRet) 
  526. ShowError();  
  527. return
  528. TCHAR dataCommad[]="DATA/r/n"
  529. send(sock,dataCommad,lstrlen(dataCommad),0);  
  530. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  531. iRet=recv(sock,buffer,256,0); 
  532. if(SOCKET_ERROR==iRet) 
  533. ShowError();  
  534. return
  535. //下面是发送正文及附件部份 
  536. TCHAR data[50000]; 
  537. TCHAR SetMailHead[1024]; //邮件头部信息 
  538. wsprintf(SetMailHead,TEXT("To:%s/r/nFrom:%s/r/nSubject: %s/r/n" 
  539. "Date:2012-8-24/r/nX-Mailer:Kevin's mailer/r/nMIME-Version:1.0/r/n" 
  540. "Content-Type: multipart/mixed;/r/n" 
  541. " boundary=/"----=_NextPart_5039E410_D41071F0_120ABDFB/";/r/n" 
  542. "This is a multi-part message in MIME format./r/n/r/n" 
  543. "------=_NextPart_5039E410_D41071F0_120ABDFB/r/n" 
  544. "Content-Type: multipart/alternative;/r/n" 
  545. " boundary=/"----=_NextPart_5039E410_D41071F0_53510C95/";/r/n/r/n" 
  546. "------=_NextPart_5039E410_D41071F0_53510C95/r/n" 
  547. "Content-Type: text/plain;/r charset=/"gb2312/"/r/n" 
  548. "Content-Transfer-Encoding: base64/r/n/r/n"),mailAdd,userF,pTitle); 
  549. strcat(SetMailHead,pText); //邮件头部再加上正文文本内容 
  550. strcat(SetMailHead,TEXT("/r/n/r/n")); 
  551. strcpy(data,SetMailHead); 
  552. TCHAR SetMailHtml[1024]; //邮件HTML代码部份 
  553. wsprintf(SetMailHtml,TEXT("------=_NextPart_5039E410_D41071F0_53510C95/r/n" 
  554. "Content-Type: text/html;/r/n" 
  555. " charset=/"gb2312/"/r/n" 
  556. "Content-Transfer-Encoding: base64/r/n/r/n")); 
  557. strcat(SetMailHtml,pText); //加入邮件内容 
  558. strcat(SetMailHtml,TEXT("/r/n/r/n------=_NextPart_5039E410_D41071F0_53510C95--/r/n/r/n")); 
  559. strcat(data,SetMailHtml); 
  560. if(TRUE==attach) //判断是否添加了附件路径 
  561. strcat(data,file); //加入附件部份代码 
  562. strcat(data,TEXT("------=_NextPart_5039E410_D41071F0_120ABDFB--/r/n")); 
  563. send(sock,data,lstrlen(data),0); 
  564. TCHAR cN[]="/r/n./r/n"//邮件结束标志 
  565. send(sock,cN,lstrlen(cN),0); 
  566. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  567. iRet=recv(sock,buffer,256,0); 
  568. if(SOCKET_ERROR==iRet) 
  569. ShowError();  
  570. return
  571. TCHAR cQuit[] = "QUIT/r/n"//退出命令 
  572. send(sock,cQuit,lstrlen(cQuit),0);  
  573. ZeroMemory(buffer,sizeof(buffer)/sizeof(TCHAR));  
  574. iRet=recv(sock,buffer,256,0); 
  575. TCHAR cNum[256]; 
  576. if(SOCKET_ERROR==iRet) 
  577. ShowError();  
  578. return
  579. }  
  580. else 
  581. {  
  582. MessageBox(hwnd,TEXT("测试发送成功"),TEXT("恭喜"),MB_OK); 
  583. free(pTitle); //释放空间 
  584. closesocket(sock); //关闭SOCK  
  585. WSACleanup(); 
  586. return
  587. void ShowError() 
  588. TCHAR* lpMsgBuf; 
  589. FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER| //自动分配消息缓冲区 
  590. FORMAT_MESSAGE_FROM_SYSTEM, //从系统获取信息 
  591. NULL,GetLastError(), //获取错误信息标识 
  592. MAKELANGID(LANG_NEUTRAL,SUBLANG_DEFAULT), //使用系统缺省语言 
  593. (LPTSTR)&lpMsgBuf, //消息缓冲区 
  594. 0, 
  595. NULL); 
  596. MessageBox(NULL,lpMsgBuf,"",MB_ICONERROR);  

希望本文所述对大家的C++程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表