当前位置:  编程技术>php
本页文章导读:
    ▪php伪静态 URL REWRITE重写规则介绍      1、确认apache支持.htaccess 修改apache的httpd.conf设置让 APACHE支持.htaccess。 打开httpd.conf文件(在那里? APACHE目录的CONF目录里面),用文本编辑器打开后,查找   代码示例: Options FollowSymLinks AllowOverride.........
    ▪php url伪静态过程详解      一,url的静态化原理 1,通过程序来把动态的url转换成静态的url,转换方法最好是统一的接口。把静态的url放到html中,这样我们通过页面看到的就是静态的url。 2,apache或者其他,加载rewrite.........
    ▪php5 Cookie与 Session用法区别与示例      1、Cookie和Session区别 Session信息是存放在server端,但session id是存放在client cookie的,当然php的session存放方法是多样化的,这样就算禁用cookie一样可以跟踪 Cookie是完全保持在客户端的如:IE firefo.........

[1]php伪静态 URL REWRITE重写规则介绍
    来源: 互联网  发布时间: 2013-12-24

1、确认apache支持.htaccess
修改apache的httpd.conf设置让 APACHE支持.htaccess。
打开httpd.conf文件(在那里? APACHE目录的CONF目录里面),用文本编辑器打开后,查找
 

代码示例:
Options FollowSymLinks
AllowOverride None
 

改为
 

代码示例:
Options FollowSymLinks
AllowOverride All

2、建立.htaccess 文件
三种方法都是先建立一个htaccess.txt的文本文件(当然,这个文本文件的名字你可以随便 取),然后有三种方式给这个文件重命名:
(1)用记事本 打开,点击文件–另存为,在文件名窗口输入”.htaccess”,注意是整个绿色部分,也就是包含英文引号,然后点击保存就行了。
(2)进入cmd命令 窗口,通过cd切换当刚建立htaccess.txt文件的文件夹,然后输入命令:rename htaccess.txt .htaccess ,然后点击键盘Enter键即可。
(3)通过ftp连接htaccess.txt所在文件夹,通过ftp软件重命名。
(4)通过dreamweaver等第三方编辑器也可以创建.htaccess。

3、rewrite规则学习
新建一个.htaccess文件:
 

代码示例:
RewriteEngine on #rewriteengine为重写引擎开关on为开启off为关闭
RewriteRule ([0-9]{1,})$ index.php?id=$1

RewriteRule是重写规则,支持正则表达式的,上面的([0-9]{1,})是指由数字组成的,$是结束标志,说明是以数字结束!
伪静态页面规则:
 

代码示例:
RewriteEngine on
RewriteRule ([a-zA-Z]{1,})-([0-9]{1,}).html$ index.php?action=$1&id=$2
 

([a-zA-Z]{1,})-([0-9]{1,}).html$是规则,index.php?action=$1&id=$2是要替换的格式,$1代表第一个括号匹配的值,$2代表第二个,如此类推!!

测试用的index.php
 

代码示例:
<?php
echo ‘你的Action是:’ . $_GET['action'];
echo ‘
’;
echo ‘你的ID是:’ . $_GET['id'];
?>
 

在浏览器中输入:
http:///view-12.html
输出的是:
你的Action是:view
你的ID是:12

就是这些了,希望对大家有所帮助。


    
[2]php url伪静态过程详解
    来源: 互联网  发布时间: 2013-12-24

一,url的静态化原理
1,通过程序来把动态的url转换成静态的url,转换方法最好是统一的接口。把静态的url放到html中,这样我们通过页面看到的就是静态的url。
2,apache或者其他,加载rewrite模块,添加重写规则。这样当我们点页面中的静态url时,就可以转向正确的url了。虽然执行的还是php文件,但是浏览器的地址栏中显示出来的,还是静态的url。

php实现url静态化,也要保持地址栏里面也要静态的url,不过相对麻烦些。

二,把动态url转换成静态url
 

代码示例:
<?php     
    //将url转换成静态url 
    function url_rewrite($file,$params = array (),$html = "",$rewrite = true)  
    {   
        if ($rewrite) {       //开发阶段是不要rewrite,所在开发的时候,把$rewrite = false 
            $url = ($file == 'index') ? '' : '/' . $file; 
            if (!emptyempty ($params) && is_array($params)) $url .= '/' . implode('/', $params); 
            if (!emptyempty ($html)) $url .= '.' . $html; 
        } else { 
            $url = ($file == 'index') ? '/' : '/' . $file; 
            if (substr($url, -4) != '.php' && $file != 'index') $url .= '.php'; 
            if (!emptyempty ($params) && is_array($params)) $url .= '?' . http_build_query($params); 
        } 
     
        return $url; 
    } 
     
    echo url_rewrite('test.php',array('class'=>"User",'act'=>'check','name'=>'tank')); 
    //$rewrite = false的情况下,显示如下/test.php?class=User&act=check&name=tank 
     
    echo url_rewrite('test.php', array ('class'=>"User",'act'=>'check','name'=>'tank')); 
    //$rewrite = true的情况下,显示如下/test.php/User/check/tank 
     
    echo url_rewrite('test', array ('class'=>"User",'act'=>'check','name'=>'tank')); 
    //$rewrite = true的情况下,显示如下/test/User/check/tank 
     
    echo url_rewrite('test', array ('class'=>"User",'act'=>'check','name'=>'tank'),'html'); 
    //$rewrite = true的情况下,显示如下/test/User/check/tank.html 
    ?> 
    <a href="/blog_article/test3</php echo url_rewrite(.html'test.php',array('class'=>"User",'act'=>'check','name'=>'tank'));?>">test</a> 
 

