在开始设计一个asp站点的时候,面对着一大堆的问题,到底要怎么样入手,才能让网站设计做到快,好,而且调试、更改,移植起来又方便呢?下面以留言本的设计为例子,谈谈站点的设计。
(一)站点的功能
“磨刀不误砍柴工”,先写出站点的功能,对以后的工作有很大的帮助。现在来设计一个留言本,功能如下:
1、单用户版。只有一个管理员,所有人都可以留言,可以搜索留言
2、记录下每个留言者的 ip,QQ,头像,姓名,主页,电子邮件,留言时间,留言内容;
3、有管理员回复功能。如果已经回复,还可以更改回复的内容。记录回复的时间;
4、记录主页的位置,以便快速回到主页。
5、自定义的页头和页脚。显示特定的信息。
6、将数据存到access数据库
7、管理功能:管理员登录/回复/删除/更改管理员密码/更改显示的留言数/更改主页
(二)站点数据库
一般ASP站点都要用到数据库,首先设计好数据库,在使用时才不会为了一个字段而去查询或更改数据库的设计。特别是对大型的网站,好的数据库设计可以影响到整个网站的运行情况。现在我们来设计留言本的数据库:
1、数据库名:lyb.mdb
2、表:共有二个表
表一: admin
字段名 |
类型 |
长度 |
其它 |
说明 |
admin_user |
文本 |
15 |
不允许空值/主键 |
管理员用户名 |
admin_pass |
文本 |
15 |
不允许空值 |
管理员密码 |
admin_http |
文本 |
50 |
可为空值 |
主页地址 |
admin_perpage |
数字/整型 |
|
小数为0 |
|
表二: main
字段名 |
类型 |
长度 |
其它 |
说明 |
user_id |
自动编号 |
|
|
|
user_name |
文本 |
15 |
不为空 |
姓名 |
user_image |
文本 |
30 |
不为空 |
头像文件名 |
user_ip |
文本 |
15 |
不为空 |
IP地址 |
user_oicq |
文本 |
10 |
可为空 |
QQ号 |
user_http |
文本 |
50 |
可为空 |
主页 |
user_email |
文本 |
50 |
可为空 |
电子邮件 |
user_time |
日期 |
长日期 |
|
留言时间 |
user_ly |
文本 |
255 |
不为空 |
留言内容 |
user_replay |
是/否 |
|
|
是否回复 |
user_rply |
文本 |
255 |
可为空 |
回复内容 |
user_rptime |
日期 |
|
长日期 |
回复时间 |
留言本的数据库比较简单,如果是大型网站,在数据库设计好后要反复检查。所有的字段名最好用命名标准,在数据库设计完成后,最好能打印出一份象上面的列表来,以方便使用。
(三)站点的文件设计
文件的设计主要是设计有多少个文件,每个文件分别包含哪些内容,以及之间的关系。以留言本为例,文件设计如下:
1、 inc.asp 有关函数和常数,包括打开数据库函数,打开表函数,文字处理函数
2、top.htm 页头信息
3、bottom.htm 页脚信息
4、index.asp 留言本主页面。包括显示留言,管理员登录,修改参数,回复留言。引用inc.asp;
5、main.CSS css文件;
6、tou.htm 头像列表文件;
7、image 文件夹,存头像及其它图片;
(四)站点的页面设计
页面设计主要是设计页面的风格和布局。这部份内容比较多,一般是先定位整个页面的风格,然后设计所有的插图和Flash,再设计CSS,最后设计每个页面。对于页面有重复的内容,先设计单个的内容。这里仅列出index.asp的大致设计,如下:
'引用 inc.asp <% '处理参数 '留言子程序 '登录子程序 '回复子程序 '删除子程序 '修改参数子程序 '退出登录子程序 %> <html> <head> <!-引用CSS-!> <title>留言本</title> <body> '引用top.htm '显示留言表单 '显示搜索表单 '显示留言记录 '引用bottom.htm </body> </html> |
当然,在页面设计阶段,并不要写出子程序,只要把显示的各部份做好就行了
(五)站页的代码设计
主要就是完成ASP代码的设计。在这里只谈谈如何让站点的可修改性和可移植性加强。只有一点:多用组件或者是函数,当然如果写成类就更好了。对于小站点,也不希望到每个页面的某个子程序再去用 set conn=server.createobject("adodb.connection"),而是把它写成一个函数或子程序,放在页面里,比如:
<% databasename="lyb.mdb" uid="" pid="" sub opendb(connect) set connect=server.CreateObject("ADODB.connection") connect.ConnectionString="DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=" &_ server.MapPath(databasename) &";uid="&uid&";pid="&pid connect.Open strconn end sub %> |
这样,当你改变数据库名或是用户名和密码的时候,很方便的能修改过来。经过一段时间的积累,你会有许多这样的函数或子程序,或是类,再做类似的站点的时候,只要整理出相关的放在一个文件里引用一下就好了。