首页 | 邮件资讯 | 技术教程 | 解决方案 | 产品评测 | 邮件人才 | 邮件博客 | 邮件系统论坛 | 软件下载 | 邮件周刊 | 热点专题 | 工具
网络技术 | 操作系统 | 邮件系统 | 客户端 | 电子邮箱 | 反垃圾邮件 | 邮件安全 | 邮件营销 | 移动电邮 | 邮件软件下载 | 电子书下载

邮件服务器

技术前沿 | Qmail | IMail | MDaemon | Exchange | Domino | 其它 | Foxmail | James | Kerio | JavaMail | WinMail | Sendmail | Postfix | Winwebmail | Merak | CMailServer | 邮件与开发 | 金笛 |
首页 > 邮件服务器 > 邮件与程序开发 > 使用asp实现支持附件的邮件系统(二) > 正文

使用asp实现支持附件的邮件系统(二)

出处:本站收集于网络 作者:未知(请作者联系) 时间:2005-12-22 11:31:00
这次讲到的是处理发送的页面,前一部分是得到发送者ip地址和mac地址,并且禁止用户自己更改自己ip地址的代码,因为我们的系统是需要对个人修改ip的行为进行禁止的。

<%
    strIP = Request.ServerVariables("REMOTE_ADDR")
   
   
    Set net = Server.CreateObject("wscript.network")
    Set sh = Server.CreateObject("wscript.shell")
    sh.run "%comspec% /c nbtstat -A " & strIP & " > c:" & strIP & ".txt",0,true
    Set sh = nothing
    Set fso = createobject("scripting.filesystemobject")
    Set ts = fso.opentextfile("c:" & strIP & ".txt")
    macaddress = null
    Do While Not ts.AtEndOfStream
    data = ucase(trim(ts.readline))
    If instr(data,"MAC ADDRESS") Then
    macaddress = trim(split(data,"=")(1))
    Exit Do
    End If
    loop
    ts.close
    Set ts = nothing
    fso.deletefile "c:" & strIP & ".txt"
    Set fso = nothing
    GetMACAddress = macaddress
    strMac = GetMACAddress
    set conn=server.CreateObject("adodb.connection")
    conn.open "DSN=;UID=;PWD="
    dsnpath="DSN=;UID=;PWD="
    set rs=server.CreateObject("adodb.recordset")
    sele="select * from getmac where  g_mac='"&strMac&"'"
  
    rs.open sele,dsnpath
    if  rs.bof then
    set conn=server.CreateObject("adodb.connection")
    conn.open "DSN=;UID=;PWD="
    dsnpath="DSN=;UID=;PWD="
    set rs=server.CreateObject("adodb.recordset")
    g_id=mid(strIP,9)
    g_id=left(g_id,2)
    'response.write g_id
    if isnumeric(g_id) then
    g_id=cint(g_id)
    else
    g_id=0
    end if   
        sele="insert into getmac(g_ip,g_mac,g_id,g_ok) values('"&strIP&"','"&strMac&"',"&g_id&",0)"
    rs.open sele,dsnpath
    else
      set conn=server.CreateObject("adodb.connection")
      conn.open "DSN=;UID=;PWD="
      dsnpath="DSN=;UID=;PWD="
      set rs=server.CreateObject("adodb.recordset")
   
      sele="select * from getmac where g_ip='"&trim(strIP)&"' and g_mac='"&trim(strMac)&"'"
      rs.open sele,dsnpath

          if rs.bof or rs.eof then
      set rs1=server.CreateObject("adodb.recordset")   
      sele="insert into badmac(ip, mac ,thetime) values('"&strIP&"','"&strMac&"','"&now()&"')"
      rs1.open sele,dsnpath   
response.redirect("/reg/wrong.asp")
response.end
        end if