上面简单的写了一个方法,把动态url转换成静态的url,页面中会产生链接如下:
 

代码示例:
<a href="/blog_article/test3/test.php/User/check/tank/index.html">test</a> 

到这儿如果直接点击的话,肯定会报404错误的,因为根不可能找到tank这个目录的。难点也在这儿,所以我们要把找不到的目录和文件指定一个php文件。这个要利用到apache,nginx,或者htaccess等。

三,指定一个统一入口
 

代码示例:
RewriteCond %{REQUEST_FILENAME} !-f  //找不到文件 
RewriteCond %{REQUEST_FILENAME} !-d  //打不到目录 
RewriteRule . /test3/index.php [L] 

不管你是以.htaccess的方式来实现,还是写在apache等的配置文件中,都是可以的。上面三句话是什么意思呢,如果找不到目录转到index.php文件,如果找不到文件,也转到index.php。
这样做了,当我们访问http://localhost/test3/test.php/User/check/tank时候,就会转到index.php来,既然知道到那个php文件了,那就好办了。
以下内容都是以http://localhost/test3/test.php/User/check/tank这种重写的方式来操作的,其他方式也都差不多。

四,index.php文件
 

代码示例:
<?php     
    $filename = $_SERVER['REQUEST_URI'];  //请求的url 
     
    /**请求的url,"/test3/test.php/User/check/tank"
     * test.php 要去的php文件
     * User 是class名
     * check 是class中的方法名
     * tank 是要传到check的参数*/ 
     
    preg_match("/(\w+\.php)/",$filename,$match);    //查找php文件名 
     
    $array =  explode()('/',$filename);       //将静态url进行分割 
     
    $key  =  array_keys()($array,$match[0]);  //得到文件所对应的下标Array ( [0] => 2 ) 
    $file_array = array_slice($array,0,$key[0]+1);  //Array ( [0] => [1] => test3 [2] => test.php ) 
    $param_array = array_slice($array,$key[0]+1);   //Array ( [0] => User [1] => check [2] => tank )  
     
    $file_path = implode('/',$file_array); 
     
    if($array[$key[0]] != "index.php"){ 
     include_once($array[$key[0]]);            //包函请求url中的php文件,在这里是test.php 
    } 
     
    if(class_exists($param_array[0])){     //判断一下test.php这个文件中有没有User这个class 
     
     $obj = new $param_array[0]; 
     if(method_exists($obj,$param_array[1])){   //判断一下User这个class中有有没有check这个方法 
     $obj->$param_array[1]($param_array[2]);  //调用这个方法,结果是(我的名子叫tank) 
     } 
    } 
?>

五,test.php文件
 

代码示例:
<?php       
    class User { 
     public function check($name){ 
     echo "我的名子叫".$name; 
     } 
    } 
?>
 

到这儿,当我们访问http://localhost/test3/test.php/User/check/tank时。
结果如下:我的名子叫tank,并且地址栏还仍然保持着静态。


    
[3]php5 Cookie与 Session用法区别与示例
    来源: 互联网  发布时间: 2013-12-24

1、Cookie和Session区别
Session信息是存放在server端,但session id是存放在client cookie的,当然php的session存放方法是多样化的,这样就算禁用cookie一样可以跟踪
Cookie是完全保持在客户端的如:IE firefox 当客户端禁止cookie时将不能再使用

2、Cookie的配置与应用
Setcookie(string name, string value, int expire,string path, string domain, int secure);
其中name是cookie变量名称标识,你在php中将能象使用普通变量名相同来用他引用cookie变量。value是cookie变量的初始值,expire 表示该cookie变量的有效时间;path 为该cookie变量的相关路径;domain 表示cookie变量的网站;secure 则需在 https 的安全传输时才有效。
 

代码示例:
SetCookie("Cookie", "cookievalue",time()+3600, "/forum", ".", 1);

1)、接收和处理Cookie
PHP对Cookie的接收和处理的支持非常好,是完全自动的,跟FORM变量的原则一样,特别简单。
比如设置一个名为 MyCookier的Cookie,PHP会自动从WEB服务器接收的HTTP头里把它分析出来,并形成一个与普通变量一样的变量,名为$ myCookie,这个变量的值就是Cookie的值。数组同样适用。另外一个办法是引用PHP的全局变量$HTTP_COOKIE_VARS数组。
分别举例如下:(假设这些都在以前的页面里设置过了,并且仍然有效)
 

