PHP教程之发明世界上最复杂的------php开辟形式
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"> 作为一个合格的coder 编码的规范是必须,命名方面我推崇“驼峰法”,另外就是自己写的代码最好要带注释,不然时间长了,就算是自己的代码估计看起来都费事,更不用说别人拉。 对于初学者来说不推荐去拿钱买的。当然如果一个网站你经常去用,而且里面的资料也比较有用,最好还是买个会员比较好,毕竟那些也是别人的工作成果。 本人接触php时间不长,算是phper中的小菜鸟一只吧。由于刚开始学的时候没有名师指,碰过不少疙瘩,呗很多小问题卡过很久,白白浪费不少宝贵的时间,在次分享一些子的学习的心得。 这些都是最基本最常用功能,我们这些菜鸟在系统学习后,可以先对这些功能深入研究。 我学习了一段时间后,我发现效果并不好(估计是我自身的问题)。因为一个人的精力总是有限的,同时学习这么多,会导致每个的学习时间都得不到保证。 这些都是最基本最常用功能,我们这些菜鸟在系统学习后,可以先对这些功能深入研究。 因为blog这样的可以让你接触更多要学的知识,可以接触用到类,模板,js ,ajax 最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。 爱上php,他也会爱上你。 说php的话,首先得提一下数组,开始的时候我是最烦数组的,总是被弄的晕头转向,不过后来呢,我觉得数组里php里最强大的存储方法,所以建议新手们要学好数组。 先学习php和mysql,还有css(html语言很简单)我认为现在的效果比以前的方法好。 有时候汉字的空格也能导致页面出错,所以在写代码的时候,要输入空格最好用引文模式。 我要在声明一下:我是个菜鸟!!我对php这门优秀的语言也是知之甚少。但是我要在这里说一下php在网站开发中最常用的几个功能: 学习php的目的往往是为了开发动态网站,phper就业的要求也涵盖了很多。我大致总结为:精通php和mysql 小鸟是第一次发帖(我习惯潜水的(*^__^*) 嘻嘻……),有错误之处还请大家批评指正,另外,前些日子听人说有高手能用php写驱动程序,真是学无止境,人外有人,天外有天。 先学习php和mysql,还有css(html语言很简单)我认为现在的效果比以前的方法好。 建数据库表的时候,int型要输入长度的,其实是个摆设的输入几位都没影响的,只要大于4就行,囧。 说点我烦的低级错误吧,曾经有次插入mysql的时间 弄了300年结果老报错,其实mysql的时间是有限制的,大概是到203X年具体的记不清啦,囧。 小鸟是第一次发帖(我习惯潜水的(*^__^*) 嘻嘻……),有错误之处还请大家批评指正,另外,前些日子听人说有高手能用php写驱动程序,真是学无止境,人外有人,天外有天。
页:
[1]