欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  php教程

php 学习笔记:MVC 入口设计与伪静态

程序员文章站 2022-05-31 09:42:34
...

原创笔记,转载须注明来源和链接 php开发web程序,MVC模式的入口设计非常关键,常用的著名开源程序如wordpress、discuz都有特别的入口设计,除了要做controller 、action ,路由设计也是被重视的,因为这关系到url的美观和搜索友好度。 wordpress的入口和伪

原创笔记,转载须注明来源和链接

php开发web程序,MVC模式的入口设计非常关键,常用的著名开源程序如wordpress、discuz都有特别的入口设计,除了要做controller 、action ,路由设计也是被重视的,因为这关系到url的美观和搜索友好度。

wordpress的入口和伪静态

以wordpress 为例,http://it.liuhuafang.com/code/2982? ,我们很容易分析到code是分类的alias,2982是文章的id;而http://edu.xiguagg.com/2013-xigua-collage/ 西瓜学院的链接也是一个文章,采用了文章的alias。

网友打开http://it.liuhuafang.com/code/2982 、http://edu.xiguagg.com/2013-xigua-collage/,wordpress的入口文件index.php就要调用入口分析和控制的类,因为url是指向唯一页面的,具有唯一性,否则浏览器也没法运行,所以,数据库设计时候就必要将参与url rewrite 和路由的字段值进行筛选。wordpress选取了category、post_id、post_name等等几个可参与路由的字段,通过设置permalink 固定连接来固化url显示的类型。

wordpress 有rewrite函数来处理多种可能设置的permalink类型的前端请求判断机制,以便能够通过各种Url中提取到关键信息字段值,比如http://edu.xiguagg.com/2013-xigua-collage/ ,wordpress要从permalink设置中的post_name字段中进行搜索2013-xigua-collage,然后返回post_id,这样就可以通过post_id调用出文章内容页面需要展示的各类相关信息。

discuz的入口设计和伪静态

discuz是多入口文件模式设计,他们把portal、forum、group、home相对独立地进行入口控制和引导,这带来了伪静态的复杂性,所以官方默认伪静态规则设为http://www.xxx.com/forum-7-1.html这样的参数裸露式的url,而没有去像wordpress那样去做permalink池的关联设计。当然,这跟产品的需求不同,wordpress多用于个人博客,访问请求量通常很少;而discuz用于讨论区,存在很多并发请求,访问量规模一旦提升,对于成本来说是一个大挑战,所以,discuz选择了牺牲个性化的这种方式。

当然,很多站长开始喜欢简洁网址,比如http://bbs.jiabao.org/baixing/1 ,这是域名+分类别名+帖子id的目录化伪静态结构,如果网站信息量很大,这种结构让网站内部结构扁平一些,会搜索友好一些,但是,这是违背discuz路由系统设计的思想的。

你打开家宝社区的链接,你会发现,这是一个帖子,而事实上,你社区首页版块分类点击版块竟然到了这里,这是什么原因呢?

因为追求扁平化目录,bbs.jiabao.org/baixing/2 这样的url可能是某版块的分页,也可能是某个帖子链接,这样子入口选择无法判别路由了,如何解决这个问题呢?

我在想:一方面,将帖子url改成 bbs.jiabao.org/baixing/2.html? 与版块的rewrite规则进行区别,如果就是非要bbs.jiabao.org/baixing/222 这样的帖子url,要么开始把其实thread id 通过sql 弄个很大的位数,让版块fid永远不太可能和帖子tid 的值冲突;要么,就要改动程序设计,将版块和帖子的重写规则进行唯一性绑定,解决入口无法识别出是主题列表分页url还是帖子url。

论坛主题列表页 {fid}, {page}
论坛主题内容页 {tid}, {page}, {prevpage}

终极的解决方案应该是这样:将主题链接和主题内容的rewrite前段入口和路由控制统一,解决版块首页的clean url ,分页加上page等辅助参数,这样bbs.jiabao.org/baixing/2 从浏览器提交到服务器,htaccess 识别引导到动态Php入口文件,并指向帖子页面。所以,{fid}/t{tid}/{page} 、{fid}/{page} 帖子页面和主题链接页面必须有个带辅助参数,否则fid tid进行严格唯一性去重,对fid tid进行搜索式匹配,当然,这相对会损耗一些性能。