3.1路由支持自定义
大家都知道SEO的重要性,官方提供的路由不支持随心所遇的自定义URL;在cms项目开发时这个问题是很大的困扰。未解决这个经过反复测试终于修成正果了。
基于官方提供的路由插件小做修改让路由实现自定义。
并不是很完善,可以完全兼容根目录访问。不支持后缀和二级目录!
哪位大神如果感兴趣可以继续修改改善。我是在3.1版本上做的修改,不过大致看了下在3.2版本稍作修改也是通用的。废话不多少直接贴代码了
首先修改下U方法
最终效果显示 例如访问user模块的reg方法 显示结果为 http://ml.topcms.pw/reg 这里的reg你可以自定义随意修改无需配置服务器function U($url='',$vars='',$suffix=true,$redirect=false,$domain=true) {<br>
// 解析URL<br>
$info = parse_url($url);<br>
$url = !empty($info['path'])?$info['path']:ACTION_NAME;<br>
if(false !== strpos($url,'@')) { // 解析域名<br>
list($url,$host) = explode('@',$info['path'], 2);<br>
}<br>
// 解析子域名<br>
if(isset($host)) {<br>
$domain = $host.(strpos($host,'.')?'':strstr($_SERVER['HTTP_HOST'],'.'));<br>
}elseif($domain===true){<br>
$domain = $_SERVER['HTTP_HOST'];<br>
if(C('APP_SUB_DOMAIN_DEPLOY') ) { // 开启子域名部署<br>
$domain = $domain=='localhost'?'localhost':'www'.strstr($_SERVER['HTTP_HOST'],'.');<br>
// '子域名'=>array('项目[/分组]');<br>
foreach (C('APP_SUB_DOMAIN_RULES') as $key => $rule) {<br>
if(false === strpos($key,'*') && 0=== strpos($url,$rule[0])) {<br>
$domain = $key.strstr($domain,'.'); // 生成对应子域名<br>
$url = substr_replace($url,'',0,strlen($rule[0]));<br>
break;<br>
}<br>
}<br>
}<br>
}<br>
<br>
// 解析参数<br>
if(is_string($vars)) { // aaa=1&bbb=2 转换成数组<br>
parse_str($vars,$vars);<br>
}elseif(!is_array($vars)){<br>
$vars = array();<br>
}<br>
if(isset($info['query'])) { // 解析地址里面参数 合并到vars<br>
parse_str($info['query'],$params);<br>
$vars = array_merge($params,$vars);<br>
}<br>
<br>
// URL组装<br>
$depr = C('URL_PATHINFO_DEPR');<br>
if($url) {<br>
if(0=== strpos($url,'/')) {// 定义路由<br>
$route = true;<br>
$url = substr($url,1);<br>
if('/' != $depr) {<br>
$url = str_replace('/',$depr,$url);<br>
}<br>
}else{<br>
if('/' != $depr) { // 安全替换<br>
$url = str_replace('/',$depr,$url);<br>
}<br>
// 解析分组、模块和操作<br>
$url = trim($url,$depr);<br>
$path = explode($depr,$url);<br>
$var = array();<br>
$var[C('VAR_ACTION')] = !empty($path)?array_pop($path):ACTION_NAME;<br>
$var[C('VAR_MODULE')] = !empty($path)?array_pop($path):MODULE_NAME;<br>
if(C('URL_CASE_INSENSITIVE')) {<br>
$var[C('VAR_MODULE')] = parse_name($var[C('VAR_MODULE')]);<br>
}<br>
if(!C('APP_SUB_DOMAIN_DEPLOY') && C('APP_GROUP_LIST')) {<br>
if(!empty($path)) {<br>
$group = array_pop($path);<br>
$var[C('VAR_GROUP')] = $group;<br>
}else{<br>
if(GROUP_NAME != C('DEFAULT_GROUP')) {<br>
$var[C('VAR_GROUP')]= GROUP_NAME;<br>
}<br>
}<br>
if(C('URL_CASE_INSENSITIVE') && isset($var[C('VAR_GROUP')])) {<br>
$var[C('VAR_GROUP')] = strtolower($var[C('VAR_GROUP')]);<br>
}<br>
}<br>
}<br>
}<br>
<br>
if(C('URL_MODEL') == 0) { // 普通模式URL转换<br>
$url = __APP__.'?'.http_build_query(array_reverse($var));<br>
if(!empty($vars)) {<br>
$vars = urldecode(http_build_query($vars));<br>
$url .= '&'.$vars;<br>
}<br>
}else{ // PATHINFO模式或者兼容URL模式<br>
if(C('URL_ROUTER_ON') && (C('URL_MODEL') == 2) && ($var[C('VAR_GROUP')] == '' || $var[C('VAR_GROUP')] == 'Home') ){<br>
$url = __APP__.'?'.http_build_query(array_reverse($var));<br>
if(!empty($vars)) {<br>
$vars = urldecode(http_build_query($vars));<br>
$url .= '&'.$vars;<br>
}<br>
if( is_array(C('URL_ROUTE_RULES')) ){<br>
foreach (C('URL_ROUTE_RULES') as $route_key => $route_val) {<br>
preg_match('#'.$route_val.'$#', $url ,$metches);<br>
if($metches){<br>
$route_url=$metches;<br>
$rule=$route_key;<br>
}<br>
}<br>
if($route_url){<br>
$url_new=explode(':', $rule);<br>
$u=$url_new[0];<br>
for($i=1;$i<count></count>
$u.=$route_url[$i].'/';<br>
}<br>
$u= trim($u,'/');<br>
$url=str_replace ('/', $depr, $u);<br>
}<br>
}<br>
}else{<br>
if(isset($route)) {<br>
$url = __APP__.'/'.rtrim($url,$depr);<br>
}else{<br>
$url = __APP__.'/'.implode($depr,array_reverse($var));<br>
}<br>
if(!empty($vars)) { // 添加参数<br>
foreach ($vars as $v => $val){<br>
if('' !== trim($val)) $url .= $depr . $v . $depr . urlencode($val);<br>
} <br>
}<br>
}<br>
//路由过滤<br>
<br>
if($suffix) {<br>
$suffix = $suffix===true?C('URL_HTML_SUFFIX'):$suffix;<br>
if($pos = strpos($suffix, '|')){<br>
$suffix = substr($suffix, 0, $pos);<br>
}<br>
if($suffix && '/' != substr($url,-1)){<br>
$url .= '.'.ltrim($suffix,'.');<br>
}<br>
}<br>
}<br>
if($domain) {<br>
$url = (is_ssl()?'https://':'http://').$domain.__ROOT__.'/'.$url;<br>
}<br>
<br>
if($redirect) // 直接跳转URL<br>
redirect($url);<br>
else<br>
return $url;<br>
}
其次对应的修改下路由行为这里我直接把文件附在下面。有兴趣的可以下载看看。
具体效果可以看本人做的项目
http://ml.topcms.pw
CheckRouteBehavior.class.php.zip
( 2.72 KB 下载:40 次 )
AD:真正免费,域名+虚机+企业邮箱=0元

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

