一、什么是CGI?
CGI(通用网关接口)是一种协议,用于Web服务器和其他软件(如Python脚本)之间的通信,主要作用是处理HTTP请求并生成响应。
在Web开发中,CGI通常用于处理动态内容,例如Web表单提交、登录验证和数据库查询等。当用户访问包含CGI脚本的网页时,Web服务器会将请求传递给CGI脚本,脚本则会根据请求的内容动态生成HTML页面,并将生成的页面返回给Web服务器。
二、使用Python编写CGI脚本
Python是一种功能强大的编程语言,它可以用于编写Web应用程序的各个方面,包括服务器端和客户端。下面我们将介绍如何使用Python编写简单的CGI脚本。
1、Hello World
下面是一个简单的CGI脚本示例,用于产生一个Hello World页面:
#!/usr/bin/env python3 print("Content-type:text/html") print("") print("<html><head><title>Hello World</title></head><body>") print("<h2>Hello World!</h2>") print("</body></html>")
以上代码实现了向客户端输出HTML代码的功能,其中第一行指定了输出内容的类型为text/html,第二行输出一个空行以分隔头部和正文,接下来的代码生成一个包含"Hello World!"标题的HTML页面。
2、Web表单处理
下面是一个用Python处理Web表单的CGI脚本示例:
#!/usr/bin/env python3 import cgi # 创建FieldStorage实例 form = cgi.FieldStorage() # 获取表单值 name = form.getvalue('name') # 生成HTML响应 print("Content-type:text/html") print("") print("<html><head><title>Greeting Page</title></head><body>") if name: print("<h2>Welcome, %s!</h2>" % name) else: print("<h2>Please enter your name.</h2>") print("<form action='/cgi-bin/greeting.py' method='post'>") print("<p>Name:<input type='text' name='name'></p>") print("<p><input type='submit' value='Submit'></p>") print("</form>") print("</body></html>")
以上代码实现了一个简单的Web表单,用于向用户索取姓名并输出欢迎消息。当用户提交表单时,CGI脚本会从请求中获取用户的姓名,并生成一个包含欢迎消息的HTML页面。
3、数据库查询
下面是一个使用Python和SQLite数据库进行查询的CGI脚本示例:
#!/usr/bin/env python3 import cgi import sqlite3 # 连接数据库 conn = sqlite3.connect('test.db') # 创建游标 cursor = conn.cursor() # 获取表单值 keyword = cgi.FieldStorage().getvalue('keyword') # 查询数据库 if keyword: results = cursor.execute("SELECT name, price FROM products WHERE name LIKE ?", ('%'+keyword+'%',)).fetchall() # 生成HTML响应 print("Content-type:text/html") print("") print("<html><head><title>Product Search Results</title></head><body>") print("<h2>Product Search Results</h2>") print("<form action='/cgi-bin/search.py' method='get'>") print("<p>Keyword:<input type='text' name='keyword'><input type='submit' value='Search'></p>") print("</form>") if keyword: if results: print("<table>") print("<tr><th>Name</th><th>Price</th></tr>") for row in results: print("<tr><td>%s</td><td>%s</td></tr>" % row) print("</table>") else: print("<p>No results found</p>") print("</body></html>") # 关闭游标和连接 cursor.close() conn.close()
以上代码使用了SQLite数据库,搜索商品名称包含关键字的商品,并输出结果。CGI脚本从请求中获取关键字,然后使用LIKE语句对数据库进行查询,并按照HTML表格的格式呈现结果。注意,为了避免SQL注入攻击,我们使用了占位符(?)来构建SQL查询语句。
三、如何在Web服务器中运行CGI脚本?
Web服务器需要配置才能运行CGI脚本。如果使用的是Apache服务器,可以在httpd.conf文件中添加以下配置:
<Directory "/var/www/cgi-bin"> AllowOverride None Options +ExecCGI Order allow,deny Allow from all AddHandler cgi-script .py </Directory>
以上配置指定了CGI脚本所在的目录,并将.py文件关联到CGI程序处理器。在服务器上安装Python 3的CGI程序处理器之后,就可以在浏览器中访问CGI脚本了。
四、结语
Python的CGI模块提供了方便的工具,可以用于实现动态Web应用程序。使用Python编写CGI脚本可以减少Web开发的复杂度,提高开发效率,同时还可以享受到Python的强大编程能力。