1. CGI变量简介

如果你在以前使用过传统的CGI,你应该对“CGI变量”的概念很熟悉。 由这些变量可以取得一些和请求(Request)有关的信息。其中一些来自于 HTTP 请求命令行(request line) 和headers (例如:在URI中问号后面的部分或者Content-Length header),一些来自于 Socket本身(例如:被请求主机的IP和名称),还有一些来自于服务器的配置信息(例如:被映射为URL目录的实际 路径)。

2. Servlet和标准CGI变量之间的对应关系

下面的表格中给出了Servlet和标准CGI变量之间的对应关系,对以前使用CGI变量进行编程的朋友会有很大的帮助。 在下表中我们假设request是HttpServletRequest类型的对象。

CGI变量 含义 在 doGet 或 doPost 访问的办法

AUTH_TYPE 如果在请求中有 Authorization header ,则这个变量将会被赋值 (basic 或 digest) request.getAuthType()

CONTENT_LENGTH 只有当请求的方法是 POST 时这个变量才会有意义,它表示传送的数据的字节数。 String.valueOf(request.getContentLength()) (返回String) 或者 request.getContentLength(),返回一个整数(int)。

CONTENT_TYPE 如果被赋值,就表示数据的MIME类型。 request.getContentType()

DOCUMENT_ROOT 和网站根目录对应的实际路径 getServletContext().getRealPath("/") 注意:在以前的Servlet标准中,这条语句是这样写的request.getRealPath("/") 。

HTTP_XXX_YYY 访问任意的HTTP headers request.getHeader("Xxx-Yyy")

PATH_INFO URL 指向的路径的信息。由于Servlet可以和服务器直接通讯,所以这个变量对Servlet没什么作用。 request.getPathInfo()

PATH_TRANSLATED 在Server上被映射为web目录的目录的真实路径的信息。和上一个变量一样,对Servlet用处不大。 request.getPathTranslated()

QUERY_STRING 如果用 GET 方法发出请求(requests),这个变量中将会存放请求的数据,其 形式为经过URL编码的一个大字符串。在servlet中,你很少会用到这个原始的字符串。而是 用 request.getParameter 方法来访问某个特定的请求数据。 request.getQueryString()

REMOTE_ADDR 客户端的IP地址,是String类型的。其形式类似于 "192.9.48.9"。 request.getRemoteAddr()

REMOTE_HOST 发出请求的客户端的域名(例如. "java.sun.com") 如果不能检测到域名,就用客户端的IP地址代替。 request.getRemoteHost()

REMOTE_USER 如果 Authorization header 被赋值,则这个变量中放有用户名。 request.getRemoteUser()

REQUEST_METHOD 请求的类型。通常为 GET 或 POST,但也可能是 HEAD, PUT, DELETE, OPTIONS, 或者 TRACE。 request.getMethod()

SCRIPT_NAME srvlet的路径 request.getServletPath()

SERVER_NAME 服务器的名称 request.getServerName()

SERVER_PORT 服务器的端口 String.valueOf(request.getServerPort())(返回String类型) request.getServerPort()(返回int类型)

SERVER_PROTOCOL 在请求命令行中用的协议的版本号。(例如. HTTP/1.0 或 HTTP/1.1)。 request.getProtocol()

SERVER_SOFTWARE 所用 Web Server 软件的名称 getServletContext().getServerInfo()

3. 例子:读取CGI变量。

下面是一个显示除去 HTTP_XXX_YYY 外所有CGI变量的的servlet。他显示了在上面的表格中列出的所有CGI变量的值。

3.1 ShowCGIVariables.java

Download Here

//! ####### Start ShowCGIVariables.java

import java.io.*;

import javax.servlet.*;

import javax.servlet.http.*;

import java.util.*;

一. 安装DBI模块

步骤1:

从TOOLS栏目中下载DBI.zip,下载完后用winzip解开到一个temp目录,共有三个文件:

Readme

DBI.ppd

DBI.tar.gz

步骤2:

在DOS窗口下,temp目录中运行下面的DOS命令:

ppm install DBI.ppd

如果提示无效命令,可在perl/bin目录下运行

二. 安装DBD-Mysql模块

从软件下载中下载DBD-Mysql.zip,安装方法同一.

三. 准备数据库

启动mysql,首先创建一个数据库mydata,然后创建一个表address

mysql> create database mydata;

Query OK, 1 row affected (0.00 sec)

mysql> use mydata;

Database changed

mysql> create table address (

-> id int(5) not null,

-> name varchar(40) not null,

-> email varchar(50) not null,

-> telephone int(12) null);

Query OK, 0 rows affected (0.05 sec)

输入些数据:

mysql> insert into address values (

-> 1,'Nighthawk','nighthawk@163.net',92384092);

Query OK, 1 row affected (0.00 sec)

四. 下面用perl程序来插入若干记录并做查询.

use DBI;

#连接数据库mydata

my $dbh = DBI->connect('DBI:mysql:mydata') or die "无法连接数据库: " . DBI->errstr;

print "插入若干记录\n";

my $sth = $dbh->prepare(q{

INSERT INTO address (id, name,email,telephone) VALUES (?, ?, ?, ?)

}) });

print "输入记录,回车结束:";

while ($inputdata =<>) {

chop $inputdata;

last unless($inputdata);

my ($id, $name,$email, $tel) = split( /,/, $inputdata);

$sth->execute($id, $name, $email,$tel)

}

