PHP:header详解-页面刷新,页面跳转…

header() 函数会传送一个标题讯息给浏览器。因为这些讯息都遵循 HTTP 的规范, 因此浏览器会依据这些讯息做适当之响应。

header()格式:��int header ( string 标头宣告文字 [, bool 置换 [, int http回应码]])

–[标头宣告文字] 的内容就是传给浏览器的标题文字内容。

–[置换] 是布尔型态的参数。 设定为 True 时, 当有二的相同型态的标题讯息宣告时, 后面的讯息将会覆盖前一个讯息。

–第三个参数会让 HTTP 回应码给指定的值。

Location

Refresh

Content-type

Expires(意思为终止)

Last-Modified等。

Location – 浏览器显示指定的网页。

格式: header(“Location: http://绝对地址”);

Location 的地址必须是一个绝对地址。

Refresh

Refresh – 更新网页。

格式如下:��header(“Refresh : N ; URL=网址”)

–N 代表更新时间, 时间单位为秒。 URL 为更新后连结的网址。 如果省略 URL 就表示更新网页本身。

Content-type

Content-type – 定义网页内容的类型。

格式: Content-Type��= “Content-Type:” media-type

举例如下:

Header(“Content-type: text/html; charset=big5″) 设定网页内容为big5

Header(“Content-type: image/gif”) 设定网页内容为gif格式的图片

Header(“Content-type: application/pdf”) 设定网页内容为pdf档

Cache Control – Cache 的控制。

Cache Control 大致可以分成几种类型

设定过期时间。 当时间超过指定时间就表示网页内容已经失效。 其格式如下

Expires = “Expires:” HTTP-date

例 如: header(“Expires: Fri, 31 Oct 2003 18:00:00 GMT”); 表示2003年10月31日星期五 18时。

header(“Expires: Wed, 30 Jun 2004 09:00:00 GMT”); 表示2004年6月30日星期三 9时。

Last-Modified = “Last-Modified” “:” HTTP-date

例如 header(“Last-Modified: Wed, 01 Jan 2003 12:00:00 GMT”); 上次修改时间2003年1月1日12时

Cache Control

no-cache 使得服务器的数据可以传送到远程的使用者, 而不会被暂存 (cache) 起来。

no-store 是预防不良的版本或者是敏感的信息被保留下来。

must-revalidate 是指必须要再评估信息, 如果暂存 (cached) 的数据是无效的则让服务器与使用者端联机

Date 是说明数据内容的建立日期及时间。 其格式如下: Date = “Date:” HTTP-date

范例: header(“Date: Sun, 15 Feb 2004 08:00:00 GMT”); 建立日期是2004年2月15日8时。

使用 header() 函数认证

基本的认证就是使用账号密码窗体输入HTTP 认证。

窗体认 证:

<?php

if (($_POST['name'] != “john”) or ($_POST['passwd'] != “1234″)):

?>

<html>

<title>登入画面</title>

<body>

<B>未输入账号或密码, 或账号,密码不正确 </B><p>

<form action=<?php echo $_SERVER['PHP_SELF'] ?> method=post>

账号 <input type=text name=name value=”请输入账号” size=10><p>

密码 <input type=password name=passwd size=10><p>

<input type=submit value=” 登入 “>

<input type=reset value=” 清除 “>

</form>

</body>

</html>

<?php

else:

echo “登入成功 …..<p>”;

echo “您登入的账号是 “.$_POST['name'].”<br>”;

echo “您使用的密码是 “.$_POST['passwd'];

endif

?>

HTTP认证

<?php

if (empty($_SERVER['PHP_AUTH_USER'])) {

header(“Content-type: text/html; charset=big5″);

header(‘WWW-Authenticate: Basic realm=”认证范围”‘);

header(‘HTTP/1.0 401 Unauthorized’);

echo ‘请输入正确的账号及密码, 不可以取消!’;

exit;

} else {

echo “您登入的账号是 “.$_SERVER['PHP_AUTH_USER'].”<br>”;

echo “您使用的密码是 “.$_SERVER['PHP_AUTH_PW'].”<p>”;

$correctName=”john”;

$correctpwd=”1234″ ;

if (($_SERVER['PHP_AUTH_USER'] != $correctName) or

($_SERVER['PHP_AUTH_PW'] !=$correctpwd)){

echo “登入失败, 请开启新的浏览器重新登入”;

}else{

echo “登入成功…..”;

}

}

?>

DIV弹窗后禁止页面滚动,IE和FF通用,基于prototype

DIV弹出之前,禁止页面滚动:
if(Prototype.Browser.IE){
$($$(‘html’)[0]).setStyle({overflow : ‘hidden’});
}else{
$($$(‘body’)[0]).setStyle({overflow : ‘hidden’});
}

DIV关闭之后,恢复页面滚动:
if(Prototype.Browser.IE){
$($$(‘html’)[0]).setStyle({overflow : ‘auto’});
}else{
$($$(‘body’)[0]).setStyle({overflow : ‘auto’});
}

给Firefox3动手术:高内存占用优化方案

所谓高内存占用,在我的机器环境下,是指120M左右:一个主题,一个扩展。

下面是手术记录:

在地址栏输入 about:config,进入配置模式:

1. 新建一个布尔值,名为 config.trim_on_minimize,并设定值为 true,这样当 Firefox 最小化时就会释放内存占用;

2. 修改browser.sessionhistory.max_total_viewers修改值为5(页面快进/快退 功能中保存的页面总数,默认是-1(无限));

3. 新建一个整数值,名为 browser.cache.memory.capacity,设定其值16384 (>=1G 内存, 此步配置指定内存)。

PHP发邮件标题与内容乱码的解决方法

先用函数base64_encode() — 使用 MIME base64 对数据进行编码
标题字符串前加编码类型例如: =?UTF-8?B?
标题字符串后加:?=
邮件header指明Content-type: text/html; charset=utf-8,这样就能防止邮件正文乱码

$to         = ‘zhoz@example.com’;
$subject   = “=?UTF-8?B?”.base64_encode(‘邮件标题’).”?=”;
$headers   = ‘MIME-Version: 1.0′ . “rn”;
$headers .= ‘Content-type: text/html; charset=utf-8′ . “rn”;
// Additional headers
$headers .= ‘To: zhoz <zhoz@example.com>’ . “rn”;
$headers .= ‘From: Admin <admin@example.com>’ . “rn”;
$headers .= ‘Reply-To: zhoz <zhoz@example>’ . “rn”;
mail($to, $subject, $message, $headers);

去掉IE和Firefox点击链接时的焦点虚线框

IE里需要在 a 标签中加入 hidefocus=”true” 属性:<a href=”” hidefocus=”true” title=””>siteface</a>
而在Firefox等浏览器中定义CSS:a { outline:none; }或者a { outline:0; } 就可以了。

在IE里 hideFocus即隐藏聚焦,具有使对象聚焦失效的功能,其功能相当于:
onFocus=”this.blur()”
它的值是一个布尔值,如hideFocus=true。也可省略赋值直接写hideFocus。

PHP 错误之引号中使用变量

当看到错误提示
syntax error, unexpected T_ENCAPSED_AND_WHITESPACE, expecting T_STRING or T_VARIABLE or T_NUM_STRING
这个提示,是提示变量使用的问题。
而我出现的是,语句中使用了数组,导致失败。下面看看失败的代码;
<?php
echo “我是数组,$n['x']“;
?>
这样即时双引号是可以解析变量的,但是素组这样的,写法是没办法解析。修改成下面就可以了!
<?php
echo “我是数组,{$n['x']}”;
?>
加上花括号{}可以让语句识别这里面是动态的。

Smarty 定界符 花括号 大括号 函数定义 转义

使用 Smarty 模板的时候,通常都是用 ‘{’ 和 ‘}’ 作为定界符(delimiter)。

有时,我们需要在 html 代码里输出大括号,如果在模板里直接写出来,会被 Smarty 的解析器认为是定界符,然后会报错:

Smarty error : syntax error: unrecognized tag

无法识别的标签!

如何解决呢?有 2 种办法:

1:内置变量

ldelim, rdelim
ldelim and rdelim are used for displaying the literal delimiter, in our case “{” or “}”. The template engine always tries to interpret delimiters, so this is the way around that.

ldelim 和 rdelim 用于输出分隔符,也就是大括号 ‘{’ 和 ‘}’。如果只是输出很少的几个大括号,请使用此方法。

2: 文本转义

我们经常会在 html 里写 javascript 函数,就不可避免地写大量的大括号,这个时候上面的解决方法就不适用了,Smarty 提供了一个转义一段代码的标签:{literal}…{/literal}

{literal}
<script type=”text/javascript”>
function sayHello() {alert(‘Hello World!’)}
</script>
{/literal}

这样,就可以在里面随意写各种符号,不必担心 Smarty 引擎会错误解析了!

sql server 2005 存储过程分页


/*
名称:PagingRecord
作用:按任意字段进行排序分页
*/

CREATE   PROCEDURE [dbo].[PagingRecord]
(
@PageIndex int,–页号,从0开始
@PageSize int,–页尺寸
@OrderField varchar(100),–排序字段及类型(多个条件用逗号分开)如:JobID DESC,Checkintime
@TableName varchar(100),–表名或视图表
@StrWhere varchar(2000),–条件
@FieldList varchar(2000),–欲选择字段列表
@DoCount AS bit=1– 0值返回记录总数, 非 0 值则返回记录
)
AS

BEGIN TRAN

DECLARE @SqlQuery varchar(4000)

IF @DoCount<>0
Goto GetCount
Else
Goto GetSearch

GetCount:–返回记录总数
DECLARE @SearchSql AS Nvarchar(4000)
SET @SearchSql= ‘SELECT Count(*) AS Total FROM ‘+@TableName+’ WHERE ‘+@StrWhere
exec sp_executesql @SearchSql
–print @SearchSql
COMMIT TRAN
return

GetSearch:

SET @SqlQuery=’SELECT ‘+@FieldList+’
FROM (SELECT row_number() over(ORDER BY ‘+@OrderField+’) as rownum,
‘+@FieldList+’
FROM ‘+@TableName+’ WHERE ‘+@StrWhere +’) as temp
WHERE rownum BETWEEN (‘+cast(@PageIndex as varchar)+’-1)*’+cast(@PageSize as varchar)+’+1 and ‘+cast(@PageIndex

as varchar)+’*'+cast(@PageSize as varchar) + ‘ ORDER BY ‘+@OrderField
–print @SqlQuery
SET NOCOUNT ON
execute(@SqlQuery)
SET NOCOUNT OFF
COMMIT TRAN

清除MSSQL事务日志文件的几种方法

1.清空日志

1):打开查询分析器,输入命令
DUMP TRANSACTION 数据库名 WITH NO_LOG
2):再打开企业管理器–右键你要压缩的数据库–所有任务–收缩数据库–收缩文件–选择日志文件–在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了。

