1.根据$_SERVER['PATH_INFO']来操作实现。
举个列子比如你的网站的地址是 http://127.0.0.1/show_new.PHP/look-id-1.shtml
你echo $_SERVER['PATH_INFO'] 出来的结果就会是 /look-id-1.shtml 看到这个我想大家可能已经明白了。
完整的demo
index.PHP
代码如下:
index.PHP
echo "添加新闻
";
echo "echo "
//关闭资源
MysqL_free_result($res);
MysqL_close($conn);
$conn=MysqL_connect("localhost","root","root")or dir("连接失败");
MysqL_select_db("tb_demo",$conn);
$sql="select * from news";
$res=MysqL_query($sql);
header("content-type:text/html;charset=utf-8");
echo "
新闻列表
";echo "添加新闻
";
echo "
MysqL_free_result($res);
MysqL_close($conn);
show_new.PHP页面
代码如下:
show_new.PHP
".$res['content'];
}else{
echo "URL地址不合法";
}
MysqL_close($conn);
header("Content-type:text/html;charset=utf-8");
$conn=MysqL_connect("localhost","root");
MysqL_select_db("tb_demo",$conn);
MysqL_query("set names utf8");
$pa = $_SERVER['PATH_INFO'];
//$pa 打印出来的值是 /look-id-1.html
//通过正则表达式匹配获取的URL地址
if(preg_match('/^\/(look)-(id)-([\d])\.shtml$/',$pa,$arr)){
$act = $arr[1]; //这个是请求的look方法
$id = $arr[3]; //这个是获取的id 值
$sql="select * from news where id= $id";
$res=MysqL_query($sql);
$res = MysqL_fetch_assoc($res);
echo $res['title']."
".$res['content'];
}else{
echo "URL地址不合法";
}
MysqL_close($conn);
看到上面的这个我想大家肯定懂了吧 其实这种方式用的不多的下面的给大家说第二种方法了啊
2.根据配置.htaccess来实现。
先说下.htaccess文件怎么创建吧,在网站根目录下建立个记事本然后双击打开点击另存为 文件名写成 .htaccess ,保存类型选择所有文件,编码选择utf-8的编码好的这是你就在目录看到这个.htaccess文件了首先在apache 开启mod_rewrite.so,AllowOverride None 这里有两处 替换为 AllowOverride All比如href 地址写成 one_new-id-1.shtml //这个意思是one_new.PHP?id=1
这里的.htaccess 就可以这么写了
代码如下:
#写你的rewrite规则
RewriteEngine On
# 可以配置多个规则,匹配的顺序是从上到下
RewriteRule one_new-id-(\d+)\.shtml$ one_new.PHP?id=$1 //这里的$1 代表的是第一个参数啊
RewriteRule abc_id(\d+)\.html$ error.PHP
#设置404错误
#ErrorDocument 404 /error.PHP
你在one_new.PHP 页面echo $_GET['id'] 肯定会输出 id的值了
说明:这个目前个人能力只能写到这里了 我以后会逐渐完善 的
有问题可以给我留言啊