有四中方法可以实现PHP的伪静态,你造吗?

说起伪静态的实现方案,你是不是很爽快的回答"简单,配置下apache的重写规则就行了嘛"

但是你有没有发现这种情况,你最近弄了很多新功能,每天上几个新功能,每天都有好多伪静态配置,才开始两天运维同学还乐意配合,过两天运维同学就要骂了。你麻痹,脑残为什么不一次搞完,天天麻烦我。但是了,你要上线啊,不得不苦逼的求运维同学了,然后说出一句程序猿界最不要脸的话"这次最后一次改动了",然后后面又要改,哎,你的人格算是扫地了。。。

 

如果有这样的烦恼存在,请看下面的文章,保证你以后再也不求运维了,想干啥就干啥。。。

 那PHP实现伪静态有多少种方法了?个人见解和统计奥,有四种方法


1、使用apache的URL重写规则,这个大家都懂,在apache里面配置, 这里同学们都造,只列举一段简单的配置

RewriteEngine On
RewriteRule ^/test.html index.php?controller=index&action=test [L]

 

2、使用PHP的pathinfo ,  你是不是有看到有的网站这样玩'www.xxx.com/index.php/c/index/a/test/id/100' , 当然要支持这种你需要把'php.ini' 中的参数

'cgi.fix_pathinfo' 设置为1。拿'www.xxx.com/index.php/c/index/a/test/id/100'来举例

echo $_SERVER['PATH_INFO']; //输出'/c/index/a/test/id/100'

到这,应该明白了吧,你再对这段进行解析,分配实际地址

 

3、使用404机制,一般情况下伪静态都是实际不存在的页面,因此可以使用apache 404配置,但是有些问题,就是'post'类型的请求会被抛弃,导致你无法获取'$_POST',

但是'$_GET'仍然可以获取, 假设此处404页面为'404page.php', apache 配置如下:

ErrorDocument 404 /404page.php

然后在 '404page.php'中嵌入如下代码

header("HTTP/1.1 200 OK"); //这里一定要有,不然状态就是404

$reqUrl = $_SERVER['REQUEST_URI']; // 请求地址

/**
* 从URL中解析参数
*/
function parseUrlParams($queryUrl)
{
    $arr = explode('?', $queryUrl);
    parse_str($arr[1], $param);
    if($param)
    {
        foreach($param as $key => $value)
        {
            $_GET[$key] = $value;
        }
    }
}

parseUrlParams($reqUrl); // url解析参数

//然后你就可以使用 $reqUrl 根据自己的规则匹配不同的实际请求地址
if(preg_match('#^/test.html#is', $reqUrl, $matches))
{
   include('index.php');
   die();
}

 

4、方法3的改进型,方法3在apache内部机制相当于重定向了,导致post(get)传递的参数无法获取。分析上面的其实是找不到相关文件,那当服务器找不到相关文件时,我们为它指定一个文件,不就OK了,它就不用跳转了,这时POST之类都不会丢失。apache 配置如下:

RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . index.php

上面一段配置的大概意思是 当请求的文件或者目录无法找到时 使用根目录下的 'index.php' 替代,那这时你就可以在'index.php'中获取相关参数并解析到实际请求地址

/**
* 获取当前请求的URI地址
*@param void
*@author painsOnline
*@return string URI
*/
function getReqUri()
{
    return trim($_SERVER["REQUEST_URI"]);
}

$reqUri = getReqUri();

if(preg_match('/^\/test.html/isU', $reqUri))
{//解析请求地址
    include 'test.php';
    exit();
}

 

鄙人才疏学浅,有不足之处,欢迎补足

 

转载于:https://www.cnblogs.com/painsOnline/p/5127524.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是C语言模拟实现银行家算法的示例代码,假设有四种资源(A、B、C、D),五个进程(P1、P2、P3、P4、P5): ```c #include <stdio.h> #include <stdbool.h> // 定义资源数量和进程数量 #define NUM_RESOURCES 4 #define NUM_PROCESSES 5 // 定义各个资源的总量和可用量 int available[NUM_RESOURCES] = {10, 5, 7, 8}; int max[NUM_PROCESSES][NUM_RESOURCES] = { {2, 2, 1, 1}, {3, 2, 2, 2}, {1, 2, 1, 3}, {2, 1, 2, 2}, {1, 1, 1, 1} }; int allocation[NUM_PROCESSES][NUM_RESOURCES] = { {2, 1, 0, 1}, {2, 0, 1, 0}, {1, 0, 1, 1}, {1, 0, 1, 0}, {0, 1, 0, 1} }; int need[NUM_PROCESSES][NUM_RESOURCES]; // 检查进程是否可执行 bool is_safe(int process, int work[]) { // 检查是否有足够的资源 for (int i = 0; i < NUM_RESOURCES; i++) { if (need[process][i] > work[i]) { return false; } } return true; } // 执行安全检查 bool safety_algorithm() { // 初始化工作向量和已完成进程集合 int work[NUM_RESOURCES]; for (int i = 0; i < NUM_RESOURCES; i++) { work[i] = available[i]; } bool finish[NUM_PROCESSES] = {false}; // 执行安全检查 int count = 0; while (count < NUM_PROCESSES) { bool found = false; for (int i = 0; i < NUM_PROCESSES; i++) { if (!finish[i] && is_safe(i, work)) { found = true; for (int j = 0; j < NUM_RESOURCES; j++) { work[j] += allocation[i][j]; } finish[i] = true; count++; printf("P%d ", i + 1); break; } } if (!found) { return false; } } return true; } int main() { // 计算各个进程的需求量 for (int i = 0; i < NUM_PROCESSES; i++) { for (int j = 0; j < NUM_RESOURCES; j++) { need[i][j] = max[i][j] - allocation[i][j]; } } // 执行安全检查并输出结果 if (safety_algorithm()) { printf("安全状态,存在安全序列\n"); } else { printf("不安全状态,不存在安全序列\n"); } return 0; } ``` 运行结果为: ``` P5 P1 P4 P3 P2 安全状态,存在安全序列 ``` 说明存在一个安全序列,可以保证所有进程都能够成功执行。如果更改available数组中的某个值,可能会导致无法找到安全序列,从而导致程序输出“不安全状态,不存在安全序列”。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值