Apache James 搭建自己的邮件服务器

–>


原文 address:http://blog.csdn.net/jwdstef/article/details/39495097



中小企业是否可以免费拥有自己的邮件系统,而不是去购买腾讯,163的企业邮箱。答案是肯定的,可以,Java开源的邮件系统很多,经过筛选,调研最终我们选择用James来搭建自己的邮件系统。接下来我们来看看window7环境下如何用James来搭建邮件系统:

       Apache James 简称 James, 是 Java Apache Mail Enterprise Server的缩写。James 是100%基于Java的电子邮件服务器。它是一种独立的邮件服务器,并提供了一个完整的电子邮件解决方案,用来收、发电子邮件。

前期准备

1.Jdk1.6 需要配置Java环境变量,这个就不在这里详细介绍如何配置了。

2.James运行文件,下载地址http://james.apache.org/download.cgi



下载完成后直接解压,解压后找到D:\X-EI\apache-james-2.3.2\james-2.3.2\bin目录下的run.bat文件,就可以启动james邮件服务器了。

         ps:如果James用到的端口被占用,可能启动的时候会报错,然后一闪而过,这个时候我们可以去修改James的POP3,SMTP,NNTP协议的端口,他们三个默认的端口为110,25,119.这三个协议我们可能见的比较多,但是你是否了解他们都代表什么意思呢,既然我们提到了这三个协议,那么我们就来看看这三个协议代表什么意思。

  • POP3(Post Office Protocol 3)即邮局协议的第3个版本,它是规定个人计算机如何连接到互联网上的邮件服务器进行收发邮件的协议。它是因特网电子邮件的第一个离线协议标准,POP3协议允许用户从服务器上把邮件存储到本地主机(即自己的计算机)上,同时根据客户端的操作删除或保存在邮件服务器上的邮件,而POP3服务器则是遵循POP3协议的接收邮件服务器,用来接收电子邮件的。POP3协议是TCP/IP协议族中的一员,由RFC
    1939 定义。本协议主要用于支持使用
    客户端远程管理在服务器上的电子邮件
  • SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP协议属于TCP/IP协议族,它帮助每台计算机在发送或中转信件时找到下一个目的地。通过SMTP协议所指定的服务器,就可以把E-mail寄到收信人的服务器上了,整个过程只要几分钟。SMTP服务器则是遵循SMTP协议的发送邮件服务器,用来发送或中转发出的电子邮件
  • NNTP(Network News Transport Protocol),中文释义:(RFC-977)网络新闻传输协议。这是一个主要用于阅读和张贴新闻文章(俗称为“帖子”,比较正式的是“新闻组邮件”)到Usenet上的Internet应用协议,也负责新闻在服务器间的传送。NNTP用于向Internet上NNTP服务器或NNTP客户(新闻阅读器)发布网络新闻邮件的协议,提供通过Internet使用可靠的基于流的新闻传输,提供新闻的分发、查询、检索和投递。NNTP还专门设计用于将新闻文章保存在中心数据库的服务器上,这样用户可以选择要阅读的特定条目,还提供过期新闻的索引、交叉引用和终止。

归纳下就是pop3是收邮件的协议,smtp是发邮件的协议,nntp是新闻协议。

如何修改James这几个协议的端口

找到目录D:\X-EI\apache-james-2.3.2\james-2.3.2\apps\james\SAR-INF底下的config.xml文件,用editplus或者其他编辑器打开文件,ctrl+f搜索pop3

[html]
view plain
copy

  1. <pop3server enabled=“true”>  
  2.     <!– POP3协议端口 –>  
  3.     <port>1130</port>  
  4.     <handler>  
  5.        <helloName autodetect=“false”>jwdstef.com</helloName>  
  6.        <connectiontimeout>120000</connectiontimeout>  
  7.     </handler>  
  8.  </pop3server>  

      我这里把原来的110端口修改成1130端口了,其他的两个端口修改也一样。

