全面理解虚拟邮件域

全面理解虚拟邮件域,第1张

介绍 如今 个人计算机拥有强大的功能 单独的一台可以轻易地完成几台服务器的任务 随着internet和邮件系统的成功 我们不得不管理越来越多的邮件域 这里有一个在同一机器上管理几个独立邮件域的方法 A linux premiere! (首次公映???) 基本原理 虚拟邮件域是一种在同一个服务器上管理 独立的用户列表的方法 每个虚拟域有它自己的密码文件 自己的缓冲目录和用户化名文件 对每个虚拟邮件域 linuxconf 将建立 ◆ /etc /vmail /passwd virtual_domain ◆ /etc /vmail /shadow virtual_domain ◆ /etc /vmail /aliases virtual_domain ◆ /var /spool /vmail / virtual_domain ◆ /vhome /virtual_domain / 这里 virtual_domain是一个域名 比如 定义虚拟域对话框 要建立一个新的虚拟邮件域 你必须填写一个对话 框 有关DNS和 IP alias 将在这个帮助文件的其他部分描述 在这里 我们将叙述对话框 一个名字 你必须为域取名字 你所要做的也仅是如此 Fall back destination 这是一个可选的域 一般来说 当一个邮件信息被发送给一个虚拟邮件域的帐户 将会进行以下过程 ◆检查那个名字的化名 如果有一个 将信息发送给化名列表中的每一个成员 化名可以指向其他化名 ◆如果没有发现化名 则将检查虚拟域的用户列表 邮件被附加到符合条件的用户文件夹中 ◆如果既没有化名也没有 用户适合 这个信息会被拒绝 发送者也将收到一个出错信息 如果定义了fall back 域 则邮件改为发往退回地址 退回地址可以为: ( )空 这是默认的情况 信息被拒绝 ( )another_user@another_domain 信息被发往另一个域中的一个特定用户 ( )@another_domain 信息发往在另一个域中的同一个帐户 例如 发往 unknown@this_domain将转寄给unknown@another_domain ( )account 信息被发往同一个域中的另一个帐户 这个帐户可以是一个化名 化名文件 每个虚拟域都绝对有一个化名文件叫做/etc/vmail/alias domain 这里domain是域名 你可以定义两个或更多 他们会被vdeliver program使用 vdeliver 绝对的拥有最高的优先权 它先在第一个里面查找 然后第二个 直到找到匹配的为止 注意 和一般的sendmail的化名(/etc/alias)过程一样 化名定义也可以指向另一个化名 邮件列表也可以如此定义 化名文件和普通的sendmail化名文件由同一个对话框维护 这样 提供了相同的功能 域名化名 规定几个域指向同一个用户群是可能的 只要需要 你可以加入很多 例如 你可以定义一个虚拟域为foo ca 然后通过域化名注册为 两个域将是等效的 开始前的注意事项 虚拟邮件域是你邮件服务器的普通邮件功能的补充 普通邮件域仍然在正确地管理 邮件存储在/var/spool/mail中 因此 如果你的机器现在接受域的邮件 你又希望分开接受和域的邮件 你必须定义这两个域为虚拟邮件域 域的配置没有影响 怎样设置虚拟邮件域 下面是Step By Step的介绍: 怎样配置POP客户端 POP的用户端不用作任何特殊的设置(这是件好事!)我们希望把几个邮件服务器并入同一个box中 We don t want to tell everyone about it : ) 怎样安装服务器 阅读邮件的技巧和访问虚拟是一样的 你需要IP地址 这里有主要的设置 假设我们想建立三个虚拟邮件域 你可以用相同的方法去安装这三个独立的服务器 每个服务器为一个单独的邮件域 从此处直至文末我们将给出这三个服务器怎样被合并到一个单独的机器上 DNS的设置 从DNS来看 每个域有一个邮件服务器 因此每个域的MX是 ◇ → ◇ → ◇ → 这是DNS所告诉世界的 也是所告诉用户的 一般来说 域的用户从接收邮件 域的用户从接收邮件 等等 到目前为止 每个邮件域已经拥有了一个服务器 安装服务器 继续下面的设置(真实的或虚拟的) 至DNS中去为每个服务器分配IP地址 这里我使用私人IP做为例子 大家会看到我从同一个网络中分配IP ◇→ ◇→ ◇→ 然后我们可以继续 根据那些IP安装 个linux服务器 tell sendmail on each one to accept one of the three domains Telling virtual 代替 个linux服务器 我们只安装单独的一个 对每个虚拟邮件域 我们必须 ◇用linuxconf 来定义 这里只包括为域命名 ◇定义IP alias (仍然用linuxconf) 这样机器也会回应对这个IP的查询 这在linuxconf 的菜单 neorking/IP aliases for virtual hosts 中完成 ◇在/etc/nf 中安装/usr/lib/linuxlonf/lib/vpop d代替/usr/ in/in/pop d 即使你没有使用虚拟域 用vpop d代替pop d 也是一个drop IP alias 是主要的 pop协议只有通过目标的IP才能识别出请求的目标 这就是为什么pop客户端必须使用不同的名字(实际上是不同的IP)从不同的邮件域阅读信息 从他们的观点来看 This is expected anyway 怎样安装vpop d 在你所使用的发行版本是用vpop d 代替标准的pop daemon 的吗?也许不是 不同的发行版本带有不同的pop d 支持NIS PAM和其他证实了的特性 简易地支持所有这些的一个最好的方法是让pop daemon 控主邮件域 vpop d 仅仅管理虚拟域 To get the result simply pass as an argument to vpop d the path of the native pop daemon 当产生一个对主域 的pop请求时 vpop d 将把控制权交给它 下面是如何设置/etc/nf 的例子 pop stream tcp nowait root /usr/ in/tcpd /usr/lib/linuxconf/lib/vpop d /usr/ in/ipop d 不要取代pop d 命令 只要简单地插入/usr/lib/linuxconf/lib/vpop d 即可 这一行依发行版本的不同而有所差别 如何检查一个配置 设置虚拟域时的大多数错误和DNS有关 下面有一些测试让你检验你的设置是否正确 一个建议 使用pop客户端不是一个强有力的测试这种配置的方法 那些程序根本不会给出任何信息 它们或是能工作或不能 检查DNS 对每个虚拟域 你必须作一些DNS设置 我们将用域作例子来说明 下面是具体的步骤 The MX 命令 nslookup q=mx 应该列出一些有用的信息 至少应能得到邮件服务器的名字和它的IP地址 这或是或是服务器的正式名字 得到的名字不需要在域中 然而 它必须指向正确的物理服务器 虚拟邮件服务器 在DNS中必须定义 这里我用mailhost 它可以是或是其它任何名字 下面的命令 nslookup 应该列出IP地址 接下来的命令 nslookup the_IP_number_you_got 应该显示 如果你没能得到这个 那么你的虚拟POP服务器根本不会工作 事实上 最后 你需要对这个IP地址进行正确的反向查询 如果在同一个DNS中 特定的反向查询域被定义成虚拟域的话 linuxconf会神奇地完成它 如你成功地完成上两个查询 你已完成了最艰难的部分 有没有服务器在监听 使用下面的命令 telnet 将连接到物理服务器 这证明IP alias已正确地设置了 有没有虚拟POP服务器在监听 用下面的命令来看vpop d有没有正确地安装 telnet pop 你应得到 +OK Virtual POP Server(Version ) ready 这里 是关键 如果没有显示这个 说明虚拟域并没有定义 或者/etc/nf中并没有安装vpop d 快速检测的工具 脚本 /usr/lib/linuxconf/lib/checkvdomain可用来检查虚拟域的vpop d的安装情况 不带参数运行它可得到更多有关它的信息 脚本 /usr/lib/linuxconf/lib/testalldomain读取/etc/named boot中定义的所以域 然后在每个域中运行脚本checkvdomain(假设每个虚拟域都有一个虚拟邮件主机) 它将报告域的配置是否正确 这对管理员管理很多虚拟域很有帮助 Once *** 作 如何增加POP用户 一旦一个虚拟邮件域开始正常工作 仍然需要在其中增加POP用户 在user accounts菜单中有一项叫Virtual POP account(mail only)的选项可以进行设置 它允许你在里面选择一个虚拟域然后增加用户或进行修改 Co_administrator 对每个虚拟邮件域 linuxconf都加入了一个新的特权 你可以将此特权交给任何普通用户 他将被允许管理这个虚拟域中的用户列表(仅仅是POP用户) 这也是完全界面的 *** 作方式 用户怎样改变他的密码 pop only 用户 (ppp用户也是)的一个问题是他们没有权限使用任何帐户外壳程序来简单地修改他们的密码 linuxconf对这个问题提供了一个巧妙的解决办法 lishixinzhi/Article/program/Oracle/201311/16870

