第一篇:留言板的制作
实验十二
一、实训目的
1、掌握制作校园留言板;
2、掌握制作留言板数据库。
二、实训内容
注意:以下各题,保存在D: 09通信学号XX文件名中。
1、设计添加留言板数据库(课本P113-114)。(40分)
2、设计留言板主页(index.asp)(课本P120-125)(60分)
第二篇:dreamweaver制作留言板步骤
一、安装与调试
常听朋友感叹ASP程序难学不易懂,不过我起初学习这门技术的时候也有过这样的感悟。从今天开始,我将以我学ASP的经验来做一个简单的ASP留言本,这个留言本用了Access数据库,所以务必请大家要跟我一起做的朋友都安装好Office软件,相信各位自己的电脑上都有了。好了,开始。
创建ASP的运行环境(安装IIS)
IIS(Internet Information Service)是构建ASP站点所必须的,所以,我们应该先确认自己的电脑已安装了IIS信息服务,如果没有安装好的话,请按以下步骤:
1、打开“控制面板”
2、双击“添加/删除程序”
3、单击“添加/删除Windows组件”,打开添加/删除Windows组件对话框:
3、从下拉的列表中选择“Internet 信息服务(IIS)”单击“下一步”:
4、出现组件安装进度窗口,如弹出需要安装盘的话,放入Windows2000安装盘,按提示操作即可。直至最后安装完毕。
二、设计数据库
ASP程序本身并不能储存数据,众所周知,留言本有以下信息需要保存:留言者姓名、联系方式、留言内容等等。因为ASP并不能储存数据,所以数据库在这种环境之下就产生了。数据库的种类也很多,针对不同的程序也有适用于它的数据库,比如Access和Ms SQL就比较适用ASP和ASP.net程序,至于其它的数据库和程序,就不属于本文所讨论的问题了,有兴趣的朋友可以查看其它一些资料。
那么既然Access和MS SQL都适用ASP,那么具体又如何来选择呢?我们可以打一个比方:比如钉一枚小钉子,聪明的人一定不会用一个大的棒槌,而是选择小的铁锤,虽然用大的棒槌也一样的可以把钉子钉进去,可是没有人愿意这样做。
数据库也一样:Access比较适用小型的应用,而MS SQL则适用于大中型的数据库应用,所以要做一个留言本,理所当然是选择Access更好一些,但是如果你决心使用MS,没有人会极力阻止你。好了,废话少说,切入正题,下面开始创建数据库。
Access是微软office办公软件中的其中一个,默认的安装Office是有这个Access的,好了,打开程序,开始了,GO!
进入实战了。打开程序后,出现一个对话框,这里我们选择第一个选项”空Access数据库”点击确定,弹出一个新建数据库的文件框,选择你上次你建的站点目录,起个data的文件名,点击创建,OK!双击”使用设计器创建表”打开表创建窗口”如图 创建表的结构如下表:
字段名称 数据类型 备注(笔者注释)
id 自动编号 设置“自动编号” user 文本 留言者姓名
qq 数字 留言者的QQ,因为QQ号是由数字组成email 文本 留言者的电子邮件
content 备注 留言内容
data 日期/时间 留言时间,设定默认值为Now()
数据库设计好了以后,可以直接在数据库里添加两条记录,以后测试时候用!
三、连接数据库
在上一节,我们已经为我们的程序创建了一个数据库,在这一节中,我们来用ASP把程序和数据库连接起来,以后就可以连接到数据库、在ASP中显示数据库中的数据以及更复杂的插入、修改和删除。
一起看以下代码,这就是ASP程序中常用的连接数据库的代码: <% set conn=server.createobject(“adodb.connection”)connstr=“Provider=Microsoft.jet.oledb.4.0;data source=”&server.mappath(“data.mdb”)conn.open connstr %>
解释一下以上代码: <% 这是ASP程序的起始
set conn=server.createobject(“adodb.connection”)在服务器上创建了一个连接数据库的对象
connstr=“Provider=Microsoft.jet.oledb.4.0;data source=”&server.mappath(“data.mdb”)告诉ASP数据库的接接方法以及路径
conn.open connstr 创建了对象后就用来打开数据库进行连接 %> 一切OK了!结束ASP程序
将上面的代码另存为conn.asp文件,放在服务器目录下面就可以了。怎么样,简单吧?
四、制作留言本首页
前面我们已经连接好了数据库,就要让它在这里发挥一下作用了,这一节将讲述如何将数据库里的数据用ASP读取出来,在页面中显示出来,这样就等于是查看留言本了。
利用DW制作如下页面(这里我就不讲如何去做这个页面了,最后我将会给出HTML代码下载)
将制作好的文件存为index.asp,下面就创建数据记录集,用来显示数据库的数据到这个页面中:
用记事本打开index.asp,在页头加入以下代码: <%@LANGUAGE=“VBScript” codepage=“936”%> <% set rs=server.createobject(“adodb.recordset”)sql=“select user,qq,email,content,data from main order by id desc” rs.open sql,conn,1,1 %> 代码拷贝框
<%@LANGUAGE=“VBScript” codepage=“936”%> <% set rs=server.createobject(“adodb.recordset”)sql=“select user,qq,email,content,data from main order by id desc” rs.open sql,conn,1,1 %> [Ctrl+A 全部选择 然后拷贝]
解释一下:
第一行,表明ASP使用的是VB脚本
第二行,是用include包含文件,这里包含的是数据库连接文件。第三行,ASP程序开始
第四行,利用Server内置对象创建一个记录集
第五行, SQL语句,这里的意思是选择数据库中的user,qq,email,content,data字段,指定该数据表的名称是“main”数据的排列顺序是倒序。
第六行,用刚才创建的名为rs的记录集打开数据库,设置属性为只读(1,1为只读数据,1,3为插入数据,2,3是修改数据。
这样就打开了数据库,接下来就可以显示了。
将“留言人”代替为“<%=rs(“user”)%> “时间”代替为“<%=rs(“data”)%> “留言内容在此”代替为“<%=rs(“content”)%>
“QQ”链接到:http://search.tencent.com/cgi-bin/friend/user_show_info?ln=<;%=rs(“qq”)%> “邮件”链接到:mailt<%=rs(“email”)%> 最后将“填写留言”链接 add.asp “管理留言”链接 admin.asp
好了,再次保存,浏览看看!
怎么了?只显示一条记录?原来我们在数据库里添加了两条记录的哦!还有一条呢?别急,因为我们没有指定ASP循环显示,所以就只有一条啦。。
在刚才的代码后面添加一行 <%do while not rs.eof%> 并在页面的第一个表格的末尾加上
<% rs.movenext loop %> 上面的代码就是说用rs记录集指针一条一条往下一条移动,直到末尾,loop是循环的意思。哈哈,再次浏览这个文件
看明白了吗,这样就可以让数据库中的数据全部显示在页面中了。
五、制作添加留言页面,实现留言功能
我们是做的一个留言本,实现留言的功能就十分重要了,要不然就算不上留言本了,接下来就一起来实现这个功能。
用DW制作以下这样的页面:
设置表单的属性如下:
姓名:设置为单行文本域,名称为“user” QQ号:设置为单行文本域,名称为“qq” 邮件:设置为单行文本域,名称为“email” 内容:设置为多行文本域,名称为“content”
最后将表单的“Action”动作指向addsave.asp就可以了。
保存文档名为add.asp,OK!下一步!
表单是做好了,但是还需要后台程序的支持,一起来使用ASP编写一个添加留言处理程序,添加留言代码:
<%@LANGUAGE=“VBScript” codepage=“936”%>
表明ASP使用的是VB脚本
是用include包含文件,这里包含的是数据库连接文件 <% set rs=server.createobject(“adodb.recordset”)
利用Server内置对象创建一个记录集 sql=“select user,qq,email,content,data from main”
SQL语句,上节有详解
rs.open sql,conn,1,3
用刚才创建的名为rs的记录集打开数据库,设置属性为插入数据 rs.addnew
用记录集新添加一条数据
user=request.form(“user”)
请求表单的变量,定义变量为user,这里request.form是请求表单的意思 qq=request.form(“qq”)
请求表单的变量,定义变量为qq,这里request.form是请求表单的意思 email=request.form(“email”)
请求表单的变量,定义变量为email,这里request.form是请求表单的意思
content=request.form(“content”)
请求表单的变量,定义变量为content,这里request.form是请求表单的意思 rs(“user”)=user
将请求到的表单值传向记录集中代表user字段的名称 rs(“qq”)=qq
将请求到的表单值传向记录集中代表qq字段的名称 rs(“email”)=email
将请求到的表单值传向记录集中代表email字段的名称 rs(“content”)=content
将请求到的表单值传向记录集中代表content字段的名称 rs.update
更新一下数据库中的数据。rs.close
关闭记录集 set rs=nothing
销毁记录集 conn.close
关闭数据库连接 set rs=nothing
销毁数据库连接 %>
代码拷贝框
<%@LANGUAGE=“VBScript” codepage=“936”%>
表明ASP使用的是VB脚本
是用include包含文件,这里包含的是数据库连接文件 <% set rs=server.createobject(“adodb.recordset”)
利用Server内置对象创建一个记录集 sql=“select user,qq,email,content,data from main”
SQL语句,上节有详解
rs.open sql,conn,1,3
用刚才创建的名为rs的记录集打开数据库,设置属性为插入数据 rs.addnew
用记录集新添加一条数据
user=request.form(“user”)
请求表单的变量,定义变量为user,这里request.form是请求表单的意思 qq=request.form(“qq”)
请求表单的变量,定义变量为qq,这里request.form是请求表单的意思 email=request.form(“email”)
请求表单的变量,定义变量为email,这里request.form是请求表单的意思
content=request.form(“content”)
请求表单的变量,定义变量为content,这里request.form是请求表单的意思
rs(“user”)=user
将请求到的表单值传向记录集中代表user字段的名称 rs(“qq”)=qq
将请求到的表单值传向记录集中代表qq字段的名称 rs(“email”)=email
将请求到的表单值传向记录集中代表email字段的名称 rs(“content”)=content
将请求到的表单值传向记录集中代表content字段的名称 rs.update
更新一下数据库中的数据。rs.close
关闭记录集 set rs=nothing
销毁记录集 conn.close
关闭数据库连接 set rs=nothing
销毁数据库连接 %>
[Ctrl+A 全部选择 然后拷贝]
将以上文件存为addsave.asp,测试下!咦?怎么填好提交以后就出现空白了,为什么?这是因为在addsave.asp中没有设置数据成功提交好后的转向页面,这里不用做那么复杂的,只要做一个刷新页面就行了,在程序的后面加上:
然后在页面中添加提示信息,比如:“您的留言已经成功提交,2秒钟后将自动返回留言本首页” 好了,这个留言的功能总算实现了,最后再测试下,看看效果!
OK!
六、制作管理登陆页面
留言本的管理功能对于留言本来说就不言而喻了,像论坛的登陆功能就是一个很好的例子,不过我们做留言本基本上有删除功能就行了,写这个教程是为了更多的ASP入门者更好的了解ASP,所以旨在学习用,当然也可以在这基础上添加更多的功能,比如回复留言者。
好了,开始了,还是按照以前的,用Dreamweaver做一个登陆页面,如下图:
把用户名的表单名称设置为admin,密码的表单名称设为password,把动作指向checkpass.asp,存admin.asp这样登陆页面就好了,下面就做检测密码的ASP程序了,看以下代码解释:
把conn.asp包含进来连接数据库 <% ASP起始
admin=request.form(“admin”)定义admin的值是表单传过来的用户名域名称admin password=request.form(“password”)定义admin的值是表单传过来的用户名域名称admin if admin=“" or password=”“ then 这句的意思是假如用户名和密码没有输入的话那么执行下一句
response.Write(”“)用javascript脚本提示用户 end if 结束if语句
sql=”select * from admin where admin=“&admin&” and password=“&password&”“ 这句很重要,我们放到后面讲
set rs=conn.execute(sql)设定记录集rs,用conn执行SQL语句 if rs.eof or rs.bof then 当没有符合筛选结果时,则执行下面的句子 response.write ”“ 用javascript脚本提示用户 else 如果符合条件的时候
session(”admin“)=admin 新建session,值等于表单传来的用户名 response.redirect ”mymanage.asp“ 转向到mymanage.asp,进入管理页 end if 结束if语句 %> ASP结束
代码拷贝框
把conn.asp包含进来连接数据库 <% ASP起始
admin=request.form(”admin“)定义admin的值是表单传过来的用户名域名称admin password=request.form(”password“)定义admin的值是表单传过来的用户名域名称admin if admin=”“ or password=”“ then 这句的意思是假如用户名和密码没有输入的话那么执行下一句
response.Write(”“)用javascript脚本提示用户 end if 结束if语句
sql=”select * from admin where admin=“&admin&” and password=“&password&”“ 这句很重要,我们放到后面讲
set rs=conn.execute(sql)设定记录集rs,用conn执行SQL语句 if rs.eof or rs.bof then 当没有符合筛选结果时,则执行下面的句子 response.write ”“ 用javascript脚本提示用户 else 如果符合条件的时候
session(”admin“)=admin 新建session,值等于表单传来的用户名 response.redirect ”mymanage.asp“ 转向到mymanage.asp,进入管理页 end if 结束if语句 %> ASP结束
[Ctrl+A 全部选择 然后拷贝]
将以上代码保存为checkpass.asp
这样,用户在admin.asp页面中输入用户名和密码后,就把用户名和密码值传给checkpass.asp处理,当用户名和密码的值和数据库中的字段相匹配时,就进入mymanage.asp这个管理页面,同时建一个session,这个session的会话变量将在后面起作用,七、制作管理页面
上节中讲的是制作登陆页面和检测用户,当用户名和密码正确时就转到管理页面,好了,开始实现它。其实这个留言本的管理页面和用户直接看到的首页没有多大的区别,只是用了Session会话变量用作保护和增加了一个删除链接,当点击这个链接的时候,就会自动删除这条留言,好了,其本的目的知道了,那就GO!
刚才讲了,这个页面和首页的index.asp相似,那么就先复制就行了,然后再改一下
首先找到下面这句:
sql=”select user,qq,email,content,data from main order by id desc“ 把它改为
sql=”select id,user,qq,email,content,data from main order by id desc“ 这样,就选取到了id这个自动编号的值,以便删除留言时锁定这个id。
然后在“邮件”这个链接后面增加一个链接“删除”,链接:del.asp?id=<%=rs(”id“),修改代码后为“ onclick=”return confirm(是否确定删除本留言?);“>删除 这样,待会我们做del这个页的时候,就会知道为什么了!改过后存为mymanage.asp
现在打开浏览器看看!
怎么不用输入用户名和密码都可进入呀?别急,上节中,我们不是建了一个session的会话变量,这时就派上用场了,直接用记事本打开。在<%@LANGUAGE=”VBScript“ codepage=”936“%>这句的后面加上<%if session(”admin“)<>”“ then%>这句,在末尾写上: <% else response.Redirect(”admin.asp“)end if%> 下面来讲解一下。
<%if session(”admin“)<>”“ then%> 就是说如果session这个(”admin“)的值不是空的话就执行。<% else response.Redirect(”admin.asp“)end if%> 为空的话就转向登陆页,重新登陆,这样的话,直接输入网址的话就会跳到admin.asp,简单吧!
八、删除留言
上节我们增加了一个删除留言的链接,以下是这个del.asp的代码
<% set rs=server.createobject(”adodb.recordset“)id=Request.QueryString(”id“)sql=”select * from main where id=“&id rs.open sql,conn,2,3 rs.delete rs.update %> 很明了吧,才几句,第1、2、3句都不用我解释了,大家都在上几节中明白了。
第4句:
id=Request.QueryString(”id“)用id取值字符串中传的id,回头看一下删除的链接:del.asp?id=<%=rs(”id“)%> 就是这个链接才把id的值传来的,<%=rs(”id")%>是读取数据库中的自动编号字段中的id。
第5句:
用sql定义SQL语句,这里的*是通配符,表示所有,而Where有点像我们汉语中的“当”,整句话的意思是选择所有来自表名为main的字段,它的条件是当数据库中的id字段是字串所传来的id。如果这个没有的话这个一时间不明白也不要紧,慢慢接触就知道了。第6句是打开符合条件的记录,确切的讲不应该叫记录集了,因为经过我们这样筛选的话,记录绝对是一条,2,3指定可以对数据库中的数据进入修改。
第7、8句
rs.delete 看了就明白了,原来这才是整个程序的精髓,就是执行删除了。rs.update 这是更新数据库中的表,删除后就更新。
最后大家自己用rs.close和conn.close释放。
第三篇:java l留言板的制作
package com.cfxy.wwl.java.shixun;
import java.awt.BorderLayout;import java.awt.GridLayout;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.FileNotFoundException;import java.io.FileReader;import java.io.FileWriter;import java.io.IOException;import java.io.PrintWriter;import java.text.SimpleDateFormat;import java.util.Date;
import javax.swing.JButton;import javax.swing.JFrame;import javax.swing.JPanel;import javax.swing.JScrollPane;import javax.swing.JTextArea;import javax.swing.ScrollPaneConstants;/* * Swing:其实大部分组建派生与awt * * 组建的对应规则: * awt Swing * Frame JFrame * Button JButton */
public class liuyanban {
//建立组件的引用
private JFrame f;private JButton b1;private JButton b2;private JButton b3;private JTextArea ta;
//构造方法
public liuyanban(){
init();}
//初始化显示界面
public void init(){
JFrame f=new JFrame(“我的留言板”);
f.setBounds(300, 200, 400, 400);
//设置布局方式
f.setLayout(new BorderLayout());
//三个按钮
b1=new JButton(“查看/刷新留言”);
b2=new JButton(“我要留言”);
b3=new JButton(“清除历史留言”);
//Panel
JPanel p=new JPanel();
p.setLayout(new GridLayout(1,3));
p.add(b1);
p.add(b2);
p.add(b3);
//创建带有滚动条的面板,其构造方法参数在接口ScrollPaneConstants中
JScrollPane jp=new JScrollPane(ScrollPaneConstants.VERTICAL_SCROLLBAR_AS_NEEDED,ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER);
ta=new JTextArea(“");
ta.setWrapStyleWord(true);
jp.setViewportView(ta);
f.add(p,”North“);
f.add(jp,”Center“);
myEvent();
f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
f.setVisible(true);} //加载各种监听器
public void myEvent(){
b2.addActionListener(new ActionListener(){
@Override
public void actionPerformed(ActionEvent arg0){
String label=b2.getText();
if(”我要留言“.equals(label)){
b2.setText(”提交留言“);
ta.setText(”留言信息:“);
}else{
//将留言信息存入文本文件
String s=ta.getText();
try {
PrintWriter FileWriter(”record.txt“,true));
Date d=new Date();
//SimpleDateFormat位于java.text包,这里使用其format(date)方法
SimpleDateFormat SimpleDateFormat(”yyyy/MM/dd hh:mm:ss“);
pw.println(sdf.format(d));
pw.println(s);
pw.println(”-------------“);
sdf=new
pw=new
PrintWriter(new
pw.close();
} catch(IOException e){
// TODO Auto-generated catch block
e.printStackTrace();
}
b2.setText(”我要留言“);
ta.setText(”留言已经提交.......“);
}
}
});
b1.addActionListener(new ActionListener(){
@Override
public void actionPerformed(ActionEvent arg0){
try {
ta.setText(”“);
BufferedReader FileReader(”record.txt“));
String line=”“;
while((line=br.readLine())!=null){
ta.append(line);
ta.append(”rn“);
br=new
BufferedReader(new
}
} catch(IOException e){
ta.setText(”文件不存在!“);
}
}
});
b3.addActionListener(new ActionListener(){
@Override
public void actionPerformed(ActionEvent arg0){
try {
PrintWriter FileWriter(”record.txt“));
pw.println(”留言记录:rn“);
pw.close();
ta.setText(”留言已经清除!");
} catch(IOException e){
// TODO Auto-generated catch block
e.printStackTrace();
}
}
pw=new
PrintWriter(new
});}
public static void main(String[] args){
new liuyanban();} }
第四篇:简单易学的ASP留言板制作教程
ASP留言本教程(1)时间:2010-04-09 22:53 点击:17次 作者: 来源:网页教学网
二、设计数据库
ASP程序本身并不能储存数据,众所周知,留言本有以下信息需要保存:留言者姓名、联系方式、留言内容等等。因为ASP并不能储存数据,所以数据库在这种环境之下就产生了。数据库的种类也很多,针对不同的程序也有适用于它的数据库,比如Access和Ms SQL就比较适用ASP和ASP.net程序,至于其它的数据库和程序,就不属于本文所讨论的问题了,有兴趣的朋友可以查看其它一些资料。
那么既然Access和MS SQL都适用ASP,那么具体又如何来选择呢?我们可以打一个比方:比如钉一枚小钉子,聪明的人一定不会用一个大的棒槌,而是选择小的铁锤,虽然用大的棒槌也一样的可以把钉子钉进去,可是没有人愿意这样做。
数据库也一样:Access比较适用小型的应用,而MS SQL则适用于大中型的数据库应用,所以要做一个留言本,理所当然是选择Access更好一些,但是如果你决心使用MS,没有人会极力阻止你。好了,废话少说,切入正题,下面开始创建数据库。
Access是微软office办公软件中的其中一个,默认的安装Office是有这个Access的,好了,打开程序,开始了,GO!
进入实战了。打开程序后,出现一个对话框,这里我们选择第一个选项"空Access数据库"点击确定,弹出一个新建数据库的文件框,选择你上次你建的站点目录,起个data的文件名,点击创建,OK!双击"使用设计器创建表"打开表创建窗口"如图
创建表的结构如下表:
字段名称
数据类型
备注(笔者注释)
id 自动编号 设置“自动编号” name 文本 留言者姓名
qq 数字 留言者的QQ,因为QQ号是由数字组成 email 文本 留言者的电子邮件 content 备注 留言内容
data 日期/时间 留言时间,设定默认值为Now()
数据库设计好了以后,可以直接在数据库里添加两条记录,以后测试时候用!这一节就到此了
ASP留言本教程(2)时间:2010-04-09 22:53 点击:17次 作者: 来源:网页教学网
三、连接数据库
在上一节,我们已经为我们的程序创建了一个数据库,在这一节中,我们来用ASP把程序和数据库连接起来,以后就可以连接到数据库、在ASP中显示数据库中的数据以及更复杂的插入、修改和删除。
一起看以下代码,这就是ASP程序中常用的连接数据库的代码: <% set conn=server.createobject(“adodb.connection”)connstr=“Provider=Microsoft.jet.oledb.4.0;data source=”&server.mappath(“data.mdb”)conn.open connstr %>
解释一下以上代码: <%
'这是ASP程序的起始
set conn=server.createobject(“adodb.connection”)
'在服务器上创建了一个连接数据库的对象
connstr=“Provider=Microsoft.jet.oledb.4.0;data source=”&server.mappath(“data.mdb”)
'告诉ASP数据库的接接方法以及路径
conn.open connstr
'创建了对象后就用来打开数据库进行连接 %>
'一切OK了!结束ASP程序
将上面的代码另存为conn.asp文件,放在服务器目录下面就可以了。怎么样,简单吧?
这一节是最重要的,一定要弄明白,否则以后操作数据库将变得不现实,如果有不懂的问题,欢迎和我讨论,我的电子邮件地址是。这一节就到此,下节我们就将数据库中的数据显示在页面中(这就实现了留言本的查看功能)
ASP留言本教程(3)时间:2010-04-09 22:53 点击:17次 作者: 来源:网页教学网
三、制作留言本首页
前面我们已经连接好了数据库,就要让它在这里发挥一下作用了,这一节将讲述如何将数据库里的数据用ASP读取出来,在页面中显示出来,这样就等于是查看留言本了。
利用DW制作如下页面(这里我就不讲如何去做这个页面了,最后我将会给出HTML代码下载)
将制作好的文件存为index.asp,下面就创建数据记录集,用来显示数据库的数据到这个页面中:
用记事本打开index.asp,在页头加入以下代码:
<%@LANGUAGE=“VBScript” codepage=“936”%> <% set rs=server.createobject(“adodb.recordset”)sql=“select user,qq,email,content,data from main order by id desc” rs.open sql,conn,1,1 %>
解释一下:
第一行,表明ASP使用的是VB脚本
第二行,是用include包含文件,这里包含的是数据库连接文件。第三行,ASP程序开始
第四行,利用Server内置对象创建一个记录集
第五行, SQL语句,这里的意思是选择数据库中的user,qq,email,content,data字段,指定该数据表的名称是“main”数据的排列顺序是倒序。
第六行,用刚才创建的名为rs的记录集打开数据库,设置属性为只读(1,1为只读数据,1,3为插入数据,2,3是修改数据。
这样就打开了数据库,接下来就可以显示了。
将“留言人”代替为“<%=rs(“user”)%> “时间”代替为“<%=rs(“data”)%>
“留言内容在此”代替为“<%=rs(“content”)%> “QQ”链接到:
“邮件”链接到:mailto:<%=rs(“email”)%> 最后将“填写留言”链接 add.asp “管理留言”链接 admin.asp
好了,再次保存,浏览看看!
怎么了?只显示一条记录?原来我们在数据库里添加了两条记录的哦!还有一条呢?别急,因为我们没有指定ASP循环显示,所以就只有一条啦。。
在刚才的代码后面添加一行
<%do while not rs.eof%>
并在页面的第一个表格的末尾加上
<% rs.movenext loop %> 上面的代码就是说用rs记录集指针一条一条往下一条移动,直到末尾,loop是循环的意思。哈哈,再次浏览这个文件
看明白了吗,这样就可以让数据库中的数据全部显示在页面中了,好了,这节就到这,下节讲一个也很重要的部份(添加留言功能。)
ASP留言本教程(4)时间:2010-04-09 22:53 点击:17次 作者: 来源:网页教学网
三、制作添加留言页面,实现留言功能
我们是做的一个留言本,实现留言的功能就十分重要了,要不然就算不上留言本了,接下来就一起来实现这个功能。
用DW制作以下这样的页面:
设置表单的属性如下:
姓名:设置为单行文本域,名称为“user” QQ号:设置为单行文本域,名称为“qq” 邮件:设置为单行文本域,名称为“email” 内容:设置为多行文本域,名称为“content”
最后将表单的“Action”动作指向addsave.asp就可以了。
保存文档名为add.asp,OK!下一步!
表单是做好了,但是还需要后台程序的支持,一起来使用ASP编写一个添加留言处理程序,添加留言代码:
<%@LANGUAGE=“VBScript” codepage=“936”%>
'表明ASP使用的是VB脚本
'是用include包含文件,这里包含的是数据库连接文件 <% set rs=server.createobject(“adodb.recordset”)
'利用Server内置对象创建一个记录集
sql=“select user,qq,email,content,data from main”
'SQL语句,上节有详解 rs.open sql,conn,1,3'用刚才创建的名为rs的记录集打开数据库,设置属性为插入数据
rs.addnew
'用记录集新添加一条数据
user=request.form(“user”)
'请求表单的变量,定义变量为user,这里request.form是请求表单的意思
qq=request.form(“qq”)
'请求表单的变量,定义变量为qq,这里request.form是请求表单的意思
email=request.form(“email”)
'请求表单的变量,定义变量为email,这里request.form是请求表单的意思
content=request.form(“content”)
'请求表单的变量,定义变量为content,这里request.form是请求表单的意思
rs(“user”)=user
'将请求到的表单值传向记录集中代表user字段的名称 rs(“qq”)=qq
'将请求到的表单值传向记录集中代表qq字段的名称
rs(“email”)=email
'将请求到的表单值传向记录集中代表email字段的名称 rs(“content”)=content
'将请求到的表单值传向记录集中代表content字段的名称
rs.update
'更新一下数据库中的数据。rs.close
'关闭记录集 set rs=nothing
'销毁记录集 conn.close
'关闭数据库连接 set rs=nothing
'销毁数据库连接 %>
将以上文件存为addsave.asp,测试下!咦?怎么填好提交以后就出现空白了,为什么?这是因为在addsave.asp中没有设置数据成功提交好后的转向页面,这里不用做那么复杂的,只要做一个刷新页面就行了,在程序的后面加上:
然后在页面中添加提示信息,比如:“您的留言已经成功提交,2秒钟后将自动返回留言本首页”
好了,这个留言的功能总算实现了,最后再测试下,看看效果!
OK!这个留言功能的实现教程就到这里了。
ASP留言本教程(5)时间:2010-04-09 22:53 点击:17次 作者: 来源:网页教学网
六、制作管理登陆页面
留言本的管理功能对于留言本来说就不言而喻了,像论坛的登陆功能就是一个很好的例子,不过我们做留言本基本上有删除功能就行了,写这个教程是为了更多的ASP入门者更好的了解ASP,所以旨在学习用,当然也可以在这基础上添加更多的功能,比如回复留言者。
好了,开始了,还是按照以前的,用Dreamweaver做一个登陆页面,如下图:
把用户名的表单名称设置为admin,密码的表单名称设为password,把动作指向checkpass.asp,存admin.asp这样登陆页面就好了,下面就做检测密码的ASP程序了,看以下代码解释:
'把conn.asp包含进来连接数据库 <% 'ASP起始
admin=request.form(“admin”)'定义admin的值是表单传过来的用户名域名称admin password=request.form(“password”)'定义admin的值是表单传过来的用户名域名称admin if admin=“" or password=”“ then '这句的意思是假如用户名和密码没有输入的话那么执行下一句
response.Write(”“)'用javascript脚本提示用户 end if '结束if语句
sql=”select * from admin where admin='“&admin&”' and password='“&password&”'“ '这句很重要,我们放到后面讲
set rs=conn.execute(sql)'设定记录集rs,用conn执行SQL语句 if rs.eof or rs.bof then '当没有符合筛选结果时,则执行下面的句子 response.write ”“ '用javascript脚本提示用户 else '如果符合条件的时候
session(”admin“)=admin '新建session,值等于表单传来的用户名 response.redirect ”mymanage.asp“ '转向到mymanage.asp,进入管理页 end if '结束if语句 %> 'ASP结束
将以上代码保存为checkpass.asp
这样,用户在admin.asp页面中输入用户名和密码后,就把用户名和密码值传给checkpass.asp处理,当用户名和密码的值和数据库中的字段相匹配时,就进入mymanage.asp这个管理页面,同时建一个session,这个session的会话变量将在后面起作用,下一节就明白了。
ASP留言本教程(6)时间:2010-04-09 22:53 点击:17次 作者: 来源:网页教学网
七、制作管理页面
上节中讲的是制作登陆页面和检测用户,当用户名和密码正确时就转到管理页面,好了,开始实现它。
其实这个留言本的管理页面和用户直接看到的首页没有多大的区别,只是用了Session会话变量用作保护和增加了一个删除链接,当点击这个链接的时候,就会自动删除这条留言,好了,其本的目的知道了,那就GO!
刚才讲了,这个页面和首页的index.asp相似,那么就先复制就行了,然后再改一下
首先找到下面这句:
sql=”select user,qq,email,content,data from main order by id desc“ 把它改为
sql=”select id,user,qq,email,content,data from main order by id desc“ 这样,就选取到了id这个自动编号的值,以便删除留言时锁定这个id。
然后在“邮件”这个链接后面增加一个链接“删除”,链接:del.asp?id=<%=rs(”id“),修改代码后为“ onclick=”return confirm('是否确定删除本留言?');“>删除 这样,待会我们做del这个页的时候,就会知道为什么了!
改过后存为mymanage.asp
现在打开浏览器看看!
怎么不用输入用户名和密码都可进入呀?别急,上节中,我们不是建了一个session的会话变量,这时就派上用场了,直接用记事本打开。在<%@LANGUAGE=”VBScript“ codepage=”936“%>这句的后面加上<%if session(”admin“)<>”“ then%>这句,在末尾写上: <% else response.Redirect(”admin.asp“)end if%> 下面来讲解一下。
<%if session(”admin“)<>”“ then%> '就是说如果session这个(”admin“)的值不是空的话就执行。<% else response.Redirect(”admin.asp“)end if%> '为空的话就转向登陆页,重新登陆,这样的话,直接输入网址的话就会跳到admin.asp,简单吧!
好了,这节就到这里了。
ASP留言本教程(7)时间:2010-04-09 22:53 点击:17次 作者: 来源:网页教学网
八、删除留言
上节我们增加了一个删除留言的链接,以下是这个del.asp的代码
<% set rs=server.createobject(”adodb.recordset“)id=Request.QueryString(”id“)sql=”select * from main where id=“&id rs.open sql,conn,2,3 rs.delete rs.update %>
很明了吧,才几句,第1、2、3句都不用我解释了,大家都在上几节中明白了。
第4句:
id=Request.QueryString(”id“)用id取值字符串中传的id,回头看一下删除的链接:del.asp?id=<%=rs(”id“)%> 就是这个链接才把id的值传来的,<%=rs(”id")%>是读取数据库中的自动编号字段中的id。
第5句:
用sql定义SQL语句,这里的*是通配符,表示所有,而Where有点像我们汉语中的“当”,整句话的意思是选择所有来自表名为main的字段,它的条件是当数据库中的id字段是字串所传来的id。如果这个没有的话这个一时间不明白也不要紧,慢慢接触就知道了。
第6句是打开符合条件的记录,确切的讲不应该叫记录集了,因为经过我们这样筛选的话,记录绝对是一条,2,3指定可以对数据库中的数据进入修改。
第7、8句 rs.delete 看了就明白了,原来这才是整个程序的精髓,就是执行删除了。rs.update 这是更新数据库中的表,删除后就更新。
最后大家自己用rs.close和conn.close释放。
第五篇:留言板
日照职业技术学院毕业设计(论文)
php留言板系统
学生姓名 院 部
电子信息科学与工程学院 专 业 计算机应用技术 指导老师 鲁 红 日 期 2015-05-19
目录
一 留言板简介..........................................................................................................................................4 二 留言板设计原理..................................................................................................................................4 三 四 五 PHP技术介绍...................................................................................................................................4 PHP技术优点...................................................................................................................................4 MYSQL介绍......................................................................................................................................6
六 留言板系统的概要设计......................................................................................................................6(一)系统开发环境...............................................................................................................................6(二)php语言选择...............................................................................................................................6(三)系统功能.......................................................................................................................................7 七 留言板详细设计..................................................................................................................................7(一)数据库设计...................................................................................................................................8(二)留言板数据库连接 写入和保存..................................................................................................9(三)留言板文件夹中文件的介绍.....................................................................................................15(四)留言板首页设计.........................................................................................................................15 八 总结....................................................................................................................................................15 九 留言板特色和不足............................................................................................................................15 参考文献:................................................................................................................................................16
第1页
留言板系统
摘要:随着Internet的发展,网站的作用越来越重要,被称之为继广播、报纸、杂志、电视后的
第五种媒体——数字媒体,拥有众多优势,所以现在不少企业都有或正在建设自己的网站。而留言板作为网站重要的一个部分,从来就是一个大家交流的平台!留言板是一种最为简单的BBS应用,借助留言板,浏览者可以张贴留言的方式给站长、版主或其他浏览者进行留言和提问。
本文主要介绍留言板系统的设计思路和制作过程,从留言板的重要性开始,介绍我的留言版采用的PHP技术和MYSQL数据库,进而阐述整个留言板系统的制作过程和具体的设计思路。该留言板较全面地利用PHP技术实现留言板的基本功能:留言、查看、删除,并增加了一些特色功能。最后介绍自己在设计过程的心得体会。关键词:留言板,PHP,MYSOL数据库
第2页
引言
Internet起源于20世纪60年代末、70年代初,当时,美国国防部为了将充斥于军事基地内各种厂商的电脑主机互连,让它们可以进行数据交换以便研究工作顺利进行,于是成立了ARPA网络计划。ARPA计划尝试建设1个网络系统,它可将各种不同厂商的电脑连接起来。随着这个计划的成功,各学术单位,研究机构也纷纷与ARPA计划所建立的ARPANet连接。到了20世纪80年代,Internet这个名词因势产生,它代表着这10年来所构建涵盖全球各地的网络系统。从1990年起,商业使用的Internet在美国急速地扩大,而Internet也从原来属于少数人使用的网络系统转变为普通百姓也能够使用的网络系统。
最初的Internet资源服务都还停留在文本模式,1989年,量子物理实验室(CERN)下的1个研究小组着手开发1种全新的Internet服务,它可以在网络上传送图片、文本、影像、声音等多媒体数据。于是由Tim Berners Lee领导的小组开发出了1种主从、分布式的网络服务系统,这就是www.xiexiebang.compile编译或链接程序,可在服务器端直接执行,这无疑是更加方便了我们的编写过程。
2、使用编程环境方便简单。可以使用普通的记事本之类的文本编辑器,即可进行编辑设计,如:Windows的记事本、FrontPage等文本编辑器。也可以用dreamweaver和专业的Microsoft Visual InterDev开发工具。
3、浏览网页方便,交互速度也快。PHP是运行在服务器端,所以我们无须担心浏览器是否支持PHP所使用的编程语言,用户端只要使用可执行HTML码的浏览器,即可浏览Personal home pages所设计的网页内容。PHP在服务器端运行,当程序执行完毕后,服务器仅将执行的结果返回给客户浏览器,这样也就减轻了客户端浏览器的负担,大大提高了交互的速度。
4、提供多种编程语言。PHP能与任何ActiveX scripting语言相容。除了可用VBScript或JScript语言来设计外,还通过plug-in的方式,使用由第三方所提供的其他脚本语言,譬如Perl等。
5、提高代码的安全性。Personal home pages的程序代码隐藏,已编码的脚本在运行时由脚本引擎解码,因此不需要单独的应用程序。客户端上仅可以看到由PHP输出的动态HTML文件。因而可以避免所写的源程序被他人剽窃,也提高了程序的安全性。
6、功能强大。编程是面向对象的(Object oriented),并可扩展ActiveX Server组件功能。Personal home page Components(ActiveX服务器组件)具有无限可扩充性。你可以使用任何编程语言来编写你所需要的Personal Server 组件。可以使用Visual Basic、Java、Visual C++、COBOL等编程语言来编写你所需要的Personal Server Component。也可以使用第三方组件或自己开发的Personal Server组件。理论上说,可以实现任何功能。
7、访问数据库十分方便。可以通过PDO(Personal Data Objects,微软的一种新的数据访问模型,是一种可以提供WEB页面开发者轻松存取Internet的数据库,并可以在用户端实现网上立即、即时更新显示的最新WEB页面数据库技术。)非常方便地访问数据库。
总之,PHP从字面上说,包含三方面含义: 1.Personal:PHP使用了微软的Personal技术。Personal(COM)技术是现在Microsoft软件的重要基础。它采用封装对象,程序调用对象的技术,简化编程,加强程序间合作。PHP本身封装了一些基本组件和常用组件,有很多公司也开发了很多实用组件。只要你可以在服务器上安装这些组件,通过访问组件,你就可以快速、简易地建立自己的WEB应用。
2.home:PHP运行在服务器端。这样就不必担心浏览器是否支持PHP所使用的编程语言。PHP的编程语言可以是VBSCRIPT和JSCRIPT。VBSCRIPT是VB的一个简集,会VB的人可以很方便的快速上手。然而NETscape浏览器不支持客户端的VBSCRIPT,所以最好不要在客户端使用VBSCRIPT。而在服务器端,则无需考虑浏览器的支持问题。NETscape浏览器也可以正常显示PHP页面。
3.page:PHP返回标准的HTML页面,可以正常地在常用的浏览器中显示。浏览者查看页面源文件时,看到的是PHP生成的HTML代码,而不是PHP程序代码。这样就可以防止别人抄袭程序。由此可以看出,PHP是在IIS下开发WEB应用的一种简单、方便的编程工具。在了解了VBSCRIPT的基本语法后,只需要清楚各个组件的用途、属性、方法,就可以轻松编写出自己的PHP系统。
第5页
而我这次所开发的留言本系统,主要是利用PHP技术的简单和实用的特点,以及PHP使用的广泛性,而且非常适合于网络中小型系统开发。
五 MYSQL介绍
MySQL是一个小型关系型数据库管理系统,开发者为瑞典MySQL AB公司。在2008 年1月16号被Sun公司收购。而2009年,SUN又被Oracle收购.对于Mysql的前途,没有任何人抱乐观的态度.目前MySQL被广泛地应用在Internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。
1.使用C和C++编写,并使用了多种编译器进行测试,保证源代码的可移植性 2.支持AIX、FreeBSD、HP-UX、Linux、Mac OS、Novell Netware、OpenBSD、OS/2 Wrap、Solaris、Windows等多种操作系统
3.为多种编程语言提供了API。这些编程语言包括C、C++、Python、Java、Perl、PHP、Eiffel、Ruby和Tcl等。
4.支持多线程,充分利用CPU资源
5.优化的SQL查询算法,有效地提高查询速度
6.既能够作为一个单独的应用程序应用在客户端服务器网络环境中,也能够作为一个库而嵌入到其他的软件中提供多语言支持,常见的编码如中文的GB 2312、BIG5,日文的Shift_JIS等都可以用作数据表名和数据列名
7.提供TCP/IP、ODBC和JDBC等多种数据库连接途径 8.提供用于管理、检查、优化数据库操作的管理工具 9.可以处理拥有上千万条记录的大型数据库
六 留言板系统的概要设计
(一)系统开发环境
基于微软平台PHP环境,使用MYSQL数据库。适用于IE8.0以上版本浏览器,Win2000+APACHE 或win7+APACHE以上运行环境。(本人用的win7+APACHE测试)。
(二)php语言选择
选择一个好的编程语言十分的重要,当前,面对众多的编程语言,很多人无从选择,而本人看到PHP的以上众多特点,个人认为:
MYSQL后台数据库+PHP服务器端程序+客户端IE浏览器,是一个精练实用高效的组合模式。在这种使用模式中,PHP程序无疑是最重要的,是沟通客户端和后台数据库之间的桥梁。在PHP程序中,通过数据库语言,建立对MYSQL数据库的连接,是客户能够访问后
第6页
台数据库的前提。
鉴于前面介绍PHP优点的原因,又有上面组合的优势,本人的留言板使用PHP语言也是十分正确而实用的。
(三)系统功能
该留言板具有的主要功能如下:
1.可以按照发言时间的先后顺序,留言板自动排序; 2.留言板的主要栏目组成图
3.本留言板不需注册,陌生人即可留言。
4.因为是个人留言板所以具有留言、查看、删除的功能。
七 留言板详细设计
有了技术和流程图以及留言板要实现的功能,接下来就应该进行详细设计了。数据库是首当其冲的,接下来就是用户常接触的首页的设计,然后就是该留言板特色功能的设计和实现。
第7页
(一)数据库设计
我的数据库采用的是MY SQL数据库,采用的原因也已经介绍了。以下就介绍留言板数据库的组成。
第8页
(二)留言板数据库连接 写入和保存
数据库链接失败!
”;
exit();} mysql_select_db(“gbook”, $con);mysql_query(“set names 'gb2312'”);date_default_timezone_set(PRC);?>
第9页
if(isset($_REQUEST['GLOBALS'])OR isset($_FILES['GLOBALS'])){ exit('Request tainting attempted.');} //Session保存路径
$sessSavePath = LOVE_ROOT.“data/sessions/”;if(is_writeable($sessSavePath)&& is_readable($sessSavePath)){ session_save_path($sessSavePath);} date_default_timezone_set(Singapore);$timestamp = time();require_once LOVE_ROOT.'./data/config.inc.php';require_once LOVE_ROOT.'./data/db.inc.php';require_once LOVE_ROOT.'./include/db_mysql.class.php';require_once LOVE_ROOT.'./include/template.class.php';if(defined('UC_KG')){include_once TM_ROOT.'/uc_client/client.php';} $PHP_SELF = $_SERVER['PHP_SELF'] ? $_SERVER['PHP_SELF'] : $_SERVER['SCRIPT_NAME'];$SCRIPT_FILENAME = str_replace('', '/',($_SERVER['PATH_TRANSLATED'] ? $_SERVER['PATH_TRANSLATED'] : $_SERVER['SCRIPT_FILENAME']));//$homeurl = 'http://'.$_SERVER['HTTP_HOST'].preg_replace(“//+(api|archiver|wap)?/*$/i”, '', substr($PHP_SELF, 0, strrpos($PHP_SELF, '/'))).'/';
//实例化数据库操作 $db = new dbstuff;$db->connect($dbhost, $dbuser, $dbpw, $dbname, $pconnect);unset($dbhost, $dbuser, $dbpw, $dbname, $pconnect);$db->query(“set names gbk”);if(getenv('HTTP_CLIENT_IP')&& strcasecmp(getenv('HTTP_CLIENT_IP'), 'unknown')){ $onlineip = getenv('HTTP_CLIENT_IP');} elseif(getenv('HTTP_X_FORWARDED_FOR')&& strcasecmp(getenv('HTTP_X_FORWARDED_FOR'), 'unknown')){ $onlineip = getenv('HTTP_X_FORWARDED_FOR');} elseif(getenv('REMOTE_ADDR')&& strcasecmp(getenv('REMOTE_ADDR'), 'unknown')){ $onlineip = getenv('REMOTE_ADDR');} elseif(isset($_SERVER['REMOTE_ADDR'])&& $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], 'unknown')){ $onlineip = $_SERVER['REMOTE_ADDR'];}
preg_match(“/[d.]{7,15}/”, $onlineip, $onlineipmatches);$onlineip = $onlineipmatches[0] ? $onlineipmatches[0] : 'unknown';unset($onlineipmatches);?>
第10页
var $querynum = 0;var $link;var $histories;
var $dbhost;var $dbuser;var $dbpw;var $dbcharset;var $pconnect;var $tablepre;var $time;
var $goneaway = 5;
function connect($dbhost, $dbuser, $dbpw, $dbname = '', $dbcharset = '', $pconnect = 0, $tablepre='', $time = 0){
$this->dbhost = $dbhost;
$this->dbuser = $dbuser;
$this->dbpw = $dbpw;
$this->dbname = $dbname;
$this->dbcharset = $dbcharset;
$this->pconnect = $pconnect;
$this->tablepre = $tablepre;
$this->time = $time;
if($pconnect){
if(!$this->link = mysql_pconnect($dbhost, $dbuser, $dbpw)){
$this->halt('Can not connect to MySQL server');
}
} else {
if(!$this->link = mysql_connect($dbhost, $dbuser, $dbpw)){
$this->halt('Can not connect to MySQL server');
}
}
if($this->version()> '4.1'){
if($dbcharset){
mysql_query(“SET character_set_connection=”.$dbcharset.“, character_set_results=”.$dbcharset.“, character_set_client=binary”, $this->link);
}
if($this->version()> '5.0.1'){
mysql_query(“SET sql_mode=''”, $this->link);
}
第11页
} } if($dbname){ mysql_select_db($dbname, $this->link);} function fetch_array($query, $result_type = MYSQL_ASSOC){
return mysql_fetch_array($query, $result_type);}
function result_first($sql){
$query = $this->query($sql);
return $this->result($query, 0);}
function fetch_first($sql){
$query = $this->query($sql);
return $this->fetch_array($query);} function fetch_row($query){
$query = mysql_fetch_row($query);
return $query;} function fetch_fields($query){
return mysql_fetch_field($query);} function fetch_rows($sql){
$result = $this->query($sql);
$arr = array();
while($row = $this->fetch_array($result))
{
$arr[] = $row;
}
$this->free_result($result);
return $arr;} function fetch_one($sql){
$rs = $this->query($sql);
$arr = $this->fetch_array($rs,MYSQL_NUM);$this->free_result($rs);
第12页
return $arr[0];} function fetch_all($sql, $id = ''){
$arr = array();
$query = $this->query($sql);
while($data = $this->fetch_array($query)){
$id ? $arr[$data[$id]] = $data : $arr[] = $data;
}
return $arr;}
function cache_gc(){
$this->query(“DELETE FROM {$this->tablepre}sqlcaches WHERE expiry<$this->time”);}
function query($sql, $type = '', $cachetime = FALSE){
$func = $type == 'UNBUFFERED' && @function_exists('mysql_unbuffered_query')'mysql_unbuffered_query' : 'mysql_query';
if(!($query = $func($sql, $this->link))&& $type!= 'SILENT'){
$this->halt('MySQL Query Error', $sql);
}
$this->querynum++;
$this->histories[] = $sql;
return $query;}
function affected_rows(){
return mysql_affected_rows($this->link);}
function error(){
return(($this->link)? mysql_error($this->link): mysql_error());}
function errno(){
return intval(($this->link)? mysql_errno($this->link): mysql_errno());}
function result($query, $row){
$query = @mysql_result($query, $row);
return $query;}
function num_rows($query){
第13页
?
$query = mysql_num_rows($query);
return $query;}
function num_fields($query){
return mysql_num_fields($query);}
function free_result($query){
return mysql_free_result($query);}
function insert_id(){
return($id = mysql_insert_id($this->link))>= 0 ? $id : $this->result($this->query(“SELECT last_insert_id()”), 0);}
function version(){
return mysql_get_server_info($this->link);}
function close(){
return mysql_close($this->link);}
function halt($message = '', $sql = ''){
$error = mysql_error();
$errorno = mysql_errno();
if($errorno == 2006 && $this->goneaway--> 0){
$this->connect($this->dbhost, $this->dbuser, $this->dbpw, $this->dbname, $this->dbcharset, $this->pconnect, $this->tablepre, $this->time);
$this->query($sql);
} else {
$s = 'Error:'.$error.'
';
$s.= 'Errno:'.$errorno.'
';
$s.= 'SQL::'.$sql;
exit($s);
} } } ?>
第14页
(三)留言板文件夹中文件的介绍
有了数据库,就应该设计留言板的各个页面。本留言板由2个文件夹,11个文件组成,简单介绍各文件的作用:
index.PHP:留言板主页,主要功能是查看留言,任何人都可以查看留言信息。Fun.php连接数据库并统计留言条数、计算页数 Config.php连接配置数据库。
(四)留言板首页设计
我留言板的首页文件index.PHP,功能主要是为访客留下相关的信息,并进行留言。界面相对简单,但功能很实用!留言板的基本功能实现具体如下:
图7.1留言首页
图7.2愿望
图7.3愿望列表
结束语:通过上面的介绍,相信对该留言板整体的构建和各项功能都有了一定的认识,最重要的是学会了留言板的设计以及类似网络的编程,更对实际操作和具体设计流程有了清晰的认识。该留言板实现了基本功能,并具有自己的特色,例如屏蔽关键字和防灌水功能。由于该留言板功能实用,而且界面友好,特别适合于中小型网站使用。对于刚刚接触网络编程人员的信心和兴趣也会有很大提高。
八 总结
通过本次毕业设计,我学到了很多东西,例如:编程规范,PHP技术等。这次毕业设计是对我大学本科四年所学知识的一次综合应用,让我认识到了自己的不足,并不断的加强改进。在系统不断的完善改进中,我学到了很多新的知识,也懂得了很多。这使我对自己的未来充满了信心。
九 留言板特色和不足
特色:任何人都可以留言,任何人都可以看到。无需注册和登录,完全开放。不足:管理员功能较弱。
第15页
参考文献:
1.《PHP语言,进阶和高级应用》 龙浩等编著 清华大学出版社
2.《PHP & MYSQL Web数据库应用开发指南》 Hugh E.Williams等著 谢君英 欧阳宇译2003年5月
3.《php程序设计》 Programming PHP 中国电力出版社 2003年7月 4.《phpmysql数据库开发指南》焦桐顺著 电子工业出版社 2001年9月 5.《php4交互网页数据库实战手册》清华大学出版社 2004年7月
第16页