2.删除LOG

1):分离数据库企业管理器->服务器->数据库->右键->分离数据库
2):删除LOG文件
3):附加数据库企业管理器->服务器->数据库->右键->附加数据库

此法生成新的LOG,大小只有500多K

3、如果想以后不让它增长

企业管理器->服务器->数据库->属性->事务日志->将文件增长限制为2M

再将此数据库设置自动收缩

实践小记-多服务器文档同步与将应用程序添加到系统服务中

最近项目中需要实现两台异地服务器图片同步,于是就开始查资料寻找合适的方法或者软件,其中在一篇文章中提到一个软件,WebSynchronizer,介绍是这样的:

档案同步化工具 – WebSynchronizer,由知名续传软件 ReGet 之软件出版公司所推出,是网站同步化、档案镜像、档案备份的绝佳工具,可以执行下列主要工作:

1) 本机资料夹及远程资料夹的同步化;
2) 两台远程计算机中的资料夹同步化;
3) 两个本机资料之同步化。

看介绍正好符合我的需求,于是便搜索这个软件,在BAIDU上搜索的都是1.3版本的,而且非开源软件,这个可愁了,现在不可能花钱去购买软件的,只能再找, 看看有没有破解版本的,结果中文搜索结果都没有破解的,于是又转向GOOGLE,结果不经意之间发现了WebSynchronizer1.5版,而且还有开源代码,难道是免费的?我赶紧下载下来,安装,一路下来也没有提示要输入序列号,就这样安装好了,真是喜出望外,后来看了一下更新日志,原来到1.5版本这个项目转成开源的了:

Current version: WebSynchronizer 1.5 (build 162)

Build 162 / 09 Jan
WebSynchronizer moved to open source

不错不错,界面好,设置简单,功能强大,绝对的好东西啊!

Continue reading