`
purpen
  • 浏览: 785628 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

学习CGI脚本 (脚本)(二)

阅读更多

No Response

有时对于一个CGI脚本也许一点没有输出. 有时你只是要从用户那儿收集点信息. 你就不用再调用一个新文本, 也不用输出结果或打开一个存在的文件. 在浏览器上的屏幕还是那个样子.

很幸运, 这一切很容易. 你只要输出下面这个命令即可(后面跟一个空行):

echo Status: 204 No Response


echo
这个Status头部提供状态码给服务器(并且也给浏览器). 特别的204将传递给浏览器,如果能识别它,它将什么也不做.
 

 


<note></note>

尽管无响应是一个官方HTTP规定的一部分,但也并不是适合所有的浏览器,也许会产生奇怪的结果,那你要多试验试试看啦.


处理表单的脚本

今天,大多数CGI脚本是用来处理表单输入的. 这个过程大致象上面说阐述的一样,但还是有些不同,比如CGI脚本只要被调用;数据怎样从服务器被发向浏览器.

 

记住, 大多数表单有两个部分: HTML的表单格式;处理表单数据的CGI脚本. 这个CGI脚本使用标签 属性调用的.

表单形式和表单脚本

正如上面所说,由于表单有两个部分. 如下:

这个ACTION属性包含着处理表单的脚本:


在这个表单中, 每个输入区都有一个NAME的属性, 用来称呼表单元素. 当这个表单数据被递交给你在ACTION中定义的CGI脚本, 这样这些name和输入内容被作为一个数字或字符传递给脚本. 

GET 和 POST

表单从浏览器发给服务器有两种方法.  GET 和 POST.

我们上面谈论的方法,实际是GET,它将数据打包放置在环境变量QUERY_STRING中作为URL整体的一部分传递给服务器。

POST做很多类似GET同样的事情, 不同的地方就是它是分离地传递数据给脚本. 你的脚本通过标准输入获取这些数据. (有些Web服务器是存储在临时文件中.) 这个QUERY_STRING环境变量将不再设置.

那你用那个方法呢? POST是个安全的方法, 尤其如果你的表单中有很多数据的话. 当你用GET, 这个服务器就分配变量QUERY_STRING给所有的表单数据, 但是这个变量可存储量是有限的. 换句话说,如果你有很多数据但是你又用GET,你会丢失很多数据.

 

如果你用POST, 你可以尽可能多地使用数据, 因为这些数据从来也不分配到一个变量里.

URL 编码

URL 编码是一种浏览器用来打包表单输入的格式. 浏览器从表单中获取所有的name和其中的值 ,将他们作为name/value参数编码, 移去那些不能传送的字符, 将数据排行等等,这些还取决于你用GET还是POST?作为URL的一部分或者分离地发给服务器. 不管哪种情况, 在服务器端的表单输入格式样子象这样:
theName=Ichabod+Crane&gender=male&status=missing&headless=yes
URL编码遵循下列规则:
  • 每对name/value由&符分开.
  • 每对来自表单的name/value由=符分开. 如果用户没有输入值给这个name,那么这个name还是出现,只是无值(象这样 "name=").
  • 任何特殊的字符(就是那些不是简单的七位ASCII,如汉字) 将以百分符%用十六进制编码. 当然也包括象 =, &, 和 % 这些特殊的字符.
  • 在输入区中的空格将以加号+显示.
因为表单输入是用这个URL编码传递给你的脚本的,在你用这些参数之前必须解码,因为解码是个很普遍的工作,可以有很多工具做这个工作 . 你没有必要自己写这个解码程序.

 

这里介绍一个叫uncgi的解码程序, 你可以从
http://www.hyperion.com/~koreth/uncgi.html. 得到原码,安装在你自己的cgi-bin目录下.
练习3: 告诉我你的名字.
让我们以这个例子来说明,如图5.

19twp05.gif (16423 字节)

这个输入被发给脚本, 然后发回显示一个hello的信息(见图.6).

19twp07.gif (14688 字节)

如果你在姓名输入处不输入任何东东,会怎样?见图7.

19twp06.gif (14812 字节)

修改表单的HTML
现在我们举一个真实的例子:



如果你在用uncgi从input中解码, 情况有点不同. 为了是uncgi正常工作, 你首先必须调用uncgi , 如果uncgi是个目录,加上实际的脚本名, 象这样:



这样,你不必修改表单中原始的HTML; 原始的HTML可以工作得很好.
脚本
处理表单输入的是个CGI脚本, 让我们来仔细地看看。

在脚本中第一步是解码,在这个例子中, 我们已经使用uncgi解码输入数据, 实际这个表单已经为你做好解码. 通过建立一个uncgi的目录,一旦表单递交给服务器,服务器会自动进行解码,这样,所有的name/value已经准备就绪等待你的使用.

现在,一个例子开始部分假设是下面这样:

echo Content-type: text/html


echo


echo "<html></html><head></head>"


echo ""


echo ""


echo "

"

接下来,有两种情况要处理:一件是处理用户不输入名字的情况,一个是如果输入了向他们说hello.

这个Name元素的值, 是包含在WWW_theName环境变量中. 用一个简单的测试命令(-z), 你能查看环境变量是否是空的还是包括相应的输出值:

if [ ! -z "$WWW_theName" ]; then


    echo "Hello, "


    echo $WWW_theName


else


    echo "You don't have a name?"


fi
最后增加一个连接"go back" . 用来返回:
echo "

 

Go Back

"


echo ""

问题

这里是使用CGI脚本比较普遍的问题:
  • 脚本内容只显示不执行.


    你正确配置了你的服务器运行CGI脚本? 你的脚本是放置在cgi-bin目录中吗?如果你的服务器允许带.cgi扩展名的CGI运行, 你的脚本文件名的扩展名是这样吗?

  • Error 500: Server doesn't support POST.


    解答还是如上一条一样,然后你用命令行执行你的CGI,可以正常运行吗?是否有错误?.

  • Document contains no data.


    确定你的头部行和数据部之间有一空行.

  • Error 500: Bad Script Request.


    确定你的脚本是可执行的(在UNIX, 用chmod +x 你的脚本.cgi). 在从浏览器运行之前,你应当从命令行运行你的脚本,如果客户端是win95,可以用telnet登陆你的服务器,执行命令行,当然必须了解UNIX命令.

CGI变量

表2 总结那些环境变量.
    <lh></lh>

    表2. CGI 环境变量.


 
环境变量         
意义
SERVER_NAME CGI脚本运行时的主机名和IP地址.
SERVER_SOFTWARE 你的服务器的类型如: CERN/3.0 或 NCSA/1.3.
GATEWAY_INTERFACE 运行的CGI版本. 对于UNIX服务器, 这是CGI/1.1.
SERVER_PROTOCOL 服务器运行的HTTP协议. 这里当是HTTP/1.0.
SERVER_PORT 服务器运行的TCP口,通常Web服务器是80.
REQUEST_METHOD POST 或 GET, 取决于你的表单是怎样递交的.
HTTP_ACCEPT  浏览器能直接接收的Content-types, 可以有HTTP Accept header定义.
HTTP_USER_AGENT 递交表单的浏览器的名称、版本 和其他平台性的附加信息。
HTTP_REFERER 递交表单的文本的 URL,不是所有的浏览器都发出这个信息,不要依赖它
PATH_INFO 附加的路径信息, 由浏览器通过GET方法发出.
PATH_TRANSLATED 在PATH_INFO中系统规定的路径信息.
SCRIPT_NAME 指向这个CGI脚本的路径, 是在URL中显示的(如, /cgi-bin/thescript).
QUERY_STRING 脚本参数或者表单输入项(如果是用GET递交). QUERY_STRING 包含URL中问号后面的参数.
REMOTE_HOST 递交脚本的主机名,这个值不能被设置.
REMOTE_ADDR 递交脚本的主机IP地址.
REMOTE_USER 递交脚本的用户名. 如果服务器的authentication被激活,这个值可以设置。
REMOTE_IDENT 如果Web服务器是在ident (一种确认用户连接你的协议)运行, 递交表单的系统也在运行ident, 这个变量就含有ident返回值.
CONTENT_TYPE 如果表单是用POST递交, 这个值将是 application/x-www-form-urlencoded. 在上载文件的表单中, content-type 是个 multipart/form-data.
CONTENT_LENGTH 对于用POST递交的表单, 标准输入口的字节数.

表单输入的解码程序

目前有两个程序: 通用目的的uncgi, 和cgi-lib.pl, 这是个Perl库,用于perl编写的CGI脚本.

 

当然也有表单上载时可以解码的程序,很少。

uncgi

说明原码可以从 http://www.hyperion.com/~koreth/uncgi.html获得。

cgi-lib.pl

这是由Steve Brenner编写的, 帮助你管理输入. 他能从GET和POST获取输入并且放置在一个Perl列表或阵列中. 更新的版本也能处理来自表单的文件上传. 从这儿可以得到信息与原码 http://www.bio.cam.ac.uk/cgi-lib. 如果你决定用Perl语言处理你的表单输入,cgi-lib是个很好的库.

为了使用cgi-lib.pl,你通常要这样写:
#!/usr/lib/perl

require 'cgi-lib.pl';
cgi-lib中尽管有很多子程序, 最重要的是ReadParse子程. ReadParse 读取输入方便地将name/value储存在一个Perl阵列中. 在你的Perl脚本中通常是这样调用的:
&ReadParse(*in);
此例中,阵列名是in, 可以随便取名的.

在表单输入解码后, 你能读取和处理这个name/value,方法是象下面这样:

print $in{'theName'};
这个将显示名字name是theName的值value.

 

如果你有多个用同样名字的name对, cgi-lib.pl用(\0)分隔多个名字. 这样可以正常处理你的脚本.

解码上传的文件输入

基于表单的文件上传需要不同的表单输入,有一些程序可以对其进行解码。

cgi-lib.pl 后来版本可以很好支持, 在http://www.bio.cam.ac.uk/cgi-lib/ 了解更多的情况.

 

另一个处理用Perl编写的CGI地址是 http://valine.ncsa.uiuc.edu/cgi_docs.html .

自己做

找专门书籍学习吧: ftp://ds.internic.net/rfc/rfc1867.txt.

非解剖的脚本头部

按照本书阐述,大多数情况可以正常操作,在一些情况下不是这样的,你可以翻阅说明书了解。


可以搜索该索引。请键入要搜索的关键字:
脚本

为了在CGI中完成讨论组, 我们看看叫
可以搜索该索引。请键入要搜索的关键字:
的搜索. 这是早期在浏览器中用来向服务器发出搜索关键字的办法,参看以前的资料。

总结

CGI脚本, 有时叫服务器端脚本或网关脚本。 在internet上有很多免费资源,你可以搜索下载读懂他们,当然都是英文的,如果你下决心翻译他们(可能更加强理解). 这样一举两得啊.

注意:上述程序可以用ultra edit来编辑,注意转换UNIX格式 ,必须采用UNIX格式存盘,再上载,用telnet登陆,在命令行键入perl sample.pl,看有无bug,再 在浏览器中调用。CGI程序包括放置CGI的目录一定要改属性为777, 要写入的HTML文件也要改属性为777.

现在网上有很多免费的cgi,基本可以满足一般需求,请到这个网址查询你要的cgi:http://www.itm.com/cgicollection/

本入门说明可以自由拷贝,但请不要删除板桥斋字样,到底我花了一些时间在上面,你我都是各取所需嘛:-)。

分享到:
评论

相关推荐

    CGI脚本入门学习--HTML格式

    CGI脚本是什么? CGI脚本 怎样工作的? 一个简单的例子 我能用CGI脚本吗? 你的服务器配置允许CGI脚本吗? 你能编程吗? 你应该用什么编程语言? 你的服务器设置正确吗? 如果你的服务器不是UNIX系统呢? 解剖...

    CGI 脚本入侵快速上手+脚本使用方法

    CGI 脚本入侵快速上手+脚本使用方法

    一个简单的CGI脚本——Web编程_v1.1归纳.pdf

    一个简单的CGI脚本——Web编程_v1.1归纳.pdf

    cgi.rar_CGI脚本_cgi

    对cgi脚本运用的介绍,希望对你有所帮助

    怎么快速配置cgi脚本

    在Linux下nginx如何安装和配置,文档里边详细的介绍了具体的流程,希望对你们有所帮助。

    计算机软件-编程源码-CGI脚本入门学习.zip

    计算机软件-编程源码-CGI脚本入门学习.zip

    fcgiwrap, CGI脚本的简单FastCGI包装.zip

    fcgiwrap, CGI脚本的简单FastCGI包装 fcgiwrap信息:主页:作者:贡献者CGI脚本的简单FastCGI包装http://nginx.localdomain.pl/wiki/FcgiWrapGrzegorz Nosek &lt;root@localdom

    cgi脚本教程

    学习cgi编程的好工具,该资料非常全面的介绍了cgi脚本

    CGI 开发使用手册

    第6章 简单CGI脚本举例 第7章 编制脚本并设置Web服务器 第8章 修改CGI脚本 第9章 如何处理自定义图像映像 第10章 使用MIME 第四部分 使用CGI搜索引擎和数据库 第11章 为Web站点建立索引 第12章 使用WAIS与CGI 第13章...

    CGI开发使用手册

    内容翔实、材料丰富,从CGI的基本概念到复杂的CGI脚本的编写,循序渐进地引导读者成为CGI专家。从本书中读者可以学到如何开发CGI应用程序、创建搜索引擎、建立交互式HTML文档,编写数据库查询脚本、编写Web爬虫和...

    在ubuntu下为nginx配置支持cgi脚本的方案

    在nginx下支持cgi脚本于支持node类似的,只要在nginx直接做个转发,转发到对应的cgi套接字就好。 使用Fcgiwrap Fcgiqwrap是另外一个CGI封装库,跟Simple CGI类似。 安装fcgiwrap apt-get install fcgiwrap 安装以后...

    cgi基础网络脚本教程

    学习网络脚本的必备用书!通过此书静而达到学习脚本还有网络应用程序的知识! 是从国内一知名黑客网站下载

    CGI安全问题 附arp欺骗和DNS中毒

    CGI在构建WebSite时,用得非常频繁,尤其是将CGI程序与JavaScript结合起来,可以实现强大的功能,正是因为CGI程序的在Server端的强大处理能力,只要CGI脚本中有一点安全方面的失误--就能使入侵者能访问计算机,造成...

    CGI开发使用手册.rar

    内容翔实、材料丰富,从CGI的基本概念到复杂的CGI脚本的编写,循序渐进地引导读者成为CGI专家。从本书中读者可以学到如何开发CGI应用程序、创建搜索引擎、建立交互式HTML文档,编写数据库查询脚本、编写Web爬虫和...

    编写Python CGI脚本的教程

    CGI脚本调用执行完毕后,它的输出结果就会被web服务器用来创建显示给用户的网页。 配置Apache web服务器,让其能运行CGI脚本 在这个教程里,我们假设Apache web服务器已经安装好,并已运行。这篇教程使用的Apache ...

    kankun:cgi脚本控制kankun wifi智能插头

    坎昆cgi脚本控制kankun wifi智能插头安装脚本SSH 到您的设备,创建文件夹 cgi-bin mkdir /www/cgi-bin 使用 scp 将文件复制到 cgi-bin 文件夹控制开关: http:///cgi-bin/relay.cgi?on http:///...

    ADT-Pulse-CGI:用于自动访问和修改 ADT Pulse 设备的 CGI 脚本

    ADT 脉冲 CGI 这是一个简单的 Perl CGI,允许您以自动方式访问 ADT Pulse 设备。免责声明我没有受雇于 Bt ADT,并且此代码未得到 ADT 或我本人的认可。 通过使用此代码,您将对其可能做或不做的任何事情承担全部责任...

    shellshockcgitool:CGI脚本Shellshock开发工具

    CGI脚本ShellShock开发工具。 什么是Shellshock? Shellshock是Bash版本1.0.3-4.3中的关键错误,可以使攻击者执行任意命令。 Bash的漏洞版本错误地执行了遵循存储在环境变量中的函数定义的命令-攻击者可以在将用户...

    使用dll创建cgi程序(181KB)

    使用dll创建cgi程序(181KB)

    gateway:Node.js中间件来执行CGI脚本

    Node.js中间件来执行CGI脚本 该模块的目的是允许诸如或类的开发工具直接提供PHP文件(可能还有其他脚本语言)。 为了使这项工作有效,您需要在PATH中使用php-cgi binaray。 用法 var http = require ( 'http' ) ; ...

Global site tag (gtag.js) - Google Analytics