了解Python程式設計的入門程式碼範例Python是一種簡單易學,功能強大的程式語言。對於初學者來說,了解Python程式設計的入門級程式碼範例是非常重要的。本文將為您提供一些具體的程式碼範例,幫助您快速入門。列印HelloWorldprint("HelloWorld")這是Python中最簡單的程式碼範例。 print()函數用於將指定的內容輸出

《Go語言程式設計實例:Web開發中的程式碼範例》隨著網路的快速發展,Web開發已成為各行業中不可或缺的一部分。作為一門功能強大且效能優越的程式語言,Go語言在Web開發中越來越受到開發者們的青睞。本文將透過具體的程式碼範例,介紹如何利用Go語言進行Web開發,讓讀者更能理解並運用Go語言來建立自己的Web應用。 1.簡單的HTTP伺服器首先,讓我們從一個

PHP變數儲存程式運行期間的值,對於建立動態且互動的WEB應用程式至關重要。本文將深入探討php變量,並透過10個真實的範例展示它們的實際應用。 1.儲存使用者輸入$username=$_POST["username"];$passWord=$_POST["password"];此範例從表單提交中提取使用者名稱和密碼,並將其儲存在變數中以供進一步處理。 2.設定配置值$database_host="localhost";$database_username="username";$database_pa

Java冒泡排序最簡單的程式碼範例冒泡排序是一種常見的排序演算法,它的基本想法是透過相鄰元素的比較和交換來將待排序序列逐步調整為有序序列。以下是一個簡單的Java程式碼範例,示範如何實作冒泡排序:publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

華為雲端邊緣運算對接指南:Java程式碼範例快速實現介面隨著物聯網技術的快速發展和邊緣運算的興起,越來越多的企業開始關注邊緣運算的應用。華為雲端提供了邊緣運算服務,為企業提供了高可靠的運算資源和便利的開發環境,使得邊緣運算應用更容易實現。本文將介紹如何透過Java程式碼快速實現華為雲端邊緣運算的介面。首先,我們需要準備好開發環境。確保你已經安裝了Java開發工具包(

如何使用PHP編寫庫存管理系統中的庫存分倉管理功能碼庫存管理是許多企業中不可或缺的一部分。對於擁有多個倉庫的企業來說,庫存分倉管理功能尤其重要。透過合理管理和追蹤庫存,企業可以實現不同倉庫之間的庫存調撥,優化營運成本,改善協同效率。本文將介紹如何使用PHP編寫庫存分倉管理功能的程式碼,並為您提供相關的程式碼範例。一、建立資料庫在開始編寫庫存分倉管理功能的程式碼之

標題:從入門到精通:Go語言中常用資料結構的程式碼實作資料結構在程式設計中起著至關重要的作用,它是程式設計的基礎。在Go語言中,有許多常用的資料結構,掌握這些資料結構的實作方式對於成為優秀的程式設計師至關重要。本文將介紹Go語言中常用的資料結構,並給出對應的程式碼範例,幫助讀者從入門到精通這些資料結構。 1.數組(Array)數組是一種基本的資料結構,是一組相同類型

Java選擇排序法程式碼編寫指南及範例選擇排序是一種簡單直觀的排序演算法,其想法是每次從未排序的元素中選擇最小(或最大)的元素進行交換,直到所有元素排序完成。本文將提供選擇排序的程式碼編寫指南,並附上具體的Java範例程式碼。演算法原理選擇排序的基本原理是將待排序數組分為已排序和未排序兩部分,每次從未排序部分選擇最小(或最大)的元素,將其放到已排序部分的末尾。重複上述
