PHP仿博客园 个人博客(1) 数据库与界面设计


Posted in PHP onJuly 05, 2013

自学PHP大半年多了,断断续续地,但是最终还是坚定了我的想法,将PHP继续下去,所以写这个PHP的博客是为了找个稳定的 PHP工作,不求工资多高,但求一收留之地。我能看懂大部分英语文档,人不蠢,爱学习,有兴趣地可以联系下!有诚意的来吧!qq:240382473
我会分3-5次发布所有关键代码和文档说明,博客后台所有的样式均套用博客园!

说明:

1. 不完全采用MVC架构,但是理念就是这样的。因为还不能写出很稳定的MVC架构。
2.几乎不采用JQUERY AJAX 因为不是特别熟悉,运用起来还不自如,留言本可以用AJAX,没问题。
3.有几个公用类,其他代码均手写,有不足地地方请多多指出,非常感谢。
4.欢迎批评与指导,但是请给出你的理由。

言归正传:先看数据库架构

PHP仿博客园 个人博客(1) 数据库与界面设计

这些表的引擎都是MYISAM, 利于存取。(黄色钥匙表示的是 primary key; 蓝色菱形的表示非空字段; 白色菱形表示的 null 字段) 图中的链接仅表示他们之间有一种潜在关系,无法在操作时关联.因为搜索引擎是 MyISAM。 所以需要联合查询, 以及多表操作。

我会挑最重要的 post , category 2个表中的特别字段来详细说明,其他说重要的。
post:
post_id
category_id varchar(10) 这个是用来索引博文的分类, 这里的category_id 也是字符串类型,所以可以为每一个博文设置多个分类。

type varchar(20) 这个字段是用来区分 随笔(post),文章(article),和日记(diary)的; 同时也是能够 设置为 postDraft, articleDraft ;

visiable 博文是否可见

其他常用字段如 标题,内容,创建时间,最后改动时间,浏览次数,评论次数,标签,允许评论,以及些保留字段。

category:
parent, count_child_number, count_parent_number 用于以后扩展
type 可以分别设置相册、博文、日记的分类
其他常用字段如 名称,描述,创建时间,可见性
comment:
address 用户IP
user_agent 用户浏览器类型

其它字段略...
服务器架构
PHP5.4.2 + MYSQL 5.523 + APACHE 2.2.22 + Windows NT ARIST-PC 6.1 build 7600 (Windows 7 Home Basic Edition) i586 (本地)
博客架构

后台目录:

PHP仿博客园 个人博客(1) 数据库与界面设计

后台目录说明:

assert 存放各种资源 js,css,image
class 存放我们的类 常用类如 数据库操作类,分页类,和我们的大部分model 。。。
extention 存放些扩展 如 mce 的富编辑器
config 存放我们的 配置信息
templates 存放所有的模版(没有采用 smarty)
upload 存放的是相片和其他文件
admin 根目录下会有一些类似的控制器 如 index.php, post.php, article.php, photo.php

我们先看看 admin/config/config.php

<?php 
ini_set( "display_errors", true ); 
date_default_timezone_set( "Asia/Shanghai" ); 
// root and direcotry separate 
define('DS', DIRECTORY_SEPARATOR); 
define('ROOT', dirname(dirname(__FILE__))); // database information 
// need hash 
define( "DB_USERNAME", "****" ); 
define( "DB_PASSWORD", '*****' ); 
define( "DB_NAME", "blog" ); 
// important directory 
define( "CLASS_PATH", "classes" ); 
define( "TEMPLATE_PATH", "templates" ); 
// user imformation 
define( "ADMIN_USERNAME", "admin" ); 
define( "ADMIN_PASSWORD", '$2a$08$wim8kpwHhAKa6MBSsGUMGOYfjkU1xvRKd4Fxwal.wj8dqFboCVSFawim8kpwHhAKa6MBSsGUMGO'); 
// hash and verified the password 
function hasher($info, $encdata = false){ 
$strength = "08"; 
//if encrypted data is passed, check it against input ($info) 
if ($encdata) { 
if (substr($encdata, 0, 60) == crypt($info, "$2a$".$strength."$".substr($encdata, 60))) { 
return true; 
}else { 
return false; 
} 
} else { 
//make a salt and hash it with input, and add salt to end 
$salt = ""; 
for ($i = 0; $i < 22; $i++) { 
$salt .= substr("./ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789", mt_rand(0, 63), 1); 
} 
//return 82 char string (60 char hash & 22 char salt) 
return crypt($info, "$2a$".$strength."$".$salt).$salt; 
} 
} 
function __autoload($className) { 
if (file_exists(ROOT . DS . 'classes' . DS . strtolower($className) . '.class.php')) { 
require_once(ROOT . DS . 'classes' . DS . strtolower($className) . '.class.php'); 
} else { 
/* Error Generation Code Here */ 
} 
}

