찾다
php教程php手册php 学习笔记:MVC 入口设计与伪静态

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

Jun 06, 2016 pm 08:10 PM
mvcphp입구원래의공부하다메모설계변화공전

原创笔记,转载须注明来源和链接 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进行搜索式匹配,当然,这相对会损耗一些性能。

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)