JAVA+PHP+阿里云组件纯手工实现POP、SMTP、IMAP开发邮件服务器(一)

前言废话:很早以前就打算写博客,可是一直由于在创业,抽不出时间。现在朝九晚五,打算利用晚上的时间,开始写博客。html

 

本类博客是一个系列,将完整的讲述纯手工开发一个邮件服务器的过程,并附有关键代码。演示地址  做者邮箱: longge93@cliyun.comjava

这一篇先说整个系统的架构。邮箱系统主要分为几个模块,根据消息发起与传递的对象不一样。我把它们分为如下几类:web

 

  1. 客户端(手机、foxmail等)发起,目的地是各大邮箱服务商的服务器。(协议:SMTP,端口:25)redis

  2. 各大邮箱服务商的服务器发起,到该邮件的收件人所在邮箱服务商的服务器。(协议:SMTP,端口:25)算法

  3. 有客户端请求,从邮箱服务商服务器商拉取邮件信息或内容。(协议:POP、IMAP,端口:110等)数据库

以上步骤,按照序号依次就是一封邮件从你手机或电脑发出,到达对方终端的过程。服务器

因此,若是要完成一个邮箱服务器,第一步就是实现各类协议。所谓协议,就是在创建socket链接以后,按照事先规定好的“暗号”,传递信息。具体每种协议的规矩,百度能够轻松知道。也可访问协议制定机构的网站获取。网络

 

而后咱们来整理一下,实现一个邮件服务器,咱们须要几个模块:架构

  1. 邮件接收器:在服务器上创建socket服务端,监听25端口。接收其余邮件服务器经过SMTP协议发过来的邮件。一般垃圾邮件过滤就是从这里开始的。socket

  2. 邮件发送器:当有用户要发送邮件时,在服务器上创建socket客户端,链接到目的邮箱的邮件接收器,经过SMTP协议发出邮件。

  3. POP、IMAP服务器:收到邮件后,还得让客户经过客户端能拉取到,这个模块的做用就是从数据库读取已经收到的邮件,传递给客户端。不能主动推,只能被动的等待拉取。若是要主动推,能够研究一下微软的exchange协议。

  4. 邮件转发器:当客户要经过手机等客户端发送邮件时,会先把邮件经过socket传递给你的服务器,而后再由邮件发送器发出。那么,邮件转发器的做用就是从客户端手里接收邮件,传递给发送器发送。该过程使用SMTP协议。

以上几个模块均使用JAVA实现。那么第一个问题来了,当用户使用WEB端,在网页上写好一封邮件,当他点击发送后,咱们如何触发JAVA写的邮件发送器呢?这时候就要引入咱们的消息中间件模块了。

 

消息中间件模块是基于redis的,消息发布、订阅机制。阿里云的KVstore对其作了封装。简单的说,就是你能够建立一个管道,这个管道有不少不少分支,你往这个管道里丢什么东西,全部分支都将及时收到这些东西。

 

利用消息中间件,咱们经过WEB端发布管道,JAVA发件器订阅该管道。便可实施触发邮件发送动做。

 

第二个问题是邮件附件、邮件原EML文件的保存问题。直接保存成文件对服务器压力很大,并且不利于查询等动做。因此我把这些所有推到阿里云的OSS存储上去。把存储路径保存下来。

 

第三个问题是邮件EML文件的解析、生成的问题。众所周知的javamail遇到中文后,其实蛮多问题。须要慢慢优化,作到更高的效率和正确率。

 

第四个问题是如何经过WEB端上传大附件。一般的解决办法是安装控件,我这里采用百度的开源项目webuploader,该项目容许用户选择flash和HTML5两种方式之一,来上传附件。而且具备大文件切片、文件上传前HASH验证等功能。

 

第五个问题是垃圾邮件的过滤问题,参考了不少过滤算法后,打算从神经网络算法延伸一套垃圾邮件过滤算法出来。具体的后面慢慢讲。

 

第六个问题是如何防止邮件攻击。天天都有大量的垃圾IP试图发送过来,若是每次都在创建socket以后再经过算法判断该IP是否在黑名单等等,太浪费资源。应该自动将其加入防火墙,之后就不用再处理该IP了。

 

正文从下一篇开始~

 

相关文章
相关标签/搜索