重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
jsp一共有9个内置对象,分别是以下9个:
创新互联公司是专业的坪山网站建设公司,坪山接单;提供网站制作、成都网站设计,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行坪山网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
1.Request对象
发送请求时,该对象被创建,一次请求结束后即销毁。(一次请求产生一个request对象)
该对象封装了用户提交的信息,通过调用该对象相应的方法要以获取封装的信息。即,使用该对象可以获取用户提交的信息。
当Request对象获取客户提交的内容为汉字字符时,会出现乱码现象,则必须进行特殊处理。首先,将获取的字符串用ISO8859-1进行编码,并将编码存放到一个字节数组中,然后将这个数组转化为字符串对象即可。如下代码:
String text = request.getParameter("body");
byte [] b = text.getBytes("ISO8859-1"); //将text字符串转换成字节数组---编码的过程
text = new String(b); //构造字符串,按照当前操作系统的字符集进行构造。将字节转换成字符串---解码的过程
Request常用的方法:
getParameter(String s) ----- 获取表单提交的信息
String s = request.getParameter("name");
getProtocol() -----获取客户使用的协议
String s = request.getProtocol() ;
getServletPath() ----获取客户提交信息的页面
String s = request.getServletPath();
getMethod() -----获取客户提交信息的方式 get或post
String s = request.getMethod();
getHeader() ----- 获取HTTP头文件中的accept、accept-encoding和host的值
String s = request.getHeader("accept");
getRemoteAddr() --获取客户的ip地址
String s = request.getRemoteAddr();
getServerHost() ---获取客户机的名称
String s = request.getServerHost();
getServerName() ---获取服务器名称
String s = request.getServerName();
getServerPort() ----获取服务器的商口号
String s = request.getServerPort();
getPamameterNames() ----获取客户端提交的所有参数的名字
Enumeration enum = request.getParameterNames();
while(enum.hasMoreElements()){
String s = (String) enum.nextElement();
out.println(s);
}
2. Response对象:对客户的请求做出动态响应,向客户端发送数据。响应客户请求时创建,响应结束时销毁。(一次响应产生一个response对象)
动态响应contentType属性
当一个用户访问了一个jsp页面时,如果该页面用page指令设置页面的contentType属性为text/html,那么jsp引擎将按照这个属性值做出反应。如果要动态改变这个属性值来响应客户,就需要使用Response对象的setContentType(String s);方法来改变contentType属性的值。
格式:response.setContentType(String s) -----参数s可取:text/html,application/x-msexcel,application/msword等
Response重定向
在某些情况下,当响应客户时,需要将客户重新引导到另一个页面,可以使用Response的sendRedirect(URL);方法,实现客户的重定向
格式:response.sendRedirect("index.jsp");
3. Session对象: 在页面的page指令加上session="true" 或缺省 情况下以及在servlet中使用request.getSession();的方式进行创建。超时或服务停止时,session结束。(一个用户对应一个session对象)
什么是session对象? ----- 它是一个jsp内置对象,它在第一个jsp被装载时自动创建,完成会话期管理。从一个客户打开浏览器并连接到服务器开始,到客户关闭浏览器离 开这个服务器结束(或者超时),被称为一个会话。当一个客户访问一个服务器时,可能会在这个服务器的几个页面之间切换,服务器应当通过某种办法知道这是一个客户,就需要创建session对象。
session对象的ID -----当一个客户首次访问服务器上的一个jsp页面时,jsp引擎会产生一个session对象,同时分配一个String类型的的ID号,jsp引擎同时将这个ID号发送到客户端,存放在cookie中,这样,session对象直到客户关闭浏览器后,服务器端,该客户的session对象才会消失,会并,和客户的会话对应关系消失。当客户重新打开浏览器再连接到该服务器时,服务器为该客户再创建一个新的session对象。
session对象的常用方法:
public String getId() ----获取Session对象的编号
pulbic void setAttribute(String key,Object obj) --- 将参数object指定的对象obj添加到Session对象中,并为添加的对象指定一个索引关键字
public Object getAttribute(String key) --- 获取session对象中含有关键字的对象
public Blooean isNew() ----判断是否为一个新的客户
4. Application对象:启动服务时创建,停止服务时销毁。(整个程序只有一个application对象)
什么是Application对象? --- 服务器启动后就产生了这个Application对象,当客户在所访问的的网站的各个页面之间浏览时,这个Application对象都是同一个,直到服务器关闭。但是,与session对象不同的是,所有客户的Application对象都是同一个,即,所有客户共享这个内置的Application对象。
Application对象的常用方法
setAttribute(String key,Ojbect obj) ----将参数obj添加到Application对象中,并为添加的对象指定一个索引关键字
getAttribute(String key); ---- 获取Application对象中含有关键字的对象
5.Out对象:请求时,就创建,请求结束时,销毁。(一个请求,创建一个out对象)
Out对象是一个输出流,用来向客户端输出数据。out对象用于各种数据的输出。其常用方法如下:
out.print(); ---- 向浏览器输出各种类型数据
out.newLine(); --- 输出一个换行符
out.close(); ---关闭流
6.cookie对象:
什么是cookie?----cookie是web服务器保存在用户硬盘上的一段文本。cookie允许一个web站点在用户电脑上保存信息并且随后再取它。
举例来说,一个web站点可能会为每一个访问者产生一个唯一的ID、然后以cookie文件的形式保存在每个用户的机器上。
如果用户选择的是IE浏览器访问web,用户就会看到所有保存在自己硬盘上的cookie。它们最常存放的地方是:c:/Windows/Cookies。cookie是以”关键字 key = 值 value“的格式来保存记录的。
创建一个cookie对象
调用cookid对象的构造函数就可以创建cookie对象。cookie的构造函数有两个字符串参数:cookie名字和cookie值。
如:Cookie c = new Cookie("username","hyc");
将cookie对象传送到客户端
在jsp中,如果要将封装好的cookie对象传送到客户端,可使用Response对象的addCookie()方法
如:Response.addCookie();
读取保存在客户端的cookie
使用request对象的getCookie()方法,执行时,将所有客户端传来的cookie对象以数组的形式排列。如果要取出更符合需求的cookie对象,就需要循环比较数组内每个对象的关键字。
如:Cookie [] c = request.getCookies();
if (c! = null){
for (int i = 0;ic.length;i++){
if("username".equals("c,getName))
out.println(c.getValue());
}
}
设置cookie对象的有效时间
调用cookie对象的setMaxAge()方法,可以设置cookie对象的有效时间。如
Cookie c = new Cookie("username","hyc");
c.setMaxAge(3600);
cookie应用
cookie对象的典型应用是用来统计网站的访问人数。由于代理服务器、缓存等的使用,唯一能帮助网站精确统计来访人数的方法就是为每个访问者建立一个唯 一的ID。使用cookie,网站可以完成以下工作
测试定多少人访问过;
测定访问者有多少是新用户(即第一次来访)、有多少老用户;
测定一个用户多久访问一次网站
当一个用户第一次访问时,网站在数据库中建立一个新的ID,并把ID通过Cookie传送给用户。用户再次来访时,网站把该用户的ID对应的计数器加1,得到用户来访的次数。
7.config对象:配置对象
8.page对象:页面对象
9.Exception对象:在处理异常的网页中可以直接访问exception隐式对象
php 函数的参数类型可以指定为类名或数组类型array,比如 这样是对的public function Right( My_Class $a, array $b ) 这样是错的public function Wrong( string $a, boolean $b ) 如果需要其他类型
我也刚刚学PHP,正在研究中,虽然你只给10分........
首先,将代码保存到一个文件,如:mysql.class.php
其次,在一个常用的文件里调用:比如头部文件header.php,因为我放在根目录所以用下面方式导入其他文件:
require dirname(__FILE__) . 'include/config.php';
//导入类文件
require dirname(__FILE__) . 'include/mysql.class.php';
//定义一个类及初始化数据库类
$db = new mysql($db_host, $db_user, $db_pass, $db_name);
$db_host = $db_user = $db_pass = $db_name = NULL;
然后,在test.php文件调用:
require_once dirname(__FILE__) . '/header.php';
使用方法:
$sql = "读取表";
$res = $db-query($sql);
$info = array();//定义数组
while($row=$db-fetchRow($res))
{
$arr['id'] = $row['id'];
$arr['title'] = $row['title'];
$info[] = $arr;
}
可以在显示的地方用:
foreach($info as $i)
{
echo $i['title']."br /";
}
或是直接使用while
还用另一种调用方式:
$here_area = $db-getRow("select areaid,areaname from {$table}area where areaid='$areaid'");
$here[] = array('name'=$here_area['areaname'],'id'=$here_area['areaid']);
测试通过,因为我正在使用.....................................
config.php代码:
?php
$db_host = "localhost";
$db_name = "test";
$db_user = "root";
$db_pass = "";
$table = "mini_";
$charset = "gb2312";
$dbcharset = "gbk";
?
mysql.class.php代码:
?php
class mysql
{
var $link = NULL;
//自动执行__construct php5类构建方法,如果PHP4和PHP5同时使用会自动使用PHP5的方法
function __construct($dbhost, $dbuser, $dbpw, $dbname = '', $pconnect = 0, $quiet = 0)
{
//自动执行时调用mysql函数
$this-mysql($dbhost, $dbuser, $dbpw, $dbname, $pconnect, $quiet);
}
//php4类构建方法,如果没有 __construct 就自动执行此功能
function mysql($dbhost, $dbuser, $dbpw, $dbname = '', $pconnect = 0, $quiet = 0)
{
if ($quiet)
{
$this-connect($dbhost, $dbuser, $dbpw, $dbname, $pconnect, $quiet);
}
else
{
$this-settings = array(
'dbhost' = $dbhost,
'dbuser' = $dbuser,
'dbpw' = $dbpw,
'dbname' = $dbname,
'charset' = $charset,
'pconnect' = $pconnect
);
}
}
function connect($dbhost, $dbuser, $dbpw, $dbname = '', $pconnect = 0, $quiet = 0)
{
global $dbcharset;
if ($pconnect)
{
if (!($this-link = @mysql_pconnect($dbhost, $dbuser, $dbpw)))
{
if (!$quiet)
{
$this-ErrorMsg("Can't pConnect MySQL Server($dbhost)!");
}
return false;
}
}
else
{
if (PHP_VERSION = '4.2')
{
$this-link = @mysql_connect($dbhost, $dbuser, $dbpw, true);
}
else
{
$this-link = @mysql_connect($dbhost, $dbuser, $dbpw);
mt_srand((double)microtime() * 1000000);
}
if (!$this-link)
{
if (!$quiet)
{
$this-ErrorMsg("Can't Connect MySQL Server($dbhost)!");
}
return false;
}
}
$this-dbhash = md5($this-root_path . $dbhost . $dbuser . $dbpw . $dbname);
$this-version = mysql_get_server_info($this-link);
if ($this-version '4.1')
{
if ($dbcharset != 'latin1')
{
mysql_query("SET character_set_connection=$dbcharset, character_set_results=$dbcharset, character_set_client=binary", $this-link);
}
if ($this-version '5.0.1')
{
mysql_query("SET sql_mode=''", $this-link);
}
}
if ($dbname)
{
if (mysql_select_db($dbname, $this-link) === false )
{
if (!$quiet)
{
$this-ErrorMsg("Can't select MySQL database($dbname)!");
}
return false;
}
else
{
return true;
}
}
else
{
return true;
}
}
function query($sql, $type = '')
{
if ($this-link === NULL)
{
$this-connect($this-settings['dbhost'], $this-settings['dbuser'], $this-settings['dbpw'], $this-settings['dbname'], $this-settings['charset'], $this-settings['pconnect']);
$this-settings = array();
}
if ($this-queryCount++ = 99)
{
$this-queryLog[] = $sql;
}
if ($this-queryTime == '')
{
if (PHP_VERSION = '5.0.0')
{
$this-queryTime = microtime(true);
}
else
{
$this-queryTime = microtime();
}
}
if (!($query = mysql_query($sql, $this-link)) $type != 'SILENT')
{
$this-error_message[]['message'] = 'MySQL Query Error';
$this-error_message[]['sql'] = $sql;
$this-error_message[]['error'] = mysql_error($this-link);
$this-error_message[]['errno'] = mysql_errno($this-link);
$this-ErrorMsg();
return false;
}
return $query;
}
function affected_rows()
{
return mysql_affected_rows($this-link);
}
function num_fields($query)
{
return mysql_num_fields($query);
}
function error()
{
return mysql_error($this-link);
}
function errno()
{
return mysql_errno($this-link);
}
function num_rows($query)
{
return mysql_num_rows($query);
}
function insert_id()
{
return mysql_insert_id($this-link);
}
function fetchRow($query)
{
return mysql_fetch_assoc($query);
}
function fetcharray($query)
{
return mysql_fetch_array($query);
}
function version()
{
return $this-version;
}
function close()
{
return mysql_close($this-link);
}
function ErrorMsg($message = '', $sql = '')
{
if ($message)
{
echo "$message\n\n";
}
else
{
echo "bMySQL server error report:";
print_r($this-error_message);
}
exit;
}
function getCol($sql)
{
$res = $this-query($sql);
if ($res !== false)
{
$arr = array();
while ($row = mysql_fetch_row($res))
{
$arr[] = $row[0];
}
return $arr;
}
else
{
return false;
}
}
function getOne($sql, $limited = false)
{
if ($limited == true)
{
$sql = trim($sql . ' LIMIT 1');
}
$res = $this-query($sql);
if ($res !== false)
{
$row = mysql_fetch_row($res);
if ($row !== false)
{
return $row[0];
}
else
{
return '';
}
}
else
{
return false;
}
}
function getAll($sql)
{
$res = $this-query($sql);
if ($res !== false)
{
$arr = array();
while ($row = mysql_fetch_assoc($res))
{
$arr[] = $row;
}
return $arr;
}
else
{
return false;
}
}
//使用: getRow($sql,true) 如果有true那值是 limit 1,读取一条信息
function getRow($sql, $limited = false)
{
if ($limited == true)
{
$sql = trim($sql . ' LIMIT 1');
}
$res = $this-query($sql);
if ($res !== false)
{
return mysql_fetch_assoc($res);
}
else
{
return false;
}
}
}
?