我正在构建一个 web 应用程序,该应用程序是客户端 js 繁重的,数据从服务器以块的形式推送。
我正在尝试为友好的 URL 解决方案实现一个解决方案,该解决方案采用如下 URL:
这相当于一系列不可见的变量。所以它最终可能会这样处理:
http://exmample.com/index.php?loc=London&type=2&priceCat=10-15
我通过将友好 URL 作为参数传递然后取回完整 URL 来获取值。
我的初始实现使用 mod_rewrite 规则转发到提取友好 url 的脚本,在数据库中查询匹配的友好 url 并返回完整的 url 及其映射到的所有参数,用它构建 url 字符串然后转发到网络然后它将参数提取到 Web 应用程序前端的地址。
但是,当我使用 php header("Location: http://example.com ") 函数时,我会丢失友好的 url,因此他们会看到带有参数的完整 URL。这是我试图满足的次要要求之一。
然后我认为由于我的网络应用程序是 js 很重,我应该尝试渲染页面然后将参数从数据库中 ajax 到我的网络应用程序吗?这是最好的方法还是有另一个我不知道的技巧来实现这一点?
没有启用 js 的客户端不是问题。
附件是一些代码来概述我的初始实现:
//get the friendly url as a parameter
$goto = explode('=',$_SERVER['QUERY_STRING']);
//$goto[1] = SomethingHere-or-there
//build the friendly URL string
$forwardingURL = 'Location:http://'.$_SERVER['HTTP_HOST'].'/'.getForwardedURL($goto[1]);
//will be http://exmample.com/index.php?loc=London&type=2&priceCat=10-15
header($forwardingURL);
//function that returns the full url param string from the friendly url
function getForwardedURL($friendlyURL){
$friendlyURL = mysql_escape_string($friendlyURL);
$query = "
SELECT url
FROM FriendlyURLmapping
WHERE friendly_url = \"$friendlyURL\"";
$resultP = mysql_query($query)
//the full parametised URL will be in $row
$row = mysql_fetch_array($resultP, MYSQL_ASSOC);
return $row["url"];
}