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 相关文章推荐
资料注册后发信小技巧
Oct 09 PHP
封装一个PDO数据库操作类代码
Sep 09 PHP
Linux fgetcsv取得的数组元素为空字符串的解决方法
Nov 25 PHP
php通过COM类调用组件的实现代码
Jan 11 PHP
基于simple_html_dom的使用小结
Jul 01 PHP
PHP中读取文件的8种方法和代码实例
Aug 05 PHP
两千行代码的PHP学习笔记汇总
Oct 05 PHP
PHP判断浏览器、判断语言代码分享
Mar 05 PHP
php的4种常用运行方式详解
Dec 22 PHP
Laravel接收前端ajax传来的数据的实例代码
Jul 20 PHP
php连接MSsql server的五种方法总结
Mar 04 PHP
laravel http 自定义公共验证和响应的方法
Sep 29 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
DOTA2 探索永无止境 玩家自创强悍插眼攻略
2020/04/20 DOTA
PHP和Mysqlweb应用开发核心技术 第1部分 Php基础-3 代码组织和重用2
2011/07/03 PHP
基于PHP生成静态页的实现方法
2013/05/10 PHP
jQuery+php实现ajax文件即时上传的详解
2013/06/17 PHP
Laravel 5框架学习之Laravel入门和新建项目
2015/04/07 PHP
PHP pear安装配置教程
2016/05/14 PHP
thinkPHP5框架闭包函数与子查询传参用法示例
2018/08/02 PHP
php实现根据身份证获取精准年龄
2020/02/26 PHP
php框架知识点的整理和补充
2021/03/01 PHP
html下载本地
2006/06/19 Javascript
在javascript中如何得到中英文混合字符串的长度
2014/01/17 Javascript
jquery 无限极下拉菜单的简单实例(精简浓缩版)
2016/05/31 Javascript
canvas 画布在主流浏览器中的尺寸限制详细介绍
2016/12/15 Javascript
js制作可以延时消失的菜单
2017/01/13 Javascript
详解angularjs 关于ui-router分层使用
2017/06/12 Javascript
VUE实现一个分页组件的示例
2017/09/13 Javascript
js 图片转base64的方式(两种)
2018/04/24 Javascript
Angular6中使用Swiper的方法示例
2018/07/09 Javascript
vue Treeselect 树形下拉框:获取选中节点的ids和lables操作
2020/08/15 Javascript
python3 判断列表是一个空列表的方法
2018/05/04 Python
python爬取网页内容转换为PDF文件
2020/07/28 Python
Python实现的从右到左字符串替换方法示例
2018/07/06 Python
解决Atom安装Hydrogen无法运行python3的问题
2019/08/28 Python
python os.path.isfile 的使用误区详解
2019/11/29 Python
Python3中configparser模块读写ini文件并解析配置的用法详解
2020/02/18 Python
python怎么调用自己的函数
2020/07/01 Python
用python实现前向分词最大匹配算法的示例代码
2020/08/06 Python
基于python爬取梨视频实现过程解析
2020/11/09 Python
html5触摸事件判断滑动方向的实现
2018/06/05 HTML / CSS
Under Armour安德玛英国官网:美国高端运动科技品牌
2018/09/17 全球购物
Python的两道面试题
2013/06/29 面试题
建筑管理专业求职信
2014/07/28 职场文书
放飞梦想演讲稿200字
2014/08/26 职场文书
沙滩主题婚礼活动策划方案
2014/09/15 职场文书
三十年同学聚会感言
2015/07/30 职场文书
Python基础之元类详解
2021/04/29 Python