1、确认apache支持.htaccess
修改apache的httpd.conf设置让 APACHE支持.htaccess。
打开httpd.conf文件(在那里? APACHE目录的CONF目录里面),用文本编辑器打开后,查找
AllowOverride None
改为
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文件:
RewriteRule ([0-9]{1,})$ index.php?id=$1
RewriteRule是重写规则,支持正则表达式的,上面的([0-9]{1,})是指由数字组成的,$是结束标志,说明是以数字结束!
伪静态页面规则:
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
echo ‘你的Action是:’ . $_GET['action'];
echo ‘
’;
echo ‘你的ID是:’ . $_GET['id'];
?>
在浏览器中输入:
http:///view-12.html
输出的是:
你的Action是:view
你的ID是:12
就是这些了,希望对大家有所帮助。
一,url的静态化原理
1,通过程序来把动态的url转换成静态的url,转换方法最好是统一的接口。把静态的url放到html中,这样我们通过页面看到的就是静态的url。
2,apache或者其他,加载rewrite模块,添加重写规则。这样当我们点页面中的静态url时,就可以转向正确的url了。虽然执行的还是php文件,但是浏览器的地址栏中显示出来的,还是静态的url。
php实现url静态化,也要保持地址栏里面也要静态的url,不过相对麻烦些。
二,把动态url转换成静态url
//将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,页面中会产生链接如下:
到这儿如果直接点击的话,肯定会报404错误的,因为根不可能找到tank这个目录的。难点也在这儿,所以我们要把找不到的目录和文件指定一个php文件。这个要利用到apache,nginx,或者htaccess等。
三,指定一个统一入口
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文件
$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文件
class User {
public function check($name){
echo "我的名子叫".$name;
}
}
?>
到这儿,当我们访问http://localhost/test3/test.php/User/check/tank时。
结果如下:我的名子叫tank,并且地址栏还仍然保持着静态。
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 的安全传输时才有效。
1)、接收和处理Cookie
PHP对Cookie的接收和处理的支持非常好,是完全自动的,跟FORM变量的原则一样,特别简单。
比如设置一个名为 MyCookier的Cookie,PHP会自动从WEB服务器接收的HTTP头里把它分析出来,并形成一个与普通变量一样的变量,名为$ myCookie,这个变量的值就是Cookie的值。数组同样适用。另外一个办法是引用PHP的全局变量$HTTP_COOKIE_VARS数组。
分别举例如下:(假设这些都在以前的页面里设置过了,并且仍然有效)
echo $MyCookie;
echo $CookieArray[0];
echo $_COOKIE["MyCookie"];
echo $HTTP_COOKIE_VARS["MyCookie"];
?>
2)、删除Cookie
要删除一个已经存在的Cookie,有两个办法:
2、SetCookie("Cookie", "value" , time()-1 / time() );
3)、使用Cookie的限制
1、必须在HTML文件的内容输出之前设置;
2、不同的浏览器对Cookie的处理不一致,且有时会出现错误的结果。
3、限制是在客户端的。一个浏览器能创建的Cookie数量最多为30个,并且每个不能超过4KB,每个WEB站点能设置的Cookie总数不能超过20个。
3、Session的配置与应用
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>