form to mail
所谓form to mail的功能,就是在页面上建立一个表单(form),该表单内记录着用户的信息,当用户提交了此表单,程序自动将表单内容发送的管理员所设定的信箱里。听起来这非常简单,根本用cgi就可以写这样的功能。 其实当然没有这么简单,实际上许多公司网页还要求此表单在提交时存如另一个数据库,这样就需要写cgi程序了。
为了便于解说form to mail的功能,我们这里不考虑复杂情况,只考虑最简单的情况。就是唯一的form to mail功能,其他的功能只要在程序内加入相应的程序块就可以了。
在unix中,我们最多使用的就是email网关,因为是cgi开发环境中少数几个标准unix工具之一。在cgi程序中发送e-mail的命令是mail和sendmail.我比较喜欢sendmail,因为它功能更强,sendmail从stdin接受数据,遇到eof或只包含。的一行信息就将信息发送出去。
perl中使用sendmail的一个方式是将mail内容写入一个临时文件,然后使用cat,同时把输出管道与sendmail命令相联系起来。
如:
open(email,“>tempfile $ $,txt”);
print(email,“stuff to be emailed …… la la la ……\n”);
close(email);
system(“cat tempfile $ $,txt /usr/sbin/sendmail $tokens(‘email’)”);
system(“rm tempfile $ $,txt”);
名字tempfile ,txt中的$ $是perl中的一个特殊变量,即进程号(pid)。之所以使用是为了避免两个用户同时启动这个程序会覆盖tempfile文件,使用这种方法每个tempfile都是唯一的。(由pid表示)。这种好的思想可以用在许多程序中。
sendmail命令从关联数组元素$token(‘email’)中找到e-mail目标地址,你可以假设这个变量的值在用户提交的表单由用户输入。如果没有安全措施,这样做是很危险的,设想有恶意的用户在web表单中给你如下地址:noone@nowhere.net;cd/;rm-r *分号是表示unix命令结束的符号并将命令提交unix命令解释器。精通web的人谁也不会在根目录运行httpd,这个例子将删除整个文件系统。所以在设计整个系统的时候,必须考虑到这种用户直接到达shell的情况。
windows 下的form to mail
很不幸,windows没有类似于unix的mail网关,不管是winnt和windows都无法做到类似的功能。当然也有些非常热心的程序员写过dos接口的mail程序,但是相当不幸,此类程序直到现在也没有很成功的例子。它们的问题是过于占用系统资源,并非常容易被黑客攻击。所以这里我就不提供程序了。
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器