|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
exit来实现结束后面的PHP语句的执行,缩小调试范围,特别是数据库交互的程序,先输出个SQL语句看看,对了,再分析怎么会插入/删除不成功呢?这样对查错很有帮助。 /*************************/
/* author:大龄青年
/* email :wenadmin@sina.com
/* from: http://blog.csdn.net/hahawen
/*************************/
原代码下载: http://club.phpe.net/index.php?s=&act=Attach&type=post&id=29432
(最近帮很多网友改法式,发明一个成绩,就是人人用php开辟设计形式的十分的凌乱,所以写下这篇文章,但愿对人人都有匡助)
php作为“最复杂”的Web剧本言语, 在国际的市场愈来愈大,phper愈来愈多,然而感到大多半人仿佛没有思索到形式成绩,甚么样的设计形式才是最优的,才是最合适本人今朝任务的,究竟效力是最主要的(用省下的工夫打游戏,多美啊...)。MVC应当是首选,www.sourceforge.net 上有很多多少优异的基于MVC的开源项目,人人可以冲曩昔研讨研讨。
头几天给本人公司网站改版,次要仍是文章宣布体系,老板说后台我想怎样设计就怎样设计,独一的条件就是快。因而本人搭建了一个复杂的宣布体系的框架。假如纯真从文章宣布体系上讲,根基上可以知足“中小型”企业网站的文章宣布体系的请求,后台的总共的php代码不超越800行,并且撑持恣意扩大和plugin功效。
空话不再说了,上面把我的架构讲一下,但愿对您能有所匡助。
注重:在入手下手前,需求您下载一个模板处置东西类:“smarttemplate”,并懂得一些模板的复杂的利用。
我的测试情况:windows2k/apache2/php4.3.2/smarttemplate类库
先讲一下全部web站点的文件的散布,在前面的章节中将陆续创立并填充上面的目次和文件
我的办事器的web的根目次是 “C:/Apache2/htdocs/”
我鄙人面创立了一个文件夹“cmstest”作为我的网站的主文件夹
文件夹“cmstest”上面的子文件布局是:
/config.inc.php
/list1.php
/list2.php
/new.php
/add.php
/view.php
/page.js
/src/MysqlUtil.php
/src/ArticleUtil.php
/src/CoreUtil.php
/src/ParseTpl.php
/src/lib/smarttemplate/*.* 这个目次用来寄存smarttemplate的类库的
/smart/template/list1.htm
/smart/template/list2.htm
/smart/template/new.htm
/smart/template/add.htm
/smart/template/view.htm
/smart/cache/
/smart/temp/
设计步调:
1、思索本人公司的网站的特色和已设计的模板的布局,总结要完成的功效,列出清单。
2、剖析功效清单,把功效分类。每类的功效都是有配合点的,可以经由过程不异的办法完成的。
3、依据功效,设计数据库的表布局
4、设计一个设置装备摆设文件config.inc.php, 用来纪录网站的一些根基的信息,包含数据库名........
5、为每类功效设计数据库查询的接口函数,如许今后类似的操作只需挪用这个接口就能够了。如许防止了今后能够产生的大批的代码反复的操作,也就到达了代码复用的目标。
6、界说本人对模板东西的包装函数,今后挪用的时分就不必管模板东西的利用成绩了,只要往本人的包装函数外面塞数就能够了。
7、基本函数已ok了,入手下手轻松的页面完成和模板的处置了。
咱们如今就入手下手设计一个复杂的体系,看看我是怎样一步一步地完成一个“最复杂的文章的宣布体系”的,固然只是我摹拟的一个复杂的项目,实践中一个项目能够比这要庞杂的多。
1、剖析我的案例:
呵呵,这个客户项目好复杂的啊,幸福ing..........
list1.php:有三个文章列表和一个按钮,“php开辟文章列表”“php开辟热门文章列表”“asp开辟最新文章”“添加新文章”
list2.php:有2个文章列表“asp开辟文章列表”“asp开辟热门文章列表”
new.php: 一个添加文章的表单的页面
add.php: 处置new.php的表单的页面
view.php: 文章观察的页面
2、剖析功效
“php开辟文章列表”“asp开辟文章列表”-------按文章的宣布按次,倒序分列显示,每页显示5篇文章
“php开辟热门文章列表”“asp开辟热门文章列表”-------按文章的点击观察次数排序显示文章,显示3篇文章
“asp开辟最新文章”按文章的宣布按次,倒序分列显示,显示3篇文章
“添加新文章”------一个文章的宣布功效, 包含文章题目/作者/内容
“文章观察”---------显示某篇文章内容
综合的看一下,对功效停止分类包含:
1、文章列表:正常的分页列表、按点击数列表、按宣布按次的列表
2、文章宣布:一个表单的输出和处置
3、文章观察:读取显示文章内容
呵呵,功效切实其实是太复杂了些。
3、设计数据库:
数据库名:cmstest
数据表:
CREATE TABLE `article` (
`id` INT NOT NULL AUTO_INCREMENT,
`title` VARCHAR( 100 ) NOT NULL ,
`content` TEXT NOT NULL ,
`datetime` DATETIME NOT NULL ,
`clicks` INT( 11 ) ,
`pid` TINYINT( 2 ) NOT NULL ,
PRIMARY KEY ( `id` )
);
CREATE TABLE `cat` (
`cid` TINYINT( 2 ) NOT NULL ,
`cname` VARCHAR( 20 ) NOT NULL ,
PRIMARY KEY ( `cid` )
);
------------------------------
article表是文章内容表,
----------------------------
`id` 文章编号
`title` 文章题目
`content` 文章内容
`datetime` 宣布工夫
`clicks` 点击数
`pid` 分类表号
------------------------------
cat表是文章的种别表
----------------------------
`cid` 分类表号
`cname` 分类称号
----------------------------
下面是表的数据库布局,光有了这些还不敷,还要无数据
INSERT INTO `cat` VALUES(1, "php开辟"),(2, "asp开辟");
INSERT INTO `article` VALUES(1, "php开辟1", "php开辟1内容", "2004-8-1 1:1:1", 0, 1);
INSERT INTO `article` VALUES(2, "php开辟2", "php开辟2内容", "2004-8-2 1:1:1", 0, 1);
INSERT INTO `article` VALUES(3, "php开辟3", "php开辟3内容", "2004-8-3 1:1:1", 4, 1);
INSERT INTO `article` VALUES(4, "php开辟4", "php开辟4内容", "2004-8-4 1:1:1", 3, 1);
INSERT INTO `article` VALUES(5, "php开辟5", "php开辟5内容", "2004-8-5 1:1:1", 2, 1);
INSERT INTO `article` VALUES(6, "php开辟6", "php开辟6内容", "2004-8-6 1:1:1", 1, 1);
INSERT INTO `article` VALUES(7, "php开辟7", "php开辟7内容", "2004-8-7 1:1:1", 0, 1);
INSERT INTO `article` VALUES(8, "jsp开辟1", "jsp开辟1内容", "2004-8-1 1:1:1", 0, 2);
INSERT INTO `article` VALUES(9, "jsp开辟2", "jsp开辟2内容", "2004-8-2 1:1:1", 0, 2);
INSERT INTO `article` VALUES(10, "jsp开辟3", "jsp开辟3内容", "2004-8-3 1:1:1", 4, 2);
INSERT INTO `article` VALUES(11, "jsp开辟4", "jsp开辟4内容", "2004-8-4 1:1:1", 3, 2);
INSERT INTO `article` VALUES(12, "jsp开辟5", "jsp开辟5内容", "2004-8-5 1:1:1", 2, 2);
INSERT INTO `article` VALUES(13, "jsp开辟6", "jsp开辟6内容", "2004-8-6 1:1:1", 1, 2);
INSERT INTO `article` VALUES(14, "jsp开辟7", "jsp开辟7内容", "2004-8-7 1:1:1", 0, 2);
如许咱们的数据库就设计完了。接上去就入手下手触及到详细的完成了。
4、设计config.inc.php文件
这个文件用来设置一些web上通用的数据信息和一些参数,其他的详细的完成页面都经由过程这个页面获得需求的数据,上面是设置装备摆设的清单
<P><FONT style="BACKGROUND-COLOR: #d3d3d3"> |
|