上一篇:
3) 发送邮件
图五
发送邮件功能的实现主要采用了Jmail.Message对象完成,关于所要用到的对象相关知识在前面已经叙述过了,大家可以将上面的功能介绍与源码对照起来阅读,这样有助于理解整个邮件发送过程,当然如果将WM元素换为HTMLF元素,这样一个简单的WEB邮件发送功能也就完成了,send.asp为邮件发送页面 sendok.asp为邮件发送处理页面
Send.asp
〈% LANGUAGE="VBSCRIPT" CODEPAGE="65001" %〉
〈%Response.ContentType = "text/vnd.wap.wml; charset=UTF-8"%〉
〈?xml version="1.0" encoding="utf-8"?〉
〈!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" ""〉
〈wml〉
〈card id="main" title="发件箱"〉
〈p〉
〈%
user=request("user")
pwd=request("pwd")
%〉
收件人:
〈input type="text" title="收件人" name="tomail" size="12" maxlength="50"/〉〈br/〉
标题:
〈input type="text" title="标题" name="subject" size="12" maxlength="50"/〉
〈br/〉内容:
〈input type="text" title="内容" name="body" size="12" maxlength="250"/〉〈br/〉
〈do type="accept" label="发送" optional="false"〉
〈go href="sendok.asp?user=〈%=user%〉&pwd=〈%=pwd%〉" method="post" accept-charset="utf-8"〉
〈postfield name="from" value="$(from)"/〉
〈postfield name="tomail" value="$(tomail)"/〉
〈postfield name="subject" value="$(subject)"/〉
〈postfield name="body" value="$(body)"/〉〈/go〉
〈/do〉
〈/p〉
〈p〉
〈a href="main.asp?user=〈%=user%〉&pwd=〈%=pwd%〉"〉返回邮箱〈/a〉〈/p〉
〈/card〉
〈/wml〉
Sendok.asp
〈% LANGUAGE="VBSCRIPT" CODEPAGE="65001" %〉
〈%Response.ContentType = "text/vnd.wap.wml; charset=UTF-8"%〉
〈?xml version="1.0" encoding="utf-8"?〉
〈!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" ""〉
〈wml〉
〈card id="main" title="发送邮件"〉
〈p〉
〈%
user=request("user")
pwd=request("pwd")
tomail=request("tomail")
'from=request.form("from")
subject=request.form("subject")
body=request.form("body")
servermail=user+"sohu.com"
dim JMail
set JMail=server.CreateObject("Jmail.message")
JMail.Silent=true
JMail.Charset = "gb2312"
JMail.from =""&ServerMail&"" '为发件人
JMail.AddRecipient tomail
JMail.Subject =""&subject&""
jmail.Body=""&body&"----------你当前使用的众赢掌中邮系统,详情请访问:http://www.palmmail.cn邮通天下 一触即发!----------"
JMail.MailServerUserName =user
JMail.MailServerPassWord = pwd
JMail.MailDomain = ""
JMail.Priority=2
sendok=JMail.send("smtp.sohu.com")
Set JMail=nothing
if sendok then
response.write "发送成功!〈a href='main.asp?user="&user&"&pwd="&pwd&"'〉返回邮箱〈/a〉"
else
response.write "发送失败!〈a href='send.asp?user="&user&"&pwd="&pwd&"'〉返回邮箱〈/a〉"
end if
%〉
〈/p〉
〈/card〉
〈/wml〉
4) 接收邮件
图六
接收邮件主要由两部分组成,第一部分为邮件列表,根据所获得的邮件总数(pop3.count)进行分页显示。第二部分为每封信的具体内容,其中包括对附件进行检测功能,由于手机浏览时并不能打开附件,因此本系统只对附件作了检测并提醒用户邮件是否包含邮件功能。
源码如下:
邮件列表:email_list.asp
〈% LANGUAGE="VBSCRIPT" CODEPAGE="65001" %〉
〈%Response.ContentType = "text/vnd.wap.wml; charset=UTF-8"%〉
〈?xml version="1.0" encoding="utf-8"?〉
〈!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" ""〉
〈wml〉
〈card id="main" title="收件箱"〉
〈p〉
〈%
user=request("user")
pwd=request("pwd")
dim perpage_num,curpage,totalpage
perpage_num=3 '设每页显示条数
if request("page")="" then
curpage=1 '当前页
else
curpage=int(request("page"))
end if
Set pop3 = Server.CreateObject( "JMail.POP3" )
pop3.connect user,pwd,""
' POP3的连接用户名,密码,POP3地址
if pop3.count mod perpage_num〈〉0 then
totalpage=int(pop3.count / perpage_num)+1
else
totalpage=int(pop3.count / perpage_num)
end if
Response.Write( "你现在有" & pop3.count & " 封邮件。分"&totalpage&"页,当前"&curpage&"页〈br/〉---------------------〈br/〉" )
if pop3.count 〉 0 then '如果没有邮件则显示无邮件
if pop3.count〉=perpage_num*curpage then
for i=(curpage-1)*perpage_num to curpage*perpage_num-1%〉
〈a href="email_info.asp?id=〈%=i+1%〉&user=〈%=user%〉&pwd=〈%=pwd%〉&page=〈%=curpage%〉"〉〈%=pop3.messages.item(i+1).Subject%〉--〈%=pop3.messages.item(i+1).date%〉〈/a〉〈br/〉
〈%next
%〉
〈%if curpage〉1 then%〉
〈a href="email_list.asp?page=〈%=curpage-1%〉&user=〈%=user%〉&pwd=〈%=pwd%〉"〉上一页〈/a〉
〈%end if%〉
〈%if int(curpage)〈int(totalpage) then%〉
〈a href="email_list.asp?page=〈%=curpage+1%〉&user=〈%=user%〉&pwd=〈%=pwd%〉"〉下一页〈/a〉
〈%end if%〉
〈%
else
for i=(curpage-1)*perpage_num to pop3.count-1%〉
〈a href="email_info.asp?id=〈%=i+1%〉&user=〈%=user%〉&pwd=〈%=pwd%〉&page=〈%=curpage%〉"〉〈%=pop3.messages.item(i+1).Subject%〉--〈%=pop3.messages.item(i+1).date%〉〈/a〉〈br/〉
〈%next%〉
〈%if curpage〉1 then%〉
〈a href="email_list.asp?page=〈%=curpage-1%〉&user=〈%=user%〉&pwd=〈%=pwd%〉"〉上一页〈/a〉
〈%end if%〉
〈%if int(curpage)〈int(totalpage) then%〉
〈a href="email_list.asp?page=〈%=curpage+1%〉&user=〈%=user%〉&pwd=〈%=pwd%〉"〉下一页〈/a〉
〈%end if%〉
〈%
end if
else
response.write("暂无邮件!")
end if
pop3.Disconnect
%〉
〈/p〉
〈p〉
〈a href="main.asp?user=〈%=user%〉&pwd=〈%=pwd%〉"〉返回邮箱〈/a〉
〈/p〉
〈/card〉
〈/wml〉
邮件详细信息:email_info.asp
〈% LANGUAGE="VBSCRIPT" CODEPAGE="65001" %〉
〈%Response.ContentType = "text/vnd.wap.wml; charset=UTF-8"%〉
〈?xml version="1.0" encoding="utf-8"?〉
〈!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" ""〉
〈wml〉
〈card id="main" title="查看邮件"〉
〈p〉
〈%
user=request("user")
pwd=request("pwd")
id=request("id")
page=request("page")
Set pop3 = Server.CreateObject( "JMail.POP3" )
' POP3的连接用户名,密码,POP3地址
pop3.connect user,pwd,""
Set msg = pop3.Messages.item(id)
ReTo = ""
ReCC = ""
Set Recipients = msg.Recipients
separator = ", "
For i = 0 To Recipients.Count - 1
If i = Recipients.Count - 1 Then
separator = ""
End If
Set re = Recipients.item(i)
If re.ReType = 0 Then
ReTo = ReTo & re.Name & re.EMail & separator
else
ReCC = ReTo & re.Name & re.EMail & separator
End If
Next
body=msg.body
body=replace(body,"〈","")
body=replace(body,"〉","")
Set Attachments = msg.Attachments
%〉
〈a href="email_title.asp?user=〈%=user%〉&pwd=〈%=pwd%〉&page=〈%=page%〉"〉返回上一页〈/a〉 〈a href="reply.asp?user=〈%=user%〉&pwd=〈%=pwd%〉&mailto=〈%=msg.From%〉"〉回复〈/a〉 〈a href="email_del.asp?user=〈%=user%〉&pwd=〈%=pwd%〉&id=〈%=id%〉"〉删除〈/a〉
〈/p〉
〈p〉
发件人:〈%= msg.FromName %〉--〈%=msg.date%〉〈br/〉
标题:〈%= msg.Subject %〉〈br/〉
内容:〈%= body %〉〈br/〉
〈%
if Attachments.Count〉0 then
response.Write("信件中包含附件,请通过网络查收!")
end if
pop3.Disconnect
%〉
〈/p〉
〈p〉
〈a href="email_list.asp?user=〈%=user%〉&pwd=〈%=pwd%〉&page=〈%=page%〉"〉返回上一页〈/a〉 〈a href="reply.asp?user=〈%=user%〉&pwd=〈%=pwd%〉&mailto=〈%=msg.From%〉"〉回复〈/a〉 〈a href="email_del.asp?user=〈%=user%〉&pwd=〈%=pwd%〉&id=〈%=id%〉"〉删除〈/a〉
〈/p〉
〈/card〉
〈/wml〉
5) 删除邮件
本功能与邮件回复功能一样,为邮件查看页面的一个子功能,通过MessageID传递实现删除邮件。
源码:email_del.asp
〈% LANGUAGE="VBSCRIPT" CODEPAGE="65001" %〉
〈%Response.ContentType = "text/vnd.wap.wml; charset=UTF-8"%〉
〈?xml version="1.0" encoding="utf-8"?〉
〈!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" ""〉
〈wml〉
〈card id="main" title="删除成功"〉
〈p〉
〈%
user=request("user")
pwd=request("pwd")
id=request("id")
Set pop3 = Server.CreateObject( "JMail.POP3" )
' POP3的连接用户名,密码,POP3地址
pop3.connect user,pwd,""
pop3.deletesinglemessage id
pop3.Disconnect
Set JMail=nothing
response.write delok&"删除成功!〈a href='email_list.asp?user="&user&"&pwd="&pwd&"'〉返回收件箱〈/a〉"
%〉
〈/p〉
〈/card〉
〈/wml〉
6) 回复邮件
回复邮件基本与发送邮件相同,只是将发送人由原来的手工输入改成通过URL参数传递,当然也可以将邮件主体内容传递到回复邮件的主体中,但由于当今手机上网基本采用流量收费的方式,为了减少流量就省去了这些功能,具体代码如下:
Reply.asp
〈% LANGUAGE="VBSCRIPT" CODEPAGE="65001" %〉
〈%Response.ContentType = "text/vnd.wap.wml; charset=UTF-8"%〉
〈?xml version="1.0" encoding="utf-8"?〉
〈!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" ""〉
〈wml〉
〈card id="main" title="发件箱"〉
〈p〉
〈%
user=request("user")
pwd=request("pwd")
tomail=request("mailto")
%〉
收件人:
〈%=tomail%〉〈br/〉
标题:
〈input type="text" title="标题" name="subject" size="8" maxlength="50"/〉
〈br/〉内容:
〈input type="text" title="内容" name="body" size="8" maxlength="250"/〉〈br/〉
〈do type="accept" label="发送" optional="false"〉
〈go href="sendok.asp?user=〈%=user%〉&pwd=〈%=pwd%〉&tomail=〈%=tomail%〉" method="post" accept-charset="utf-8"〉
〈postfield name="subject" value="$(subject)"/〉
〈postfield name="body" value="$(body)"/〉〈/go〉
〈/do〉
〈/p〉
〈p〉
〈a href="email_list.asp?user=〈%=user%〉&pwd=〈%=pwd%〉"〉返回收件箱〈/a〉〈br/〉
〈a href="main.asp?user=〈%=user%〉&pwd=〈%=pwd%〉"〉返回邮箱〈/a〉〈/p〉
〈/card〉
〈/wml〉
虽然这套系统可以实现邮件的发送、接收、回复、删除等功能,但是很多方面都是非常欠缺的,比如接收邮件时不能够显示出未读邮件,邮件不能够按照发送邮件的先后顺序排序等等,希望大家有兴趣帮忙多多完善,有什么好的想法好的建议多与我交流,欢迎来信sn1985boysohu.com。