基于mysql的bbs设计(一)


Posted in PHP onOctober 09, 2006

1。系统架构:
  采用模块化思想,分为3层:
  a。数据存储层:使用mysql来存放bbs的所有数据,包括用户信息,
    文章数据,用户信件,用户消息,系统数据(?),关键问题:
    数据库的规划,是否用文件来辅助。
  b。系统功能层:完成bbs的基本功能,由多个并列模块组成,向下
    调用mysql的函数访问数据库,向上,接受处理请求,将处理的
    结果返回上层,根据请求类型,返回成败结果和其他数据。而且
    模块高度灵活,可以方便的修改增加。包括:
    ** 用户模块,处理用户的注册,基本数据的修改,权限的变化,
     网友信息的查询。
    ** 版面模块,完成文章发表,文章的读取,文章的删除,文章
     的加标记,读改删权限检查,此模块对数据库的要求最高。
    ** 精华区模块,包括精华区的文章,目录的增加,删除,上下移     动
(?)读改删权限检查,目录结构是其中的难点。
    ** 信件模块,包括发新信件,读删信件,信笺标记,新信件的通
     知
    ** 消息模块,包括发送消息,接受消息,新消息通知,消息回顾,
     消息存信件。
    ** 系统动态模块,包括当前上站人数,当前动态,由于变动频繁,
     此类数据用共享内存实现可能更好。
    ** 聊天模块,双人聊天是否能借鉴icq的做法,由双方直接通话,
     但聊天结果存信件可能较麻烦,同时,为兼容telnet功能,当
     上层服务层为telnet时,增加专门的模块来进行处理。
    ** 聊天室模块,利用共享内存还是数据库?开房间,里面的权限
     问题。
     根据需要,还能增加新的功能。例如:活动看板模块,但对于非
    telnet终端,意义好象不大。。。。。
  c。服务层:直接和客户机对话,根据客户机的请求,调用功能模块取得
    数据,然后将数据发送回客户端,根据客户端的类型,分别开发不同
    的服务模块,并且尽可能合理进行抽象,使对不同的服务层,能共用
    系统功能层的模块。具体包括:
    ++ cq66服务端,采取原cq66的方式,并重新规划协议,支持系统功能
     层的所有功能,但要用专门的客户端程序(cq66),如果能做到向
     下兼容则更好,客户端程序要随服务端的升级而升级,用户可能有
     点不便。有需要可以在传输过程中加入加密功能,类似ssh。
    ++ telnet服务端,采用旧bbs的方式,有些功能不支持,客户端无须
     升级,服务器端要保存客户方的状态,并根据客户端的按键来判断
     状态的转移,并由此得出所需的数据,(例如阅读某篇文章),然
     后再向系统功能层请求数据,然后将数据加以处理(例如加上顶行,
     尾行)然后返回数据,可以在现有的bbsd上修改,可以省去io模块
     的设计但难度较大,除文章方面好一点外,其他比较难改,但从头
     写起太费力。
    ++ httpd服务端,所需的功能更少,相对较简单,本来直接调用mysql
     数据库也行,直接可以用php,但考虑到分层的原则,建议仍用c编
     cgi的方式实现不知能不能在原来的基础上修改呢?估计不行。
  系统的关键和难点:
  a。数据库的设计,mysql支持大量的table吗?例如几万?每个
    用户至少一个表,然后每个版一个表,精华区的表结构可能更复杂。
    但应该总会比现在bbs的文件结构清晰一些,效率也高一点吧,排序
    和cache的功能可以信赖mysql吧。
  b。mysql中文本字段的大小限制,限制一篇文章不得大于64k不过分吧,
    而且从效率的角度,将一篇文章以最大2k的块为单位存放可能更好,
    这样,当telnet用户看文章时,telnet服务器不用每次都查询数据库
    读取几十k的数据,再将其中的某2k传给用户,可局部补偿数据库字段
    不能象文件那样从中间读取一部分。不过这样文章字段数据的管理
    比较复杂。
2。系统开发计划:
  先考虑用户模块和版面模块,规划好数据结构,应该很容易和现有bbsd结合
