jsp+mysql制作简单的留言板(1)

本文介绍如何利用jsp和mysql创建一个简单的留言板系统。主要包括board.jsp页面,用于展示留言并提供分页功能,以及数据库message表的创建,包含留言者姓名、邮箱、主题、时间等字段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

留言板要实现的功能是:浏览的人能留言并能分页的查看留言,管理员能对留言进行处理!
这个留言板由9个小程序组成,分别是:board.jsp;message.html;opendata.jsp;manager.jsp;password.jsp;check.jsp;delete.jsp;convert.jsp
现在说第一个:board.jsp
他的任务是整个留言板的主程序,让使用者留言,并提供分页功能!
在开始之前,我们必须在mysql数据库建立一个mydate的数据库,在mudate中建立名为message的表:
mysql>create table message( name char(20),email char(40 ),subject char(60),time char(60),sex char(10),memo text,id int not null auto_increment,primary key(id));

board.jsp代码:
<HTML>
<HEAD>
<TITLE>流言板</TITLE>

</HEAD>
<BODY>
<%@ page import="java.sql.*"%>
<%@ page contentType="text/html;charset=GB2312"%>
<%@ include file="opendata.jsp"%>
<%
  int count=0,lastp,numf,numl,prep,nextp,pageno;   
  if(request.getParameter("pageno")==null)      //pageno:代表页码
        pageno=0;
  else
        pageno=Integer.parseInt(request.getParameter("pageno"));
  sql="select * from message";
  rs=smt.executeQuery(sql);
  while(rs.next())
       count++;                                                       <%-- count:多少留言--%>
  lastp=(int)Math.ceil((double)count/5);                     
<%--用来计算此表中有几页留言:ceil返回大于等于其数字参数的最小整数。

Math.ceil(number)

必选项number 参数是数值表达式。

说明
返回值为大于等于其数字参数的最小整数。 --%>
  if(pageno==0||pageno>lastp)
       pageno=lastp;
  numf=pageno*5-4;                                                    <%--显示留言的第一笔数据的编号_id--%>
  numl=numf+4;<%--numl:此页的最后的一笔数据编号id--%>
  if(pageno==1)
       prep=1;                                                           <%-- prep:上一页--%>
  else
      prep=pageno-1;
  if(pageno==lastp)
      nextp=lastp;
  else
      nextp=pageno+1;
  sql="select * from message where id between "+numf+" and "+numl;
  rs=smt.executeQuery(sql);

%>

<font size=7 color=green>留言板</font>
<hr>
<center>
<form action=board.jsp method=POST>
<table boder=0>
  <tr>
       <td>目前的页次<font color=red><%=pageno%></font>/<font color=blue><%=lastp%></font></td>
    <td><a href=board.jsp?pageno=<%=prep%>>[上一页]</a></td>
<%--将参数pageno传递给程序,依据它来计算numl和numf,再将留言数据通过sql取出--%>
    <td><a href=board.jsp?pageno=<%=nextp%>>[下一页]</a></td>
    <td><a href=board.jsp?pageno=1>[第一页]</a></td>
    <td><a href=board.jsp>[最后一页]</a></td>
    <td>输入页次<input type=text size=3 name=pageno></td>
    <td><input type=submit name=SEND value=送出></td>
    <td><a href=password.jsp><font color=red size="5"><i>站长专用</i></font></a></td>
  </tr>
</table>
</form>
<%
   String name,email,subject,time,sex,memo;
   while(rs.next())
   {
      name=rs.getString(1);
   email=rs.getString(2);
   subject=rs.getString(3);
   time=rs.getString(4);
   sex=rs.getString(5);
   memo=rs.getString(6);
      out.print("<center>");
   out.print("<table border=1>");
   out.print("<tr><td bgcolor=yellow>姓名</td><td>"+name+"</td></tr>");
   out.print("<tr><td bgcolor=yellow>E-mail</td><td>"+email+"</td></tr>");
   out.print("<tr><td bgcolor=yellow>时间</td><td>"+time+"</td></tr>");
      out.print("<tr><td bgcolor=yellow>主题</td><td>"+subject+"</td></tr>");
   out.print("<tr><td bgcolor=yellow>留言</td><td>"+memo+"<img src="+sex+"></td></tr>");
   out.print("</table><p>");

   }
%>
<hr>
<center><a href="message.html">我要留言</a>
<a href=board.jsp>查看留言</a>

</BODY>
</HTML>

一、设计目的 留言系统目前在各类网站中被广泛使用。通过综合运用JSP、Servlet、JavaBean、JDBC、MySQL和MVC + DAO等技术与方法,设计与实现一个留言管理系统,进一步理解和掌握Java Web编程开发的基本技术和方法,熟练使用开发工具。 二、课程设计内容 设计留言管理系统的目的是提供对留言的增加、删除、修改和显示的功能。 系统分前台和后台两个模块1)前台留言模块主要针对普通用户,按功能又分为以下模块(1) 发表留言(即添加留言) 普通用户可以在留言管理系统中随意留言,如果留言的字数太少如低于10个字符,系统将给出提示。 (2) 查看留言 可以浏览留言(即查看留言列表)、查看详细留言(即查看某条留言内容)、搜索留言(即查看符合条件的留言列表)、查看友情链接(即导航到别的网站)。 2)后台模块(管理模块)针对管理员提供操作,按功能又分为以下模块(1) 登录管理:需要输入管理员账号、口令和验证码,系统将验证、口令和验证码是否正确,如果验证成功,则进入管理员界面;否则,系统提示账号或密码错误的信息。 另外,登录后的管理员可以选择退出登录,进而退出管理界面。(实现提示:将退出请求提交给处理退出的Servlet,在该Servlet中将session失效,再将页面重定向到登录页面。) (2) 留言管理:可以查看所有的留言,可以增加留言(即回复留言)、修改留言、删除留言。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值