[html]
view plain
copy

  1. <smtpserver enabled=“true”>  
  2.       <!– SMTP协议端口 –>  
  3.       <port>25</port>  
  4.       <handler>       
  5.          <helloName autodetect=“false”>jwdstef.com</helloName>  
  6.          <connectiontimeout>360000</connectiontimeout>  
  7.          <authRequired>true</authRequired>  
  8.          <authorizedAddresses>192.168.0.0/255.255.255.0,127.0.0.0/8</authorizedAddresses>  
  9.          <maxmessagesize>0</maxmessagesize>  
  10.       </handler>  
  11.    </smtpserver>  


[html]
view plain
copy

  1. <nntpserver enabled=“true”>  
  2.      <!– NNTP协议端口 –>  
  3.      <port>119</port>  
  4.      <handler>  
  5.         <helloName autodetect=“false”>jwdstef.com</helloName>  
  6.         <connectiontimeout>120000</connectiontimeout>  
  7.         <authRequired>false</authRequired>  
  8.      </handler>  
  9.   </nntpserver>  


我们修改完这个几个端口后,就可以顺利启动James服务了。






配置服务



默认配置启动James服务,只能给内网发送邮件,我们的要求是可以给外网的其他邮箱发邮件,比如163,qq,sina等邮箱发送邮件,那么我们必须修改James默认配置,接下来我们就来看看如何修改
在D:\X-EI\apache-james-2.3.2\james-2.3.2\apps\james\SAR-INF下打开config.xml文件,找到

[html]
view plain
copy

  1. <postmaster>[email protected]</postmaster>  
  2.       <servernames autodetect=“true” autodetectIP=“true”>  
  3.          <servername>localhost</servername>  
  4.       </servernames>  

修改localhost为你自己的域名,假如我们的域名是jwdstef.com,那么修改完成为:

[html]
view plain
copy

  1. <postmaster>[email protected]</postmaster>  
  2.       <servernames <span style=“color:#cc0000;”>autodetect=“false” autodetectIP=“false”</span>>  
  3.          <servername>jwdstef.com</servername>  
  4.       </servernames>  

修改dns服务,打开cmd,执行ipconfig /all 找到自己的DNS服务



[html]
view plain
copy

  1. <servers>  
  2.          <!–Enter ip address of your DNS server, one IP address per server –>  
  3.          <!– element. –>  
  4.          <server>mail.126.com</server>  
  5.           <server>smtp.163.com</server>  
  6.           <server>202.106.195.68</server>  
  7.            <server>192.168.1.98</server>  
  8.           <server>jwdstef.com</server>  
  9.           
  10.       </servers>  
  11.       <autodiscover>false</autodiscover>  
  12.       <authoritative>false</authoritative>  

找到

[html]
view plain
copy

  1. <mailet match=“RemoteAddrNotInNetwork=127.0.0.1” class=“ToProcessor”>   
  2.     <processor> relay-denied </processor>   
  3.     <notice>550 – Requested action not taken: relaying denied</notice>   
  4. </mailet>  


将其注释掉。并且开启SMTP Server 身份验证,打开

[html]
view plain
copy

  1. <span style=“font-family:Microsoft YaHei;”><authRequired>true</authRequired></span>  

打开后邮箱访问需要帐号验证,这样保证邮箱的安全性。
James 邮件用户的用户信息默认保存在apps\james\var\users 目录下,通过修改配置文件apps\james\SAR-INF\config.xml,可以把用户信息保存到数据库中,
配置方法如下

找到

[html]
view plain
copy

  1. <users-store>  
  2.      <repository name=“LocalUsers” class=“org.apache.james.userrepository.UsersFileRepository”>  
  3.         <destination URL=“file://var/users/”/>  
  4.      </repository>  


改为