起来的。然后再考虑其他模块?。。。。。。。
(//以下有空再写。。。。。先睡觉去。。hmm.........)
3。数据库设计
4。用户模块设计
5。版面模块设计
6。bbsd和cq66服务器端改造
7。初步测试计划 。

PHP 相关文章推荐
php实现加减法验证码代码
Feb 14 PHP
php操作MongoDB基础教程(连接、新增、修改、删除、查询)
Mar 25 PHP
PHP下的Oracle客户端扩展(OCI8)安装教程
Sep 10 PHP
PHP中通过fopen()函数访问远程文件示例
Nov 18 PHP
php不使用copy()函数复制文件的方法
Mar 13 PHP
php实现上传图片文件代码
Jul 19 PHP
使用PHP实现生成HTML静态页面
Nov 18 PHP
Yii2设置默认控制器的两种方法
May 19 PHP
PHP 年月日的三级联动实例代码
May 24 PHP
PHP设计模式之原型模式定义与用法详解
Apr 03 PHP
PHP进阶学习之类的自动加载机制原理分析
Jun 18 PHP
Laravel 错误提示本地化的实现
Oct 22 PHP
基于mysql的bbs设计(二)
Oct 09 #PHP
基于mysql的bbs设计(三)
Oct 09 #PHP
支持oicq头像的留言簿(一)
Oct 09 #PHP
NT IIS下用ODBC连接数据库
Oct 09 #PHP
怎样在UNIX系统下安装php3
Oct 09 #PHP
怎样在UNIX系统下安装MySQL
Oct 09 #PHP
关于文本留言本的分页代码
Oct 09 #PHP
You might like
全国FM电台频率大全 - 9 上海市
2020/03/11 无线电
php Smarty date_format [格式化时间日期]
2010/03/15 PHP
比较strtr, str_replace和preg_replace三个函数的效率
2013/06/26 PHP
php中get_meta_tags()、CURL与user-agent用法分析
2014/12/16 PHP
PHP进阶学习之反射基本概念与用法分析
2019/06/18 PHP
thinkphp5 框架结合plupload实现图片批量上传功能示例
2020/04/04 PHP
基于jquery实现的鼠标拖拽元素复制并写入效果
2011/08/23 Javascript
JS解决url传值出现中文乱码的另类办法
2013/04/08 Javascript
jQuery中:enabled选择器用法实例
2015/01/04 Javascript
基于jQuery实现自动轮播旋转木马特效
2015/11/02 Javascript
AngularJS入门教程之表单校验用法示例
2016/11/02 Javascript
AngularJS的ng-repeat指令与scope继承关系实例详解
2017/01/21 Javascript
从零开始做一个pagination分页组件
2017/03/15 Javascript
Popup弹出框添加数据实现方法
2017/10/27 Javascript
[02:41]《西雅图我们来了》2015国际邀请赛出征全记录
2015/07/23 DOTA
[00:35]2016完美“圣”典风云人物:冷冷宣传片
2016/12/08 DOTA
[47:04]EG vs RNG 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/18 DOTA
Python OS模块常用函数说明
2015/05/23 Python
Python实现将目录中TXT合并成一个大TXT文件的方法
2015/07/15 Python
Python简单实现安全开关文件的两种方式
2016/09/19 Python
python调用pyaudio使用麦克风录制wav声音文件的教程
2019/06/26 Python
python opencv对图像进行旋转且不裁剪图片的实现方法
2019/07/09 Python
pytorch 实现删除tensor中的指定行列
2020/01/13 Python
Python MySQL 日期时间格式化作为参数的操作
2020/03/02 Python
Django bulk_create()、update()与数据库事务的效率对比分析
2020/05/15 Python
python连接手机自动搜集蚂蚁森林能量的实现代码
2021/02/24 Python
css3学习之2D转换功能详解
2016/12/23 HTML / CSS
美国婴儿服装购物网站:Gerber Childrenswear
2020/05/06 全球购物
《三袋麦子》教学反思
2014/03/02 职场文书
听课评语大全
2014/04/30 职场文书
关于读书的演讲稿400字
2014/08/27 职场文书
五一劳动节演讲稿
2014/09/12 职场文书
党干部专题民主生活会对照检查材料思想汇报
2014/10/06 职场文书
2014年妇幼保健工作总结
2014/12/08 职场文书
大学军训决心书
2015/02/05 职场文书
Python中的变量与常量
2021/11/11 Python