这里我们定义了一些基本常量,和几个函数。

__autoload() 函数加载 admin/class/ 中的所有类
用 hasher() 函数加密了一个 88位的 不可逆密码, 登录过程就是用config.php 中的常量和 hasher( ) 函数来进行验证。

来看我们的 admin/index.php 后台控制器 这个控制器主页 显示一些博客的相关数据

<?php 
require_once( "config/config.php" ); 
session_start( ); 
$action = isset( $_GET['action'] ) ? $_GET['action'] : ""; 
$username = isset( $_SESSION['username'] ) ? $_SESSION['username'] : ""; if ( $action != "login" && $action != "logout" && !$username ) { 
login(); 
exit; 
} 
switch( $action ){ 
case "login" : 
login( ) ; 
break; 
case "logout"; 
logout( ); 
break; 
default : 
admin( ); 
break; 
} 
function login( ){ 
$results['pageTitle'] = "Login Form"; 
// handle login 
if( isset( $_POST['login'] ) ){ 
// we simple verify it from constant variable 
// if we need to verify the user from database , do this later 
// $user = new User ; 
// $user->isValidateUser( $name, $password ); 
if ( $_POST['username'] == ADMIN_USERNAME && $_POST['password'] == hasher($_POST['password'], ADMIN_PASSWORD ) ){ 
// register a session data 
$_SESSION['username'] = ADMIN_USERNAME ; 
// location to admin page 
header( "Location: index.php"); 
} else { 
// Login failed: display an error message to the user 
$results['errorMessage'] = "Incorrect username or password. Please try again."; 
require( TEMPLATE_PATH . "/loginForm.php" ); 
} 
} else { 
require( TEMPLATE_PATH . "/loginForm.php" ); 
} 
} 
function admin( ){ 
$results['pageTitle'] = "Administrator Page"; 
require( TEMPLATE_PATH . "/admin.php" ); 
} 
function logout( ){ 
$results['pageTitle'] = "Login Page"; 
unset( $_SESSION['username'] ); 
header( "Location: index.php "); 
}

这个设计模式是从一个老外那里学的!

原理就是:
首先我们加载我们的config.php, 初始化session变量,获得 $action 这个重要变量的值;
然后我们判断 $action 和 $username 的值, 如果用户没有登录以及用户名为空,返回登录页面;
如果用户正确输入了用户名和密码,则注册一个session 变量 $username,然后跳转到主页面 index.php, 这时我们会调用默认的 $action admin( ), 这个函数会加载一个模版admin.php;里面有个数组变量 $results['pageTitle'],以及我们的后台博客样式框架。
如果用户输入错了,则给出提示信息。

这个设计理念的核心就是, give {action} then {do something}
我们会在后面的代码中反复看到。

这个就是博客后台的框架样式,从博客园copy 来的,采用表格布局的,兼容的,可自定义其他样式的,简单的,实用的,可扩展的,完美后台框架。

PHP仿博客园 个人博客(1) 数据库与界面设计

这个样式在其他的浏览器中表现同样兼容,写这篇博文的时候,我已完成了部分功能。 下一篇:实现随笔,文章,日记 以及他们分类的CRUD。

ps:这些操作还没有使用ajax,因为我对ajax还不熟悉。