POP3(Post Office Protocol 3) POP适用于C/S结构的脱机模型的电子邮件协议,
目前已发展到第三版,称POP3。,它规定怎样将个人计算机连接到Internet的邮件
服务器和下载电子邮件的电子协议。它是因特网电子邮件的第一个离线协议标准,
POP3允许用户从服务器上把邮件存储到本地主机(即自己的计算机)上,同时删除
保存在邮件服务器上的邮件,而POP3服务器则是遵循POP3协议的接收邮件服务器,
用来接收电子邮件的。
POP适用于C/S结构的脱机模型。脱机模型即不能在线 *** 作,不像IMAP4(netscape
支持IMAP4)当客户机与服务器连接并查询新电子邮件时,被该客户机指定的所有
将被下载的邮件都将被程序下载到客户机,下载后,电子邮件客户机就可以删除或
修改任意邮件,而无需与电子邮件服务器进一步交互。POP3客户向POP3服务器发送
命令并等待响应,POP3命令采用命令行形式,用ASCII码表示。
服务器响应是由一个单独的命令行组成,或多个命令行组成,响应第一行以ASCII
文本+OK或-ERR指出相应的 *** 作状态是成功还是失败在POP3协议中有三种状态,认
可状态,处理状态,和更新状态。
当客户机与服务器建立联系时,一旦客户机提供了自己身份并成功确认,即由认可
状态转入处理状态,
在完成相应的 *** 作后客户机发出quit命令,则进入更新状态,更新之后最后重返认
可状态。如下图
等待连接 身份确认 quit命令
—— |认可|————— |处理|——————|更新|
|__________________________________|
重返认可状态
POP3命令码如下:
命令 参数 状态 描述
------------------------------------------
USER username 认可 此命令与下面的
pass命令若成功,将导致状态转换
PASS password 认可
APOP Name,Digest 认可 Digest是MD5消息
摘要
------------------------------------------
STAT None 处理 请求服务器发回关于
邮箱的统计资料,如邮件总数和总字节数
UIDL [Msg#] 处理 返回邮件的唯一标
识符,POP3会话的每个标识符都将是唯一的
LIST [Msg#] 处理 返回邮件数量和每
个邮件的大小
RETR [Msg#] 处理 返回由参数标识的
邮件的全部文本
DELE [Msg#] 处理 服务器将由参数标
识的邮件标记为删除,由quit命令执行
RSET None 处理 服务器将重置所有
标记为删除的邮件,用于撤消DELE命令
TOP [Msg#] 处理 服务器将返回由
参数标识的邮件前n行内容,n必须是正整数
NOOP None 处理 服务器返回一个肯定的响应

POP3是Post Office Protocol 3的简称,即邮局协议的第3个版本,它规定怎样将个人计算机连接到Internet的邮件服务器和下载电子邮件的电子协议。

它是因特网电子邮件的第一个离线协议标准,POP3允许用户从服务器上把邮件存储到本地主机(即自己的计算机)上,同时删除保存在邮件服务器上的邮件,而POP3服务器则是遵循POP3协议的接收邮件服务器,用来接收电子邮件的。

SMTP 的全称是“Simple Mail Transfer Protocol”,即简单邮件传输协议。它是一组用于从源地址到目的地址传输邮件的规范,通过它来控制邮件的中转方式。

SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。SMTP 服务器就是遵循 SMTP 协议的发送邮件服务器。

扩展资料:

POP3服务常用指令:

1、USER [username]

处理用户名。

2、PASS [password]

处理用户密码。

3、APOP [Name,Digest]

认可Digest是MD5消息摘要。

4、STAT

处理请求服务器发回关于邮箱的统计资料,如邮件总数和总字节数。

5、UIDL [Msg#]

处理返回邮件的唯一标识符,POP3会话的每个标识符都将是唯一的。

6、LIST [Msg#]

处理返回邮件数量和每个邮件的大小。

7、RETR [Msg#]

处理返回由参数标识的邮件的全部文本。

8、DELE [Msg#]

处理服务器将由参数标识的邮件标记为删除,由quit命令执行。

9、RSET

处理服务器将重置所有标记为删除的邮件,用于撤消DELE命令。

10、TOP [Msg# n]

处理服务器将返回由参数标识的邮件前n行内容,n必须是正整数。

参考资料来源:百度百科-POP3

参考资料来源:百度百科-SMTP

python中email模块使得处理邮件变得比较简单,今天着重学习了一下发送邮件的具体做法,这里写写自己的的心得,也请高手给些指点。
一、相关模块介绍
发送邮件主要用到了smtplib和email两个模块,这里首先就两个模块进行一下简单的介绍:
1、smtplib模块
smtplibSMTP([host[, port[, local_hostname[, timeout]]]])
SMTP类构造函数,表示与SMTP服务器之间的连接,通过这个连接可以向smtp服务器发送指令,执行相关 *** 作(如:登陆、发送邮件)。所有参数都是可选的。
host:smtp服务器主机名
port:smtp服务的端口,默认是25;如果在创建SMTP对象的时候提供了这两个参数,在初始化的时候会自动调用connect方法去连接服务器。
smtplib模块还提供了SMTP_SSL类和LMTP类,对它们的 *** 作与SMTP基本一致。
smtplibSMTP提供的方法:
SMTPset_debuglevel(level):设置是否为调试模式。默认为False,即非调试模式,表示不输出任何调试信息。
SMTPconnect([host[, port]]):连接到指定的smtp服务器。参数分别表示smpt主机和端口。注意: 也可以在host参数中指定端口号(如:smptyeahnet:25),这样就没必要给出port参数。
SMTPdocmd(cmd[, argstring]):向smtp服务器发送指令。可选参数argstring表示指令的参数。
SMTPhelo([hostname]) :使用"helo"指令向服务器确认身份。相当于告诉smtp服务器“我是谁”。
SMTPhas_extn(name):判断指定名称在服务器邮件列表中是否存在。出于安全考虑,smtp服务器往往屏蔽了该指令。
SMTPverify(address) :判断指定邮件地址是否在服务器中存在。出于安全考虑,smtp服务器往往屏蔽了该指令。
SMTPlogin(user, password) :登陆到smtp服务器。现在几乎所有的smtp服务器,都必须在验证用户信息合法之后才允许发送邮件。
SMTPsendmail(from_addr, to_addrs, msg[, mail_options, rcpt_options]) :发送邮件。这里要注意一下第三个参数,msg是字符串,表示邮件。我们知道邮件一般由标题,发信人,收件人,邮件内容,附件等构成,发送邮件的时候,要注意msg的格式。这个格式就是smtp协议中定义的格式。
SMTPquit() :断开与smtp服务器的连接,相当于发送"quit"指令。(很多程序中都用到了smtpclose(),具体与quit的区别google了一下,也没找到答案。)
2、email模块
emial模块用来处理邮件消息,包括MIME和其他基于RFC 2822 的消息文档。使用这些模块来定义邮件的内容,是非常简单的。其包括的类有:
class emailmimebaseMIMEBase(_maintype, _subtype, _params):这是MIME的一个基类。一般不需要在使用时创建实例。其中_maintype是内容类型,如text或者image。_subtype是内容的minor type 类型,如plain或者gif。 _params是一个字典,直接传递给Messageadd_header()。
class emailmimemultipartMIMEMultipart([_subtype[, boundary[, _subparts[, _params]]]]:MIMEBase的一个子类,多个MIME对象的集合,_subtype默认值为mixed。boundary是MIMEMultipart的边界,默认边界是可数的。
class emailmimeapplicationMIMEApplication(_data[, _subtype[, _encoder[, _params]]]):MIMEMultipart的一个子类。
class emailmimeaudio MIMEAudio(_audiodata[, _subtype[, _encoder[, _params]]]): MIME音频对象
class emailmimeimageMIMEImage(_imagedata[, _subtype[, _encoder[, _params]]]):MIME二进制文件对象。
class emailmimemessageMIMEMessage(_msg[, _subtype]):具体的一个message实例,使用方法如下:
msg=mailMessageMessage() #一个实例
msg['to']='XXX@XXXcom' #发送到哪里
msg['from']='YYY@YYYYcom' #自己的邮件地址
msg['date']='2012-3-16' #时间日期
msg['subject']='hello world' #邮件主题
class emailmimetextMIMEText(_text[, _subtype[, _charset]]):MIME文本对象,其中_text是邮件内容,_subtype邮件类型,可以是text/plain(普通文本邮件),html/plain(html邮件), _charset编码,可以是gb2312等等。
二、几种邮件的具体实现代码
1、普通文本邮件
普通文本邮件发送的实现,关键是要将MIMEText中_subtype设置为plain。首先导入smtplib和mimetext。创建smtplibsmtp实例,connect邮件smtp服务器,login后发送,具体代码如下:(python26下实现)
# -- coding: UTF-8 --
import smtplib
from emailmimetext import MIMEText
mailto_list=[YYY@YYYcom]
mail_host="smtpXXXcom" #设置服务器
mail_user="XXXX" #用户名
mail_pass="XXXXXX" #口令
mail_postfix="XXXcom" #发件箱的后缀
def send_mail(to_list,sub,content):
me="hello"+"<"+mail_user+"@"+mail_postfix+">"
msg = MIMEText(content,_subtype='plain',_charset='gb2312')
msg['Subject'] = sub
msg['From'] = me
msg['To'] = ";"join(to_list)
try:
server = smtplibSMTP()
serverconnect(mail_host)
serverlogin(mail_user,mail_pass)
serversendmail(me, to_list, msgas_string())
serverclose()
return True
except Exception, e:
print str(e)
return False
if __name__ == '__main__':
if send_mail(mailto_list,"hello","hello world!"):
print "发送成功"
else:
print "发送失败"
2、html邮件的发送
与text邮件不同之处就是将将MIMEText中_subtype设置为html。具体代码如下:(python26下实现)
# -- coding: utf-8 --
import smtplib
from emailmimetext import MIMEText
mailto_list=["YYY@YYYcom"]
mail_host="smtpXXXcom" #设置服务器
mail_user="XXX" #用户名
mail_pass="XXXX" #口令
mail_postfix="XXXcom" #发件箱的后缀
def send_mail(to_list,sub,content): #to_list:收件人;sub:主题;content:邮件内容
me="hello"+"<"+mail_user+"@"+mail_postfix+">" #这里的hello可以任意设置,收到信后,将按照设置显示
msg = MIMEText(content,_subtype='html',_charset='gb2312') #创建一个实例,这里设置为html格式邮件
msg['Subject'] = sub #设置主题
msg['From'] = me
msg['To'] = ";"join(to_list)
try:
s = smtplibSMTP()
sconnect(mail_host) #连接smtp服务器
slogin(mail_user,mail_pass) #登陆服务器
ssendmail(me, to_list, msgas_string()) #发送邮件
sclose()
return True
except Exception, e:
print str(e)
return False
if __name__ == '__main__':
if send_mail(mailto_list,"hello","<a href=''>小五义</a>"):
print "发送成功"
else:
print "发送失败"
3、发送带附件的邮件
发送带附件的邮件,首先要创建MIMEMultipart()实例,然后构造附件,如果有多个附件,可依次构造,最后利用smtplibsmtp发送。
# -- coding: cp936 --
from emailmimetext import MIMEText
from emailmimemultipart import MIMEMultipart
import smtplib
#创建一个带附件的实例
msg = MIMEMultipart()
#构造附件1
att1 = MIMEText(open('d:\\123rar', 'rb')read(), 'base64', 'gb2312')
att1["Content-Type"] = 'application/octet-stream'
att1["Content-Disposition"] = 'attachment; filename="123doc"'#这里的filename可以任意写,写什么名字,邮件中显示什么名字
msgattach(att1)
#构造附件2
att2 = MIMEText(open('d:\\123txt', 'rb')read(), 'base64', 'gb2312')
att2["Content-Type"] = 'application/octet-stream'
att2["Content-Disposition"] = 'attachment; filename="123txt"'
msgattach(att2)
#加邮件头
msg['to'] = 'YYY@YYYcom'
msg['from'] = 'XXX@XXXcom'
msg['subject'] = 'hello world'
#发送邮件
try:
server = smtplibSMTP()
serverconnect('smtpXXXcom')
serverlogin('XXX','XXXXX')#XXX为用户名,XXXXX为密码
serversendmail(msg['from'], msg['to'],msgas_string())
serverquit()
print '发送成功'
except Exception, e:
print str(e)
4、利用MIMEimage发送
# -- coding: cp936 --
import smtplib
import mimetypes
from emailmimetext import MIMEText
from emailmimemultipart import MIMEMultipart
from emailmimeimage import MIMEImage
def AutoSendMail():
msg = MIMEMultipart()
msg['From'] = "XXX@XXXcom"
msg['To'] = "YYY@YYYcom"
msg['Subject'] = "hello world"
txt = MIMEText("这是中文的邮件内容哦",'plain','gb2312')
msgattach(txt)
file1 = "C:\\hellojpg"
image = MIMEImage(open(file1,'rb')read())
imageadd_header('Content-ID','<image1>')
msgattach(image)
server = smtplibSMTP()
serverconnect('smtpXXXcom')
serverlogin('XXX','XXXXXX')
serversendmail(msg['From'],msg['To'],msgas_string())
serverquit()
if __name__ == "__main__":
AutoSendMail()
利用MIMEimage发送,原本是想能够在正文中显示,可是代码运行后发现,依然是以附件形式发送的,希望有高手能够指点一下,如何可以发送在正文中显示的的邮件,就是是附件中存在,但同时能显示在正文中,具体形式如下图。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/13486356.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-08-16
下一篇 2023-08-16

发表评论

登录后才能评论

评论列表(0条)

保存