传统 CGI 如何获取 web 传递的数据,form 表单传递方式原理是什么?
时间: 2024-02-29 21:55:56 浏览: 39
传统 CGI(Common Gateway Interface)是一种在 Web 服务器和应用程序之间进行数据交换的标准接口,它可以通过接受 Web 服务器传递过来的数据,执行相应的程序并将结果返回给 Web 服务器。
在传统 CGI 中,form 表单传递方式是通过 HTTP 协议中的 POST 或 GET 方法来传递数据的。当用户在 Web 浏览器中填写了一个表单并提交时,表单中的所有数据都会被打包成一个 HTTP 请求,然后发送给 Web 服务器。Web 服务器会将这个请求交给相应的 CGI 程序来处理。
对于 POST 方法,Web 服务器会将所有的表单数据打包成一个消息体,放在 HTTP 请求的消息体中,然后将这个消息体发送给 CGI 程序。CGI 程序可以通过读取标准输入(stdin)来获取这个消息体中的所有数据。
对于 GET 方法,Web 服务器会将所有的表单数据打包成一个查询字符串,放在 HTTP 请求的 URL 中,然后将这个 URL 发送给 CGI 程序。CGI 程序可以通过读取环境变量 QUERY_STRING 来获取这个查询字符串中的所有数据。
综上所述,传统 CGI 可以通过读取标准输入或环境变量来获取 Web 服务器传递过来的数据,从而实现对表单数据的处理。
相关问题
引入 CGIC 库后的 form 表单数据处理方法是什么?
CGIC(Common Gateway Interface for C)是一个用于处理 CGI 的 C 语言库。它可以简化 CGI 程序的开发,提供了方便的接口来处理 Web 服务器传递过来的数据,包括表单数据。
使用 CGIC 库处理 form 表单数据的方法如下:
1. 首先,需要在 CGI 程序中引入 CGIC 库的头文件:
```
#include "cgic.h"
```
2. 在 CGI 程序的主函数中,需要调用 `cgiHeaderContentType` 函数来设置 HTTP 响应头,指明返回的内容类型为 HTML:
```
int main(int argc, char *argv[]) {
cgiHeaderContentType("text/html");
//...
}
```
3. 接着,需要使用 `cgiForm*` 函数来获取表单数据,例如:
```
char name[50];
cgiFormString("name", name, sizeof(name));
```
上面的代码可以获取表单中名为 "name" 的字段的值,并将其存储在 `name` 变量中。如果表单中没有名为 "name" 的字段,那么 `cgiFormString` 函数会返回一个错误码。
4. 最后,需要将处理后的数据输出到 HTML 页面中,例如:
```
printf("<html><head><title>CGI Example</title></head><body>");
printf("<h1>Hello, %s!</h1>", name);
printf("</body></html>");
```
上面的代码将处理后的数据输出到 HTML 页面中,其中 `%s` 会被替换为 `name` 变量中的值。
综上所述,使用 CGIC 库处理表单数据需要引入 CGIC 库的头文件,调用 `cgiHeaderContentType` 函数设置 HTTP 响应头,使用 `cgiForm*` 函数获取表单数据,然后将处理后的数据输出到 HTML 页面中。
python cgi mysql_将Python CGI脚本的表单数据传递给mySQL查询
要将表单数据传递给MySQL查询,需要使用Python的MySQL驱动程序。可以使用Python的`mysql-connector`模块来连接MySQL数据库,将表单数据插入到数据库中。
以下是一个示例代码,可以将表单数据插入到MySQL数据库中:
```python
import mysql.connector
import cgi
# 连接MySQL数据库
cnx = mysql.connector.connect(user='username', password='password',
host='localhost',
database='database_name')
# 获取表单数据
form = cgi.FieldStorage()
# 获取表单数据中的参数
param1 = form.getfirst('param1')
param2 = form.getfirst('param2')
# 将数据插入到数据库中
cursor = cnx.cursor()
query = "INSERT INTO table_name (column1, column2) VALUES (%s, %s)"
cursor.execute(query, (param1, param2))
# 提交事务
cnx.commit()
# 关闭数据库连接
cnx.close()
```
在上面的代码中,`param1`和`param2`是表单数据中的参数名称。`table_name`是要插入数据的表的名称,`column1`和`column2`是表中的列名。
此代码片段可以放在Python CGI脚本中,以便将表单数据传递给MySQL查询。