# $dbh->commit;

print "下面根据输入的名字打印出EMAIL地址和电话\n";

my $sth = $dbh->prepare('SELECT * FROM address WHERE name=?')

or die $dbh->errstr;

print "请输入姓名,回车结束:";

while ($inputname =<>) {

my @data;

chomp $inputname;

last unless($inputname);

$sth->execute($inputname) or die "错误: " . $sth->errstr;

while (@data = $sth->fetchrow_array()) {

print "Email:$data[2]\t Telephone:$data[3]\n";

}

}

#断开连接

$dbh->disconnect;

Nighthawk

Perl操作Mysql数据库

perl mysql 数据推拉_Perl操作Mysql数据库相关推荐

  1. perl mysql 数据推拉_MySQL_Perl操作mysql数据库的方法,Perl对Mysql的操作。 一、标准 - phpStudy...

    Perl对Mysql的操作. 一.标准操作 1.连接.关闭 my $dbh = DBI->connect("DBI:mysql:database=DBname;host=localho ...

  2. perl mysql 数据推拉_Perl Mysql数据库操作实现代码

    Perl Mysql数据库操作实现代码 2021-01-23 17:46:104 一. 安装DBI模块 步骤1: 从TOOLS栏目中下载DBI.zip,下载完后用winzip解开到一个temp目录,共 ...

  3. perl mysql 数据推拉_使用Perl DBI操作MySQL的一些建议

    使用perl连接mysql,这个网上有很多案例了,一般大家都是DBI下的DBD::MySQL这个模块进行.这里做一个mask弄一个TIPS: Perl DBI MySQL的字符集为UTF8 Perl ...

  4. mysql 数据路由_node-路由操作mysql数据库

    node大部分方法都是异步的,在操作数据库方法后面紧接着输出结果,输出的结果只会为空值,使用promise及其方便的解决这个问题,接下来看看node如何使用路由来处理不同请求,进而操作mysql数据库 ...

  5. perl mysql 数据推拉_用perl 从mysql取出数据做统计分析代码

    为完成老大的要求,我写了一个代码完成这个工作.现在记录在博客上,跟大家分享一下.脚本水平很差,((o(´∀`)o)). 要求如下: 1.数据库mydata1中有个sms_info表,表中记录格式如下: ...

  6. perl mysql 数据推拉_科学网—从MySQL数据库中提取序列并进行引物设计的perl脚本 - 闫双勇的博文...

    利用MySQL数据库来储存序列,通过perl脚本获取序列,并进行引物设计.当然除了引物设计干其它事情也是可以的. 将FASTA文件导入MySQL数据库的方法: bp_seqfeature_load.p ...

  7. 关于Ubuntu 16.04系统挂载硬盘以及迁移MYSQL数据存储目录的操作步骤

    转载链接 : 关于Ubuntu 16.04系统挂载硬盘以及迁移MYSQL数据存储目录的操作步骤 :https://www.jianshu.com/p/58093888ee25 本文背景: 现有项目系统 ...

  8. .NET 使用 MySql.Data.dll 动态库操作MySql的帮助类--MySqlHelper

    .NET 使用 MySql.Data.dll 动态库操作MySql的帮助类--MySqlHelper 參考演示样例代码,例如以下所看到的: /// <summary>/// MySql 数 ...

  9. MySql数据库主键外键与数据库设计

    MySql数据库主键外键与数据库设计 首先要指出的: 列.字段.属性是一个概念 行.记录.元组是一个概念 MySQL数据库CONSTRAINT约束:非空约束,唯一约束,主键约束,外键约束 show c ...

最新文章

  1. mysql dba系统学习(19)配置mysql+lvs+keeplived实现Mysql读操作的负载均衡
  2. 第四十五课:MVC,MVP,MVVM的区别
  3. jenkins+github+docker+maven自动化构建部署
  4. cookie读取中文时乱码
  5. win7系统修复工具_205个电脑系统修复小工具, 联想工程师专用!
  6. python中beautifulsoup是什么_Python中的BeautifulSoup – 获取类型的第n个标记
  7. jQuery----各版本
  8. js判断对象为空_在 JavaScript 中如何检查对象为空
  9. zookeeper的会话
  10. java 事件cancel_Activiti结束事件(End Event)
  11. Apache Solr 全文检索概述 与 Win10 下安装 Solr
  12. 简单的三步教你下载PyCharm汉化插件,让你学习Python事功半倍
  13. Java定时任务,定时执行某个操作
  14. 这10本豆瓣高分经典数学书,果断收藏!
  15. PHP文件上传接口(带参数)
  16. webpack出现CssSyntaxError
  17. 嵌入式应用-详解移植并使用freetype显示文字
  18. 基于博弈思想的攻击图漏洞修复策略
  19. 第三次作业 软件产品同质化问题
  20. Bing必应地图中国API一显示地图 (转) 做人要厚道

热门文章

  1. 多态 oc c++ 与oc category
  2. iOS-mac下 svn的使用
  3. 协同工作流引擎,开启流程优化新纪元
  4. linux shell awk 中 printf 用法
  5. golang 指定范围 生成随机数
  6. tomcat 和 jdk 版本 对应关系
  7. linux 解压 tar.gz 报错 gzip: stdin: not in gzip format
  8. python3 value查key的三种方法
  9. pycharm 添加数据库驱动
  10. linux内核 task_struct 中自旋锁的应用