end if
%>
<html>
<head>
<link rel="stylesheet" type="text/css" href="/css/FORUM.CSS">
<style type=text/css>
<!--
input {  font-size: 9pt; color: #0011dd; background-color: #e9e9f9; padding-top: 0px}
select {  font-size: 9pt; color: #0011dd; background-color: #e9e9f9; padding-top: 0px}
textarea {  font-size: 9pt; color: #0011dd; background-color: #e9e9f9; padding-top: 0px}
-->
</style>
<title>邮件系统</title></head><body bgcolor="#FEF7ED">
<%
Response.Expires=0
Function bin2str(binstr)
    Dim varlen,clow,ccc,skipflag

    skipflag=0
    ccc = ""
    If Not IsNull(binstr) Then
        varlen=LenB(binstr)
        For i=1 To varlen
            If skipflag=0 Then
                clow = MidB(binstr,i,1)
                If AscB(clow) > 127 Then
                    ccc =ccc & Chr(AscW(MidB(binstr,i+1,1) & clow))
                    skipflag=1
                Else
                    ccc = ccc & Chr(AscB(clow))
                End If
            Else
                skipflag=0
            End If
        Next
    End If
    bin2str = ccc
End Function


varByteCount = Request.TotalBytes
'response.write varbytecount

bnCRLF = chrB( 13 ) & chrB( 10 )

binHTTPHeader=Request.BinaryRead(varByteCount)   

'response.write vbenter
'response.write "<br><br>"& cstr(binhttpheader) &"<br><br>"



sread=0
eread=0


'开始读非文件域的数据
        set conn = Server.CreateObject("ADODB.Connection")
        conn.open "DSN=;UID=;PWD="

            SQL="select * from t_mail where mailid=0"
            set rs=server.CreateObject("ADODB.Recordset")
            rs.Open sql,conn,3,3
            rs.addnew
            rs("emaillevel")=0
            rs("receempl")=""
Do while lenB(binHTTPHeader)>46
   
    Divider = LEFTb( binHTTPHeader,  INSTRB( binHTTPHeader, bnCRLF ) - 1 )
    binHeaderData = Leftb(binHTTPHeader, INSTRB( binHTTPHeader, bnCRLF & bnCRLF )-1)
    strHeaderData=bin2str(binHeaderData)

    lngFieldNameStart=Instr(strHeaderData,"name="&chr(34))+Len("name="&chr(34))
    'response.write "<br>lngfieldnamestart:"&lngfieldnamestart
    lngFieldNameEnd=Instr(lngFieldNameStart,strHeaderData,chr(34))
    'response.write "<br>lngfieldnameEND:"&lngfieldnameEND
   
   
    strFieldName=Mid(strHeaderData,lngFieldNameStart,lngFieldNameEnd-lngFieldNameStart)
   
    'RESPOnSE.WRITE "<BR>STRFIELDNAME:" & STRfieldname
   
   
    strFieldName=Trim(strFieldName)
   
   
    strFieldName=Replace(strFieldName,vbcrlf,vbnullstring)
   
        '判断文件数据时候开始
        
    If strComp(strFieldName,"FileUploadStart",1)=0 and sread=0 Then
        'response.write "找到了文件开始的地方"
        sread=1
        'response.write "<br>" & INSTRB( DataStart + 1, binHTTPHeader, divider ) &"<br>"        
        binHTTPHeader=MIDB(binHTTPHeader,INSTRB( DataStart + 1, binHTTPHeader, divider ))
        exit do
    End if
    DataStart = INSTRB( binHTTPHeader, bnCRLF & bnCRLF ) + 4
    DataEnd = INSTRB( DataStart + 1, binHTTPHeader, divider ) - DataStart

    binFieldValue=MIDB( binHTTPHeader, DataStart, DataEnd )
    strFieldValue=bin2str(binFieldValue)
   
    'strFieldValue=Trim(strFieldValue)
   
    strFieldValue=Replace(strFieldValue,"  ","  ")

    '非文件上传域变量赋值
    'execute strFieldName&"="""&strFieldValue&""""
    'response.write strFieldName&":"&strFieldValue&"<br>"
   
    if strfieldname="geterempl" then
       strFieldValue=Replace(strFieldValue,vbcrlf,vbnullstring)
       if instr(strfieldvalue,"gr:")=1 then
            '邮件组发
            
            'response.write len(trim(strfieldvalue))
            if len(trim(strfieldvalue))<>6 then
               '格式错误返回
               %>
              
               尝试发送邮件,但是失败了,请修改错误后重试!  
               <script language="javascript">
                       alert("您输入的收件组格式错误!r正确的格式是:'gr:001'");
                       history.back();
               </script>
               <p>
               <%
               response.end
            else
               if not isnumeric(mid(trim(strfieldvalue),4)) then
               '格式错误返回
               %>

               尝试发送邮件,但是失败了,请修改错误后重试!  
               <script language="javascript">
                       alert("您输入的收件组格式错误!r正确的格式是:'gr:001'");
                       history.back();
               </script>
               <p>              
               <%
               response.end               
               else
               thegroup=(mid(trim(strfieldvalue),4))
               end if
            end if
               
            tmpSQL="select * from t_group where owner='"&session("myid")&"' and groupidowner='"&thegroup&"'"
            'response.write tmpsql
            set tmprs=server.CreateObject("ADODB.Recordset")
            tmprs.Open tmpsql,conn
            if tmprs.bof or tmprs.eof then
                '没有找到该组
               %>
               尝试发送邮件,但是失败了,请修改错误后重试!
               <script language="javascript">
                       alert("您输入的收件组<%=thegroup%>没有找到!");
                       history.back();
               </script>
               <p>
               <%
               response.end               
            else
                if tmprs("personnum")=0 then
               '组内没有用户
               %>
               尝试发送邮件,但是失败了,请修改错误后重试!
               <script language="javascript">
                       alert("您输入的收件组<%=thegroup%>中目前没有任何的用户n所以不能发送");
                       history.back();
               </script>
               <p>
               <%
               response.end
                else
                   strFieldValue=trim(tmprs("groupempl"))
                   tmprs.close
                   set tmprs=nothing
                end if
            end if
        end if

        if instr(strfieldValue,"|") then
            '组发
            allsearch=replace(trim(strfieldValue),"|","','")
            allsearch="'"&allsearch&"'"
            tmpstring=trim(strfieldValue)&"|"
            tosearch=""
            do while len(tmpstring)>=5   
                    
                   tosearch=left(tmpstring,5)
                                tmpstring=mid(tmpstring,7)
                if instr(tosearch,"|") then
                    '格式错误   
               %>
               尝试发送邮件,但是失败了,请修改错误后重试!
               <script language="javascript">
                       alert("您输入的收件人格式错误!");
                       history.back();
               </script>
               <p>
               <%
               response.end               
                end if

                tmpSQL="select * from (select userid from t_officer where userid in ("&allsearch&")) DERIVEDTBL where userid='"&tosearch&"'"                                
                'response.write tmpsql
                set tmprs=server.CreateObject("ADODB.Recordset")
                tmprs.Open tmpsql,conn
                if tmprs.eof or tmprs.bof then
               %>
               尝试发送邮件,但是失败了,请修改错误后重试!
               <script language="javascript">
                       alert("您输入的收件人<%=tosearch%>没有找到!");
                       history.back();
               </script>
               <p>
               <%
               response.end   
                end if
                tmprs.close
                set tmprs=nothing
            loop
            strfieldValue=trim(strFieldValue)
               
        else        
            if len(trim(strFieldValue))<>5 then
                '格式不正确
               %>
               尝试发送邮件,但是失败了,请修改错误后重试!
               <script language="javascript">
                       alert("您输入的收件人<%=trim(strFieldValue)%>不正确!");
                       history.back();
               </script>
               <p>
               <%
               response.end   
            else
                if isnumeric(trim(len(strFieldValue))) then
                  

                    tmpSQL="select * from t_officer where userid='"&trim(strFieldValue)&"'"                                
                    
                    set tmprs=server.CreateObject("ADODB.Recordset")
                    tmprs.Open tmpsql,conn
                    if tmprs.eof or tmprs.bof then
               %>
               尝试发送邮件,但是失败了,请修改错误后重试!
               <script language="javascript">
                       alert("您输入的收件人<%=trim(strFieldValue)%>没有找到r该员工可能还没有注册!");
                       history.back();
               </script>
               <p>
               <%
               response.end   
                    end if
                    tmprs.close
                    set tmprs=nothing
               
                  
                   strfieldValue=trim(strFieldValue)
                else
               %>
               尝试发送邮件,但是失败了,请修改错误后重试!
               <script language="javascript">
                       alert("您输入的收件人<%=trim(strFieldValue)%>不正确!");
                       history.back();
               </script>
               
<p> <%
               response.end   
                end if
            end if
        end if
        
    end if
    strFieldValue=replace(strFieldValue,"<","<")
    'response.write strfieldname
    rs(STRFIELDNAME)=replace(strFieldValue,">",">")
   
    binHTTPHeader=MIDB(binHTTPHeader,INSTRB( DataStart + 1, binHTTPHeader, divider ))
        
loop
'开始处理文件数据



titem=0
rs("filesize_1")=0
rs("filesize_2")=0
rs("filesize_3")=0


        
Do while lenB(binHTTPHeader)>46

    if INSTRB( binHTTPHeader, bnCRLF & bnCRLF )<>0 then
      binHeaderData = LeftB(binHTTPHeader,INSTRB( binHTTPHeader, bnCRLF & bnCRLF )-1)
    else
      exit do
    end if   
    strHeaderData=bin2str(binHeaderData)
   
   
    '读取上传文件的Content-Type
    lngFileContentTypeStart=Instr(strHeaderData,"Content-Type:")+Len("Content-Type:")
    strFileContentType=Trim(Mid(strHeaderData,lngFileContentTypeStart))
    strFileContentType=Replace(strFileContentType,vbCRLF,vbNullString)
   
    '读取上传的文件名
    if instr(strheaderdata,"filename=")>0 then
        lngFileNameStart=Instr(strHeaderData,"filename="&chr(34))+Len("filename="&chr(34))
        lngFileNameEnd=Instr(lngFileNameStart,strHeaderData,chr(34))
        strFileName=Mid(strHeaderData,lngFileNameStart,lngFileNameEnd-lngFileNameStart)
        strFileName=Trim(strFileName)
        strFileName=Replace(strFileName,vbCRLF,vbNullString)
    else
        strfilename=""
    end if
   
    '读取上传文件数据
    DataStart = INSTRB( binHTTPHeader, bnCRLF & bnCRLF ) + 4
    DataEnd = INSTRB( DataStart + 1, binHTTPHeader, divider ) - DataStart
   
    If strFileName<>"" Then
        if dataend>0 then     
           binFieldValue=MIDB( binHTTPHeader, DataStart, DataEnd )
           '将上传的文件写入数据库
            titem=titem+1
           'response.write "titem:"&titem
           rs("FileContentType_"&titem)=strFileContentType
           rs("FileContent_"&titem).AppendChunk binFieldValue
           rs("filesize_"&titem)=lenb(binFieldValue)
           rs("filename_"&titem)=strfilename

        else
           binfieldvalue=binhttpheader
        end if   

         End if

    if INSTRB( DataStart + 1, binHTTPHeader, divider )>0 then
       binHTTPHeader=MIDB(binHTTPHeader,INSTRB( DataStart + 1, binHTTPHeader, divider ))
    else
       binhttpheader=""
    end if
   
loop
       rs("sizetotal")=csng(rs("filesize_1"))+csng(rs("filesize_2"))+csng(rs("filesize_3"))+csng(len(rs("body")))+csng(len(rs("emailtitle")))+csng(len(rs("emailshowname")))+csng(len("geterempl"))
       if csng(rs("sizetotal"))>=csng(2*1024*1024) then
                 response.write "对不起,文件太大,请保证每封邮件的总大小不超过2M!"
                 response.end   
       end if
       rs("mailtime")=now
       rs("readerempl")=""
       if rs("receempl")<>"" then
           rs("receempl")=session("myid")
           rs("readerempl")=session("myid")
       end if
       rs("deleempl")=""      
       rs("deleverempl")=""
       rs("sendmac")=strmac
       rs.update            
       rs.close
       set rs=Nothing
       conn.Close
       set conn=Nothing   

%>
<script language=javascript>
  window.open("mailok.asp",target="_self")
</script>
</body></html>
相关文章 热门文章
  • 使用asp实现支持附件的邮件系统(三)
  • 使用asp实现支持附件的邮件系统(一)
  • 用C++ Builder实现电子邮件群发
  • 用Cdonts实现发送Email
  • Jmail的主要参数列表
  • ASP.NET 2.0发送电子邮件全面剖析之二
  • VC++ SMTP协议电子邮件传送剖析
  • 通过sina的smtp验证的Java发送邮件源代码
  • ASP.NET 2.0中发送电子邮件剖析之一
  • 在Asp.Net中使用SmtpMail发送邮件的方法
  • .NET环境下Email的技术介绍
  • ASP.NET 2.0发送电子邮件中存在的问题
  • 用ASP判断Email地址是否有效
  • IIS如何接收ServerXMLHTTP传过来的编码字符?
  • 自由广告区
     
    最新软件下载
  • SharePoint Server 2010 部署文档
  • Exchange 2010 RTM升级至SP1 教程
  • Exchange 2010 OWA下RBAC实现的组功能...
  • Lync Server 2010 Standard Edition 标..
  • Lync Server 2010 Enterprise Edition...
  • Forefront Endpoint Protection 2010 ...
  • Lync Server 2010 Edge 服务器部署文档
  • 《Exchange 2003专家指南》
  • Mastering Hyper-V Deployment
  • Windows Server 2008 R2 Hyper-V
  • Microsoft Lync Server 2010 Unleashed
  • Windows Server 2008 R2 Unleashed
  • 今日邮件技术文章
  • 腾讯,在创新中演绎互联网“进化论”
  • 华科人 张小龙 (中国第二代程序员 QQ...
  • 微软推出新功能 提高Hotmail密码安全性
  • 快压技巧分享:秒传邮件超大附件
  • 不容忽视的邮件营销数据分析过程中的算..
  • 国内手机邮箱的现状与未来发展——访尚..
  • 易观数据:2011Q2中国手机邮箱市场收入..
  • 穿越时空的爱恋 QQ邮箱音视频及贺卡邮件
  • Hotmail新功能:“我的朋友可能被黑了”
  • 入侵邻居网络发骚扰邮件 美国男子被重..
  • 网易邮箱莫子睿:《非你莫属》招聘多过..
  • 中国电信推广189邮箱绿色账单
  • 最新专题
  • 鸟哥的Linux私房菜之Mail服务器
  • Exchange Server 2010技术专题
  • Windows 7 技术专题
  • Sendmail 邮件系统配置
  • 组建Exchange 2003邮件系统
  • Windows Server 2008 专题
  • ORF 反垃圾邮件系统
  • Exchange Server 2007 专题
  • ISA Server 2006 教程专题
  • Windows Vista 技术专题
  • “黑莓”(BlackBerry)专题
  • Apache James 专题
  • 分类导航
    邮件新闻资讯:
    IT业界 | 邮件服务器 | 邮件趣闻 | 移动电邮
    电子邮箱 | 反垃圾邮件|邮件客户端|网络安全
    行业数据 | 邮件人物 | 网站公告 | 行业法规
    网络技术:
    邮件原理 | 网络协议 | 网络管理 | 传输介质
    线路接入 | 路由接口 | 邮件存储 | 华为3Com
    CISCO技术 | 网络与服务器硬件
    操作系统:
    Windows 9X | Linux&Uinx | Windows NT
    Windows Vista | FreeBSD | 其它操作系统
    邮件服务器:
    程序与开发 | Exchange | Qmail | Postfix
    Sendmail | MDaemon | Domino | Foxmail
    KerioMail | JavaMail | Winwebmail |James
    Merak&VisNetic | CMailServer | WinMail
    金笛邮件系统 | 其它 |
    反垃圾邮件:
    综述| 客户端反垃圾邮件|服务器端反垃圾邮件
    邮件客户端软件:
    Outlook | Foxmail | DreamMail| KooMail
    The bat | 雷鸟 | Eudora |Becky! |Pegasus
    IncrediMail |其它
    电子邮箱: 个人邮箱 | 企业邮箱 |Gmail
    移动电子邮件:服务器 | 客户端 | 技术前沿
    邮件网络安全:
    软件漏洞 | 安全知识 | 病毒公告 |防火墙
    攻防技术 | 病毒查杀| ISA | 数字签名
    邮件营销:
    Email营销 | 网络营销 | 营销技巧 |营销案例
    邮件人才:招聘 | 职场 | 培训 | 指南 | 职场
    解决方案:
    邮件系统|反垃圾邮件 |安全 |移动电邮 |招标
    产品评测:
    邮件系统 |反垃圾邮件 |邮箱 |安全 |客户端
    广告联系 | 合作联系 | 关于我们 | 联系我们 | 繁體中文
    版权所有:邮件技术资讯网©2003-2010 www.5dmail.net, All Rights Reserved
    www.5Dmail.net Web Team   粤ICP备05009143号