代码示例:
<?php
echo $MyCookie;
echo $CookieArray[0];
echo $_COOKIE["MyCookie"];
echo $HTTP_COOKIE_VARS["MyCookie"];
?>

2)、删除Cookie
要删除一个已经存在的Cookie,有两个办法:
 

代码示例:
1、SetCookie("Cookie", "");
2、SetCookie("Cookie", "value" , time()-1 / time() );

3)、使用Cookie的限制
1、必须在HTML文件的内容输出之前设置;
2、不同的浏览器对Cookie的处理不一致,且有时会出现错误的结果。
3、限制是在客户端的。一个浏览器能创建的Cookie数量最多为30个,并且每个不能超过4KB,每个WEB站点能设置的Cookie总数不能超过20个。

3、Session的配置与应用

代码示例:
<?php
session_start(); //初始化session.需在文件头部
$_SESSION[name]=value; //配置Seeeion
echo $_SESSION[name]; //使用session
isset()($_SESSION[name]); // 判断
unset($_SESSION[name]); //删除
session_destroy(); //消耗所有session
?>
 

注意:session_register(),session_unregister,session_is_registered在php5下不再使用。

1、cookies用法实例
 

代码示例:

<?php
if($_GET['out'])
{ //用于注销cookies
setcookie('id',"");
setcookie('pass',"");
echo "<script>location.href='/blog_article/login.html'</script>"; //因为cookies不是及时生效的,只有你再次刷新时才生效,所以,注销后让页面自动刷新。
}

if($_POST['name']&&$_POST['password']) //如果变量用户名和密码存在时,在下面设置cookies
{ //用于设置cookies
setcookie('id',$_POST['name'],time()+3600);
setcookie('pass',$_POST['password'],time()+3600);
echo "<script>location.href='/blog_article/login.html'</script>"; //让cookies及时生效

}
if($_COOKIE['id']&&$_COOKIE['pass'])
{ //cookies设置成功后,用于显示cookies
echo "登录成功!<br />用户名:".$_COOKIE['id']."<br/>密码:".$_COOKIE['pass'];
echo "<br />";
echo "<a href='/blog_article/login/out/out.html'>注销cookies</a>"; //双引号内,如果再有引号,需要用单引号。
}
?>
 

 

代码示例:

<form action="" method="post">
用户ID:
<input type="text" name="name" /><br/><br/>
密码:
<input type="password" name="password" /><br/><br />
<input type="submit" name="submit">
</form>

2、session用法实例
 

代码示例:

<?php
//session用法实例
session_start();//启动session,必须放在第一句,否则会出错。
if($_GET['out'])
{

unset($_SESSION['id']);
unset($_SESSION['pass']);
}

if($_POST['name']&&$_POST['password'])
{
//用于设置session
$_SESSION['id']=$_POST['name'];
$_SESSION['pass']=$_POST['password'];
}

if($_SESSION['id']&&$_SESSION['pass'])
{
echo "登录成功!<br/>用户ID:".$_SESSION['id']."<br />用户密码:".$_SESSION['pass'];
echo "<br />";
echo "<a href='/blog_article/login/out/out.html'>注销session</a>";
}
?>
 

代码示例:

<form action="/blog_article/login.html" method="post">
用户ID:
<input type="text" name="name" /><br/><br/>
密码:
<input type="password" name="password" /><br/><br />
<input type="submit" name="submit">
</form>


    
最新技术文章:
▪PHP函数microtime()时间戳的定义与用法
▪PHP单一入口之apache配置内容
▪PHP数组排序方法总结(收藏)
▪php数组排序方法大全(脚本学堂整理奉献)
▪php数组排序的几个函数(附实例)
▪php二维数组排序(实例)
▪php根据键值对二维数组排序的小例子
▪php验证码(附截图)
▪php数组长度的获取方法(三个实例)
▪php获取数组长度的方法举例
▪判断php数组维度(php数组长度)的方法
▪php获取图片的exif信息的示例代码
▪PHP 数组key长度对性能的影响实例分析
▪php函数指定默认值的方法示例
▪php提交表单到当前页面、提交表单后页面重定...
▪php四舍五入的三种实现方法
▪php获得数组长度(元素个数)的方法
▪php日期函数的简单示例代码
▪php数学函数的简单示例代码
▪php字符串函数的简单示例代码
▪php文件下载代码(多浏览器兼容、支持中文文...
▪php实现文件下载、支持中文文件名的示例代码...
▪php文件下载(防止中文文件名乱码)的示例代码
▪解决PHP文件下载时中文文件名乱码的问题
▪php数组去重(一维、二维数组去重)的简单示例
▪php小数点后取两位的三种实现方法
▪php Redis 队列服务的简单示例
▪PHP导出excel时数字变为科学计数的解决方法
▪PHP数组根据值获取Key的简单示例
▪php数组去重的函数代码示例
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3