404页面就是一个告诉搜索引擎这个页面不存在了,同时也提示用户可以选择其它的操作了,下面我来给没有apache操作权限朋友介绍php中自定义404页面的操作方法。
方法一
代码如下 |
复制代码 |
@header("http/1.1 404 not found");
@header("status: 404 not found");
echo 'echo 404';
exit();
|
加载一个404错误页面
代码如下 |
复制代码 |
@header("http/1.1 404 not found");
@header("status: 404 not found");
include("../../404.htm");
exit();
|
也可以在站点中加入.htaccess 代码如下
代码如下 |
复制代码 |
errordocument 404 /404.html
|
如果有apahce配置权限,我们可以修改 httpd.conf
找到:
代码如下 |
复制代码 |
#ErrorDocument 500 "The server made a boo boo."
#ErrorDocument 404 /missing.html
#ErrorDocument 404 "/cgi-bin/missing_handler.pl"
#ErrorDocument 402 xxxxxxx |
修改为
代码如下 |
复制代码 |
ErrorDocument 404 /404.htm |
本文章来给大家介绍php设计模式实例之单例模式方法,有需要了解的朋友可进入参考参考。
单例类:
1.构造函数需要标记为private,单例类不能再其他类中实例化,只能被其自身实例化
2.拥有一个保存类的实例静态成员变量
3.拥有一个访问这个实例的公共的静态方法。[常用getInstance()方法进行实例化单例类,通过instanceof操作符可以检测到此类是否已经被实例化]
注:需要创建__clone()方法防治对象被复制
作用:
1.php的应用主要用于数据库,所以一个应用中会存在大量的数据库操作,使用单例模式,则可以避免大量new操作消耗的资源
2.如果系统中需要一个类来全局控制某些配置信息,那么使用单例模式可以很方便的实现。参照ZF的FrontController部分
3.在一个页面请求汇总,便于进行调试,因为所有的代码都集中在一个类中,我们可以在类中设置钩子,输出日志,从而避免到处var_dump,echo。
php单例模式的例子。
代码如下 |
复制代码 |
<?php
/**
* 单例模式
*/
class DanLi{
//静态成员变量
private static $_instance;
//私有的构造方法
private function __construct(){
}
//防止对象被克隆
public function __clone(){
trigger_error('Clone is not allow!',E_USER_ERROR);
}
public static function getInstance(){
if(!(self::$_instance instanceof self)){
self::$_instance = new self;
}
return self::$_instance;
}
public function test(){
echo "ok";
}
}
//错误:$danli = new DanLi(); $danli_clone = clone $danli;
//正确:$danli = DanLi::getInstance(); $danli->test();
?>
|
下面我们讨论下为什么要使用PHP单例模式?
多数人都是从单例模式的字面上的意思来理解它的用途, 认为这是对系统资源的节省, 可以避免重复实例化, 是一种"计划生育". 而PHP每次执行完页面都是会从内存中清理掉所有的资源. 因而PHP中的单例实际每次运行都是需要重新实例化的, 这样就失去了单例重复实例化的意义了. 单单从这个方面来说, PHP的单例的确有点让各位失望. 但是单例仅仅只有这个功能和应用吗? 答案是否定的,我们一起来看看。
1. php的应用主要在于数据库应用, 所以一个应用中会存在大量的数据库操作, 在使用面向对象的方式开发时(废话), 如果使用单例模式, 则可以避免大量的new 操作消耗的资源。
2. 如果系统中需要有一个类来全局控制某些配置信息, 那么使用单例模式可以很方便的实现. 这个可以参看zend Framework的FrontController部分。
3. 在一次页面请求中, 便于进行调试, 因为所有的代码(例如数据库操作类db)都集中在一个类中, 我们可以在类中设置钩子, 输出日志,从而避免到处var_dump, echo。
代码如下 |
复制代码 |
<?php
/**
* 设计模式之单例模式
* $_instance必须声明为静态的私有变量
* 构造函数和析构函数必须声明为私有,防止外部程序new
* 类从而失去单例模式的意义
* getInstance()方法必须设置为公有的,必须调用此方法
* 以返回实例的一个引用
* ::操作符只能访问静态变量和静态函数
* new对象都会消耗内存
* 使用场景:最常用的地方是数据库连接。
* 使用单例模式生成一个对象后,
* 该对象可以被其它众多对象所使用。
*/
class Example
{
//保存例实例在此属性中
private static $_instance;
//构造函数声明为private,防止直接创建对象
private function __construct()
{
echo 'I am Construceted';
}
//单例方法
public static function singleton()
{
if(!isset(self::$_instance))
{
$c=__CLASS__;
self::$_instance=new $c;
}
return self::$_instance;
}
//阻止用户复制对象实例
public function __clone()
{
trigger_error('Clone is not allow' ,E_USER_ERROR);
}
function test()
{
echo("test");
}
}
// 这个写法会出错,因为构造方法被声明为private
$test = new Example;
// 下面将得到Example类的单例对象
$test = Example::singleton();
$test->test();
// 复制对象将导致一个E_USER_ERROR.
$test_clone = clone $test;
?>
|
本文章来给大家介绍PHP session_encode()和 session_decode() 用法,有需要了解的同学可参考本实例。
session_encode
session_encode — 将当前会话数据编码为一个字符串
说明
string session_encode ( void )
session_encode()返回一个字符串,该字符串包含有被编码的当前会话数据。
代码如下 |
复制代码 |
<?
//boolean session_encode()
session_register ( 'bgcolor' );
session_register ( 'fontcolor' );
$id = session_id ( $usr_id );
$bgcolor = "white";
$fontcolor = "blue";
$usr_data = session_encode ();
print $usr_data;
?>
|
session_decode
代码如下 |
复制代码 |
<?
session_start();
$_SESSION = array();
session_decode( "products|a:2:{i:0;s:8:"Hal 2000";i:1;s:6:"Tardis";}" );
foreach ( $_SESSION['products'] as $p ) {
print "$p<br/>n";
}
?>
|
本文章来给大家介绍关于各种PHP去除多余的HTML,Javascrit,Css标签 方法与实现程序,大家可进入参考。
1.不保留任何HTML标签,代码会是这样:echo strip_tags($str);
2. 只保留<p>一个标签的话,只需要将<p>字符串写到strip_tags的第二个参数中,代码会是这样:echo strip_tags($str, "<p>");
3. 我们要保留<p>与<b>…多个标签,只需要将多个标签用空格分隔后写到strip_tags的第二个参数中,代码会是这样:echo strip_tags($str, "<p> <b>");
4.保留所有标签,仅仅转义用addslashes(), stripslashes(), htmlspecialchars(), htmlentities(), nl2br() 等函数.
addslashes(), stripslashes() 一般是入数据库和出库的时候使用,以免变量中存储类似引号这些关键词,这样的话,本来是内容的部分却被数据库识别为标识符来执行,就会引起错误.
htmlspecialchars() 函数只用来转义少量HTML, &,双引号,大于号和小于号.并不会全部转换成 HTML 所定的 ASCII 转换
htmlentities() 本函数有点像 htmlspecialchars() 函数,但本函数会将所有 string 的字符都转成 HTML 的特殊字集字符串。不过在转换后阅读网页源代码的方面,会有很多困扰,尤其是网页源代码的中文字会变得不知所云,浏览器上看到的还是正常的。
自带函数去除html标记
strip_tags
去掉 HTML 及 PHP 的标记。
语法: string strip_tags(string str);
传回值: 字串
函式种类: 资料处理
代码如下 |
复制代码 |
<?php
$new = htmlspecialchars("<a href='test'>Test</a>", ENT_QUOTES);
echo $new;
?>
|
函式将特殊字元转成 HTML 的字串格式 ( &....; )。最常用到的场合可能就是处理客户留言的留言版了。
& (和) 转成 &
" (双引号) 转成 "
< (小于) 转成 <
> (大于) 转成 >
此函式只转换上面的特殊字元,并不会全部转换成 HTML 所定的 ASCII 转换。
这里只替换 html,js,css
代码如下 |
复制代码 |
function get_enhtml($string){
$pattern=array ("'<script[^>]*?>.*?</script>'si",// 去掉 javascript
"'<style[^>]*?>.*?</style>'si",// 去掉 HTML 标记
"'<[/!]*?[^<>]*?>'si",//去掉 HTML 标记
"'<!--[/!]*?[^<>]*?>'si", // 去掉 注释标记
"'([rn])[s]+'", // 去掉空白字符
"'&(quot|#34);'i",
"'&(amp|#38);'i",
"'&(lt|#60);'i",
"'&(gt|#62);'i",
"'&(nbsp|#160);'i",
"'&(iexcl|#161);'i",
"'&(cent|#162);'i",
"'&(pound|#163);'i",
"'&(copy|#169);'i",
"'&#(d+);'e");
$replace=array ("", "", "", "", "1", "", "&", "<", ">", " ", chr(161), chr(162), chr(163), chr(169), "chr(1)");
$string=preg_replace($pattern, $replace, $string);
$string=preg_replace("/<(.*?)>/","",$string);
$string=str_replace("n","",$string);
$string=str_replace("r","",$string);
$string=str_replace(" ","",$string);
$string=str_replace(" ","",$string);
return addslashes(trim($string));
}
|
替换所有html标签
代码如下 |
复制代码 |
function noHTML($content)
{
$content = preg_replace("/<a[^>]*>/i",'', $content);
$content = preg_replace("/</a>/i", '', $content);
$content = preg_replace("/<div[^>]*>/i",'', $content);
$content = preg_replace("/</div>/i",'', $content);
$content = preg_replace("/<font[^>]*>/i",'', $content);
$content = preg_replace("/</font>/i",'', $content);
$content = preg_replace("/<p[^>]*>/i",'', $content);
$content = preg_replace("/</p>/i",'', $content);
$content = preg_replace("/<span[^>]*>/i",'', $content);
$content = preg_replace("/</span>/i",'', $content);
$content = preg_replace("/<?xml[^>]*>/i",'', $content);
$content = preg_replace("/</?xml>/i",'', $content);
$content = preg_replace("/<o:p[^>]*>/i",'', $content);
$content = preg_replace("/</o:p>/i",'', $content);
$content = preg_replace("/<u[^>]*>/i",'', $content);
$content = preg_replace("/</u>/i",'', $content);
$content = preg_replace("/<b[^>]*>/i",'', $content);
$content = preg_replace("/</b>/i",'', $content);
$content = preg_replace("/<meta[^>]*>/i",'', $content);
$content = preg_replace("/</meta>/i",'', $content);
$content = preg_replace("/<!--[^>]*-->/i",'', $content);//注释内容
$content = preg_replace("/<p[^>]*-->/i",'', $content);//注释内容
$content = preg_replace("/style=.+?['|"]/i",'',$content);//去除样式
$content = preg_replace("/class=.+?['|"]/i",'',$content);//去除样式
$content = preg_replace("/id=.+?['|"]/i",'',$content);//去除样式
$content = preg_replace("/lang=.+?['|"]/i",'',$content);//去除样式
$content = preg_replace("/width=.+?['|"]/i",'',$content);//去除样式
$content = preg_replace("/height=.+?['|"]/i",'',$content);//去除样式
$content = preg_replace("/border=.+?['|"]/i",'',$content);//去除样式
$content = preg_replace("/face=.+?['|"]/i",'',$content);//去除样式
$content = preg_replace("/face=.+?['|"]/",'',$content);
$content = preg_replace("/face=.+?['|"]/",'',$content);
$content=str_replace( " ","",$content);
return $content;
}
|
本文章来给大家介绍关于php 获取checkbox表单取值程序代码,有需要了解的朋友可进入参考,因为checkbox 属生与input有区别,所以这里特别来介绍一下。
设我们有一个html页面,代码如下:
代码如下 |
复制代码 |
<FORM method="post" action="checkTest.php">
<INPUT name="test[]" type="checkbox" value="1" />
<INPUT type="checkbox" name="test[]" value="2" />
<INPUT type="checkbox" name="test[]" value="3" />
<INPUT type="checkbox" name="test[]" value="4" />
<INPUT type="checkbox" name="test[]" value="5" />
<INPUT type="submit" name="Submit" value="Submit" />
</FORM>
|
注意上面input的name属性,各个属性内容都一样,而且都是test[],加上[]的原因在于让test的内容变成数组形式传递。
checkTest.php的代码内容如下:
代码如下 |
复制代码 |
<?php
echo implode(",",$_POST['test']);
?>
|
标签:[!--infotagslink--]