[html]
view plain
copy

  1. <users-store>  
  2.         
  3.       <repository name=“LocalUsers” class=“org.apache.james.userrepository.JamesUsersJdbcRepository” destinationURL=“db://intouch/users”>  
  4.          <sqlFile>file://conf/sqlResources.xml</sqlFile>  
  5.       </repository>  
  6.   
  7.    </users-store>  


[html]
view plain
copy

  1. 通过修改用户的存储介质从file变成了db,db://intouch/users 中intouch是数据库的名字,users是邮件系统存储用户的表名  

然后我们需要让邮件信息也保存在数据库,邮件信息的保存需要修改

[html]
view plain
copy

  1. 找到<inboxrepository>项, 默认是<repository destinationurl=“file://var/mail/inboxes/” type=“mail”>   
  2. 屏蔽掉,在它下面有个例子<repository destinationurl=“db://maildb/inbox/” type=“mail”>,**它.  
  3. 然后是spool,找到<spoolrepository>将默认屏蔽掉.     
  4. **<repository   destinationurl=“db://maildb/spool/spool”   type=“spool”/>    
  5. 这时候数据库中会自动建两个表:spool和inbox;spool是临时表,只要通过邮件服务器的邮件,不管是发,收,都会存到这个表里。存入的时候邮件有个状态:message_state,状态的值有几种,transe..span,root等第一个表示正在传,当传完后邮件服务器会自动删除这条邮件(此功能可配置,后面有介绍,通过改删除邮件的SQL可屏蔽此功能);当接收一个邮件时,也是先放在spool表里。然后往inbox表里转存;  



我这里使用的数据库是Mysql,首先我在mysql里面创建好数据库intouch,找到<data-source>

[html]
view plain
copy

  1. <data-source name=“intouch” class=“org.apache.james.util.dbcp.JdbcDataSource”>  
  2.          <driver>com.mysql.jdbc.Driver</driver>  
  3.          <dburl>jdbc:mysql://localhost/intouch?autoReconnect=true</dburl>  
  4.          <user>root</user>  
  5.          <password>123</password>  
  6.          <max>20</max>  
  7.       </data-source>  

配置好数据库连接。然后将对应数据库的jar包放到D:\X-EI\apache-james-2.3.2\james-2.3.2\lib下
这样James的数据库连接就配置好了,启动James服务,我们会看到mysql数据库intouch库里面多了一个users表。



我们还需要配置一个地方,修改c:/windows/system32/drivers/etc/hosts 文件,增加一个地址映射。

[html]
view plain
copy

  1. 127.0.0.1 jwdstef.com  



以上配置完成后,James邮箱所有配置完成。


接下来我们需要登录邮件服务器,去增加用户,发送邮件,接收邮件。


执行CMD,打开命令窗口,执行命令telnet jwdstef.com 4555,

[html]
view plain
copy

  1. JAMES Remote Administration Tool 2.3.1  
  2. Please enter your login and password  
  3. Login id:  
  4. root  
  5. Password:  
  6. root  
  7. Welcome root.HELP for a list of commands  


这里的4555端口是默认的,为了安全,我们最好修改下这个端口,还有登录的用户名和密码,最好也修改了。修改的位置

[html]
view plain
copy

  1. <remotemanager enabled=“true”>  
  2.     <!–服务连接端口–>  
  3.       <port>4555</port>  
  4.       <handler>  
  5.          <helloName autodetect=“false”>jwdstef.com</helloName>  
  6.          <administrator_accounts>  
  7.             <!–服务连接管理员帐号密码–>  
  8.             <account login=“root” password=“root”/>  
  9.          </administrator_accounts>  
  10.          <connectiontimeout> 60000 </connectiontimeout>  





登录成功后,我们可以添加用户,命令如下:
adduser 帐号 密码






完成配置后,我们增加了用户,但是如何收发邮件呢,通过命令去收发邮件肯定不可能,所以我们需要一个webmail来收发邮件,我们可以自己搭建一个webmail客户端应用,也可以使用foxmail等邮件客户端软件。