PHP 相关文章推荐
使用 php4 加速 web 传输
Oct 09 PHP
PHP 开发工具
Dec 06 PHP
PHP高自定义性安全验证码代码
Nov 27 PHP
php GUID生成函数和类
Mar 10 PHP
php截取字符串函数substr,iconv_substr,mb_substr示例以及优劣分析
Jun 10 PHP
推荐一本PHP程序猿都应该拜读的书
Dec 31 PHP
php缓冲输出实例分析
Jan 05 PHP
PHP进程同步代码实例
Feb 12 PHP
PHP封装的MSSql操作类完整实例
May 26 PHP
thinkPHP5.0框架引入Traits功能实例分析
Mar 18 PHP
Laravel 中使用简单的方法跟踪用户是否在线(推荐)
Oct 30 PHP
Laravel5.1 框架数据库操作DB运行原生SQL的方法分析
Jan 07 PHP
PHP cdata 处理(详细介绍)
Jul 05 #PHP
PHP的基本常识小结
Jul 05 #PHP
深入解析fsockopen与pfsockopen的区别
Jul 05 #PHP
在windows平台上构建自己的PHP实现方法(仅适用于php5.2)
Jul 05 #PHP
php中如何同时使用session和cookie来保存用户登录信息
Jul 05 #PHP
php记录代码执行时间(实现代码)
Jul 05 #PHP
如何修改和添加Apache的默认站点目录
Jul 05 #PHP
You might like
德生H-501的评价与改造
2021/03/02 无线电
php笔记之:AOP的应用
2013/04/24 PHP
用JTrackBar实现的模拟苹果风格的滚动条
2007/08/06 Javascript
网页源代码保护(禁止右键、复制、另存为、查看源文件)
2012/05/23 Javascript
jquery 中多条件选择器,相对选择器,层次选择器的区别
2012/07/03 Javascript
JS弹出层单纯的绝对定位居中示例代码
2014/02/18 Javascript
js判断移动端是否安装某款app的多种方法
2015/12/18 Javascript
使用vue.js开发时一些注意事项
2016/04/27 Javascript
Javascript 6里的4个新语法
2016/08/25 Javascript
jQuery简单实现列表隐藏和显示效果示例
2016/09/12 Javascript
Bootstrap基本样式学习笔记之表单(3)
2016/12/07 Javascript
js 实现获取name 相同的页面元素并循环遍历的方法
2017/02/14 Javascript
bootstrap multiselect 多选功能实现方法
2017/06/05 Javascript
Vue中computed与methods的区别详解
2018/03/24 Javascript
Angular搜索场景中使用rxjs的操作符处理思路
2018/05/30 Javascript
微信小程序登陆注册功能的实现代码
2019/12/10 Javascript
[10:07]2014DOTA2国际邀请赛 实拍选手现场观战DK对阵Titan
2014/07/12 DOTA
Python简单操作sqlite3的方法示例
2017/03/22 Python
基于python 爬虫爬到含空格的url的处理方法
2018/05/11 Python
Python给图像添加噪声具体操作
2019/03/03 Python
Django 中间键和上下文处理器的使用
2019/03/17 Python
详解Python中的内建函数,可迭代对象,迭代器
2019/04/29 Python
matplotlib quiver箭图绘制案例
2020/04/17 Python
Python如何实现机器人聊天
2020/09/10 Python
法国发饰品牌:Alexandre De Paris
2018/12/04 全球购物
什么是WEB控件?使用WEB控件有哪些优势?
2012/01/21 面试题
最新销售员个人自荐信
2013/09/21 职场文书
给排水工程师岗位职责
2013/11/21 职场文书
网络维护中文求职信
2014/01/03 职场文书
秋季开学典礼主持词
2014/03/19 职场文书
代办社保委托书范文
2014/10/06 职场文书
县委党的群众路线教育实践活动工作情况报告
2014/10/25 职场文书
2014年采购部工作总结
2014/11/20 职场文书
2016年寒假家长评语
2015/10/10 职场文书
2016师德师风学习心得体会
2016/01/12 职场文书
高三英语教学反思
2016/03/03 职场文书