我们先看看如何配置foxmail,使其可以连接到我们刚才搭建的邮件服务器,完成邮件的收发。

打开foxmail进入设置页面,添加账号


jwdstef这个用户是我在James服务后台通过命令 adduser jwdstef jd1增加的。配置完成后,我们就可以收发邮件了。我们来试试给163的邮箱发一封邮件



登录163邮箱



收到邮件,说明我们的邮件服务器配置成功了!

如果还不能成功发送,接收,采取如下暴力配置:

①、查找替换所有的 localhost为域名

②、查找所有autodetect属性,修改为false。autodetectIP也设为false.

查找所有myMailServer,替换为域名。

附件大小配置

整合了mysql,james 对附件大小的限制是使用mysql对行记录的限制来实现的。mysql在默认配置配置情况下默认是1M

修改mysql所在安装目录的my.ini 增加max-allowed-packet=64M(附件大小) 

收附件的时候,会遇到收不到超过10m附件的情况,一个是前面说的mysql字段大小限制,还有一个会有jvm虚拟内存的限制,因为默认16m的虚拟内存是不够的,要在james中修改。这里有两种修改方法: 


1)在run.bat中加入set JAVA_OPTS=“-Xms32m -Xmx512m -Xss512m” 并启动 
2)在conf/wrapper.conf修改并通过服务启动

wrapper.java.initmemory=64 
wrapper.java.maxmemory=512

如果想正常收发邮件,请确保好helo或ehlo名,并对自己的mx地址做好dns反向解析,就可以基本保证全网收发.

James用户密码的加密方式

james 用户密码所用的加密方式是sha加密

[java]
view plain
copy

  1. /** 
  2.      * 可以用于 md5 或者 sha 加密 
  3.      *  
  4.      * @param pass 
  5.      *            要加密的明文 
  6.      * @param algorithm 
  7.      *            加密方式 (md5或 sha) 
  8.      * @return 
  9.      * @throws NoSuchAlgorithmException 
  10.      */  
  11.     public static String digestString(String pass, String algorithm)   
  12.         throws NoSuchAlgorithmException {  
  13.   
  14.         MessageDigest md;  
  15.         ByteArrayOutputStream bos;  
  16.   
  17.         try {  
  18.             md = MessageDigest.getInstance(algorithm);  
  19.             byte[] digest = md.digest(pass.getBytes(“iso-8859-1”));  
  20.             bos = new ByteArrayOutputStream();  
  21.             OutputStream encodedStream = MimeUtility.encode(bos, “base64”);  
  22.             encodedStream.write(digest);  
  23.             return bos.toString(“iso-8859-1”);  
  24.         } catch (IOException ioe) {  
  25.             throw new RuntimeException(“Fatal error: “ + ioe);  
  26.         } catch (MessagingException me) {  
  27.             throw new RuntimeException(“Fatal error: “ + me);  
  28.         }  
  29.     }  

webmail配置

下来我们看看,如何搭建自己的邮件web端应用,经过调研筛选,这里我选择了Java开源的claros intouch2作为web端。

下载claros intouch2,地址:http://www.claros.org/web/showProduct.do-id=1.html



下载完成后我们把war包部署到tomcat6底下,启动tomcat,关于tomcat的安装和配置,这里我就不介绍了,大家自己去g.cn。

需要修改D:\Program Files\apache-tomcat-6.0.28\apache-tomcat-6.0.28\webapps\intouch2\WEB-INF\config目录下的config.xml文件

[html]
view plain
copy

  1. <?xml version=“1.0” encoding=“UTF-8”?>  
  2. <claros-config>  
  3.     <!– COMMON PARAMETERS –>  
  4.     <common-params>  
  5.         <charset>utf-8</charset>  
  6.         <!– the timezone is not functional at 2.0 –>  
  7.         <server-timezone>Europe/Istanbul</server-timezone>  
  8.         <!– this directory must be writable (e.g. run a chmod 777 on it) –>  
  9.         <tmp-dir>/tmp</tmp-dir>   
  10.         <!– th e following two is in MB’s–>  
  11.         <max-attachment-size>5</max-attachment-size>  
  12.         <max-mail-size>10</max-mail-size>  
  13.         <title>Claros inTouch 2.1</title>  
  14.         <!– We recommend running spamassasin. –>  
  15.         <spam-check-enabled>false</spam-check-enabled>  
  16.         <!– valid values are: da, de, en, fr, it, pt_br, pl, sk, tr, vi, zh_cn_utf8 –>  
  17.         <default-lang>en</default-lang>  
  18.         <!– this is the default rss feed. users can set their own –>  
  19.         <rss-feed>http://rss.cnn.com/rss/cnn_topstories.rss</rss-feed>  
  20.     </common-params>  
  21.   
  22.     <!– CHAT SERVER SETUP –>  
  23.     <!– if you have a jabber server with transports running such as   
  24.         the MSN, yahoo, icq, aol transports the following transport   
  25.         domains must be set. If you don’t have your own jabber server  
  26.         or not running transports omit the following settings.  
  27.     —>  
  28.     <chat>  
  29.         <default-domain>claros.org</default-domain>  
  30.         <msn-transport>msn.claros.org</msn-transport>  
  31.         <yahoo-transport>yahoo.claros.org</yahoo-transport>  
  32.         <icq-transport>icq.claros.org</icq-transport>  
  33.         <aol-transport>aol.claros.org</aol-transport>  
  34.     </chat>  
  35.   
  36.     <!– MAIL SERVER SETUP –>      
  37.     <servers>  
  38.         <server>  
  39.             <!– give any name you desire –>  
  40.             <shortname>jwdstef.com</shortname>  
  41.             <!– your imap/pop3 server ip/dns –>  
  42.             <fetch-server>jwdstef.com</fetch-server>  
  43.             <fetch-server-port>1130</fetch-server-port>    
  44.             <fetch-protocol>pop3</fetch-protocol>    
  45.             <fetch-ssl>false</fetch-ssl>    
  46.     
  47.             <smtp-server>jwdstef.com</smtp-server>    
  48.             <smtp-server-port>25</smtp-server-port>    
  49.             <smtp-authenticated>true</smtp-authenticated>    
  50.             <smtp-ssl>false</smtp-ssl>    
  51.           
  52.             <folder-namespace></folder-namespace>  
  53.         </server>  
  54.     </servers>  
  55.   
  56.     <!– THE DATABASE SETUP –>  
  57.     <!–   
  58.         Please note that DB setup is essential to work. There is a intouch-mysql file in the SQL directory  
  59.         of the zip file. Please create a database and dump the sql file to the db.   
  60.           
  61.         mysqladmin -u root -p create intouch  
  62.         mysql -u root -p intouch < intouch-mysql.sql  
  63.      —>  
  64.     <db-config>  
  65.         <db>  
  66.             <!– do not change the term file!!! –>  
  67.             <id>file</id>  
  68.             <!– the connection url for the JDBC connection –>  
  69.             <database>jdbc:mysql://localhost:3306/intouch</database>  
  70.             <!– the connection class –>  
  71.             <driver>com.mysql.jdbc.Driver</driver>  
  72.             <!– the user with read/write/delete/update/select permission to the database  –>  
  73.             <login>root</login>  
  74.             <!– the plain text password –>  
  75.             <password>123</password>  
  76.         </db>  
  77.     </db-config>  
  78. </claros-config>  

启动后我们访问Intouch。

访问成功!这样我们的web客户端也搭建完成。

本文来源 互联网收集,文章内容系作者个人观点,不代表 本站 对观点赞同或支持。如需转载,请注明文章来源,如您发现有涉嫌抄袭侵权的内容,请联系本站核实处理。

© 版权声明

相关文章