学JavaEE也有一段时间了,跟着老师和教材做了不少东西,但是一直以来没时间写博客,今天就把以前写的一个简易留言板简单发一下吧。

 

  • 开发工具

        主要用的开发工具为 MyEclipse(2014、2016均可)、Tomcat 7.0、SQL Server 2016、SSMS数据库管理工具、浏览器等。

  • 下载地址

百度网盘链接:https://pan.baidu.com/s/1c2iCPQ4 提取码:7yxk 

 

  • 开发环境

 

        开发环境为windows系统,已安装配置Java最新版开发环境。

 

  • 主要功能与语言

        登录、注册、并可以在留言板留言,所有留言内容均可见。

 

        所采用JSP+Servlet+JavaBean传统方式,仅限于学习使用。

 

 

  • 主要代码实现

    JSP代码:

 

login.jsp

 

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>  
    <title>登录界面</title>
  </head>
  
  <body bgcolor="#ddd" style="font-family:Microsoft YaHei" >
  <div style="text-align:center;margin-top:120px">
    <h1 >请登录</h1>
    <form action="loginServlet" method="post">
    	<table style="margin-left:40%">
    		<caption>用户登录</caption>
    		<tr>
    			<td>登录名:</td>
    			<td><input name="name" type="text" size="20"></td>
    		</tr>
    		<tr>
    			<td>密码:</td>
    			<td><input name="password" type="password" size="21"></td>
    		</tr>
    	</table> 
    	<input type="submit" value="登录">
    	<input type="reset" value="重置"> 
    </form>
    <br>
    <a href="register.jsp">注册</a>
    </div>
  </body>
</html>

register.jsp

 

 

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>  
    <title>注册界面</title>
  </head>
  
  <body bgcolor="#ddd" style="font-family:Microsoft YaHei" >
  <div style="text-align:center;margin-top:120px">
    <h1 >请注册</h1>
    <form action="registerServlet" method="post">
    	<table style="margin-left:40%">
    		<caption>用户注册</caption>
    		<tr>
    		    <td>ID:</td>
    		    <td><input name="id" type="text" size="20"></td>
    		</tr>
    		<tr>
    			<td>登录名:</td>
    			<td><input name="name" type="text" size="20"></td>
    		</tr>
    		<tr>
    			<td>密码:</td>
    			<td><input name="password" type="password" size="21"></td>
    		</tr>
    	</table> 
    	<input type="submit" value="注册">
    	<input type="reset" value="重置"> 
    </form>
    <br>
    <a href="login.jsp">登录</a>
    </div>
  </body>
</html>

error.jsp

 

 

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>  
    <title>登录出错界面</title>
  </head>
  
  <body bgcolor="#ddd" style="font-family:Microsoft YaHei">
  <div style="text-align:center;margin-top:130px">
    <p>输入的用户名不存在或者密码错误</p>
    <a href="login.jsp">点我返回登陆界面</a>
    </div>
  </body>
</html>

main.jsp

 

 

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@page import="org.model.MessBoar" %>
<%@page import="org.dao.*" %>

<html>
  <head>  
    <title>留言板界面</title>
  </head>

  <body bgcolor="#ddd" >
  <div style="margin-left:35%;margin-top:100px;font-family:Microsoft YaHei">
   <h1 style="margin-left:5%">这里是留言板主界面</h1>
   <form  action="leavemessage.jsp" method="post">
  		<table border="1">
  			<caption>所有留言信息</caption>
  			<tr><th>留言人姓名</th><th>留言时间</th>
				<th>留言标题</th><th>留言内容</th></tr>
  		<%
  			ArrayList<MessBoar> al=new ArrayList<MessBoar>();
  			al= (ArrayList)session.getAttribute("al");
  			if(al!=null){
  				Iterator iter=al.iterator();
  				while(iter.hasNext()){
  				MessBoar mb=(MessBoar)iter.next();
  		%>
  				<tr><td><%= new LoginDao().getName(mb.getId()) %></td>
  					<td><%= mb.getTime().toString() %></td>
  					<td><%= mb.getTitle() %></td>
  					<td><%= mb.getMessage() %></td></tr>
  		<% 
  			}
  			}
  		 %>
  		</table>
  	</form>
   <a style="margin-left:22%" href="leavemessage.jsp">留言</a>
    </div>
  </body>
</html>

leavemessage.jsp

 

 

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@page import="org.model.MessBoar" %>
<%@page import="org.dao.*" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>  
    <title>留言界面</title>
  </head>
  
  <body bgcolor="#ddd" style="font-family:Microsoft YaHei">
  <div style="text-align:center;margin-top:140px">
    <h1 >请留言</h1>
   <form action="leaveMessageServlet" method="post">
  			<table style="margin-left: 37%" border="1">
  			<caption>填写留言信息</caption>
  		    	<tr><td>留言标题</td>
  				<td><input type="text" name="title"/></td></tr>
  			<tr><td>留言内容</td>
  				<td><textarea name="message" rows="5" cols="35"></textarea></td>
			</tr>
  			</table>
  		<input type="submit" value="提交"/>
  		<input type="reset" value="重置"/>
  	</form>
    <a href="main.jsp">返回留言板界面</a>
    </div>
  </body>
</html>

success.jsp

 

 

<%@ page language="java" pageEncoding="gb2312"%>
<html>
<head>
    	<title>成功界面 </title>
</head>
<body>
	<div bgcolor="#ddd" style="margin-left:42%;margin-top:240px;font-family:Microsoft YaHei"">
		留言成功,单击<a href="loginServlet">这里</a>返回主界面。
	</div>
</body>
</html>

 

 

 

 

 

web.xml(配置)

 

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
  <servlet>
  	<servlet-name>loginServlet</servlet-name>
  	<servlet-class>org.servlet.LoginServlet</servlet-class>
  </servlet>
  <servlet-mapping>
  	<servlet-name>loginServlet</servlet-name>
  	<url-pattern>/loginServlet</url-pattern>
  </servlet-mapping>
  	<servlet>
    	<servlet-name>registerServlet</servlet-name>
    	<servlet-class>org.servlet.RegisterServlet</servlet-class>
	</servlet>
	<servlet-mapping>
   	 <servlet-name>registerServlet</servlet-name>
   	 <url-pattern>/registerServlet</url-pattern>
	</servlet-mapping>
  <servlet>
    	<servlet-name>leaveMessageServlet</servlet-name>
    	<servlet-class>org.servlet.LeaveMessageServlet</servlet-class>
	</servlet>
	<servlet-mapping>
   	 <servlet-name>leaveMessageServlet</servlet-name>
   	 <url-pattern>/leaveMessageServlet</url-pattern>
	</servlet-mapping>
  <display-name>messageBoard</display-name>
  <welcome-file-list>
    <welcome-file>login.jsp</welcome-file>
  </welcome-file-list>
</web-app>

DBconn.java

 

 

package org.db;
import java.sql.*;

public class DBconn {
	public static Connection conn;     //Connection对象(链接)
	//连接数据库
	public static Connection getConn(){
		try{
			//加载注册SQLSever的JDBC驱动
			Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
			//编写链接字符串,创建并且获取链接
			conn=DriverManager.getConnection("jdbc:sqlserver://localhost:1433;databaseName=MessageBoard","sa","19961002happy");
			return conn;
		}catch(Exception e){
			e.printStackTrace();
			return null;
		}
	}
	public static void CloseConn(){
		try{
			conn.close();
		}catch(Exception e){
			e.printStackTrace();
		}
	}
}

LoginDao.java

 

package org.dao;
import java.sql.*;
import org.model.*;
import org.db.*;
import java.util.ArrayList;
public class LoginDao {
	Connection conn=DBconn.getConn(); ;                                      //数据库连接对象
	PreparedStatement pstmt;
	public Login checkLogin(String name,String password){ //验证用户名密码
		try{
			pstmt=conn.prepareStatement("select*from[loginss] where name=? " + " and password=?");
			pstmt.setString(1, name);                     //设置SQL语句参数
			pstmt.setString(2, password);                 //设置SQL语句参数
			ResultSet rs=pstmt.executeQuery();            //执行查询,返回结果集
			if(rs.next()){                                //通过JavaBean保存值
				Login login=new Login();
				login.setId(rs.getInt(1));
				login.setName(rs.getString(2));
				login.setPassword(rs.getString(3));
				login.setRole(rs.getInt(4));
				return login;                             //返回JavaBean对象
			}
			return null;                                  //验证失败返回null
		}catch(Exception e){
			e.printStackTrace();
			return null;
		}
	}
	public  ArrayList<MessBoar> findMbInfo(){
		try{
			ArrayList<MessBoar> al=new ArrayList<MessBoar>();
			pstmt=conn.prepareStatement("select * from [messagess]");
			ResultSet rs=pstmt.executeQuery();
			while(rs.next()){
				MessBoar mb=new MessBoar();
				mb.setId(rs.getInt(1));
				mb.setName(rs.getString(2));
				mb.setTime(rs.getDate(3));
				mb.setTitle(rs.getString(4));
				mb.setMessage(rs.getString(5));
				al.add(mb);
			}
			return al;
		}catch(Exception e){
			e.printStackTrace();
			return null;
		}
	}
		public String getName(int id){
			String name=null;
			try{
				pstmt=conn.prepareStatement("select name from [loginss] where id=?");
				pstmt.setInt(1, id);
				ResultSet rs=pstmt.executeQuery();
				while(rs.next()){
					 name=rs.getString(1);
				}
				return name;
			}catch(Exception e){
				e.printStackTrace();
				return null;
			}
		}

		public boolean addInfo(MessBoar mb){
			try{
				pstmt=conn.prepareStatement("insert into [messagess] values(?,?,?,?,?)");
				pstmt.setInt(1, mb.getId());
				pstmt.setString(2, mb.getName());
				pstmt.setDate(3, mb.getTime());
				pstmt.setString(4, mb.getTitle());
				pstmt.setString(5, mb.getMessage());
				pstmt.executeUpdate();
				return true;
			}catch(Exception e){
				e.printStackTrace();
				return false;
			}
		}
		public boolean insertUser(int id,String name,String password){
			try{
				pstmt=conn.prepareStatement("insert into [loginss] values(?,?,?,?)");
				pstmt.setInt(1, id);
				pstmt.setString(2, name);				
				pstmt.setString(3, password);
				pstmt.setInt(4, 0);
				pstmt.executeUpdate();
				return true;
			}catch(Exception e){
				e.printStackTrace();
				return false;
			}
		}


}

 

 

 

Login.java

 

 

 

 

package org.model;

public class Login {
	private Integer id;
	private String name;
	private String password;
	private int role;
	public Integer getId(){
		return this.id;
	}
	public void setId(Integer id){
		this.id=id;
	}
	public String getName(){
		return this.name;
	}
	public void setName(String name){
		this.name=name;
	}
	public String getPassword(){
		return this.password;
	}
	public void setPassword(String password){
		this.name=password;
	}
	public int getRole(){
		return this.role;
	}
	public void setRole(int role){
		this.role=role;
	}
}

message.java

 

 

package org.model;
import java.sql.*;
public class MessBoar {
	private int id;
	private String name;
	private Date time;
	private String title;
	private String message;
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id=id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name=name;
	}
	public Date getTime() {
		return time;
	}
	public void setTime(Date time) {
		this.time=time;
	}
	public String getTitle() {
		return title;
	}
	public void setTitle(String title) {
		this.title=title;
	}
	public String getMessage() {
		return message;
	}
	public void setMessage(String message) {
		this.message=message;
	}
}

LeaveMessageServlet.java

 

 

package org.servlet;

import java.io.IOException;
import java.sql.Date;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.dao.LoginDao;
import org.model.*;

public class LeaveMessageServlet extends HttpServlet{
	public void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{
		// 设置请求编码
				request.setCharacterEncoding("gb2312");
				// 设置响应编码
				response.setContentType("gb2312");
				// 获取title内容
				String title=request.getParameter("title");
				// 获取message内容
				String message=request.getParameter("message");
				// 从session中取出当前用户对象
				Login leaveMessageBoard=(Login) request.getSession().getAttribute("login");
				// 建立留言表对应JavaBean对象,把数据封装进去
				MessBoar mb=new MessBoar();
				mb.setId(leaveMessageBoard.getId());
				// 参数为获取的当前时间
				mb.setName(leaveMessageBoard.getName());
				mb.setTime(new Date(System.currentTimeMillis()));
				mb.setTitle(title);
				mb.setMessage(message);
				// 调DB类中的方法判断是否插入成功
				if(new LoginDao().addInfo(mb)){
					response.sendRedirect("success.jsp") ;
				}
		}
	public void doPost(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{
		doGet(request,response);
	}
}

LoginServlet.java

 

package org.servlet;
import java.io.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
import org.model.*;
import org.dao.*;
public class LoginServlet extends HttpServlet{
	public void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{
		request.setCharacterEncoding("gb2312");           //设置请求编码
		response.setContentType("gb2312");                //设置响应编码
		LoginDao loginDao= new LoginDao();
		HttpSession session=request.getSession();         // 先获得user对象,如果是第一次访问该Servlet,用户对象肯定为空,但如果是第
		Login l=(Login) session.getAttribute("login");    // 二次甚至是第三次,就不应该再判断该用户的信息
		if(l==null)
			l = loginDao.checkLogin(request.getParameter("name"),request.getParameter("password"));
		if(l!=null){                                      //如果登陆成功
			session.setAttribute("login",l);              //将获取的对象保存在session中
			ArrayList al=loginDao.findMbInfo();           //获取留言板的内容,返回一个数组
			session.setAttribute("al", al);               //把数组保存起来
			response.sendRedirect("main.jsp");            //验证成功跳转到 main.jsp
		}
		else{                                             //验证失败跳转到 error.jsp
			response.sendRedirect("error.jsp");
		}
		}
	public void doPost(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{
		doGet(request,response);
	}
}

 

 

 

RegisterServlet.java

 

 

 

 

package org.servlet;
import java.io.IOException;
import org.dao.*;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class RegisterServlet extends HttpServlet {
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
			request.setCharacterEncoding("gb2312");
			int id=Integer.valueOf(request.getParameter("id"));
			String name=request.getParameter("name");
			String password=request.getParameter("password");
			if(new LoginDao().insertUser(id ,name, password)){
				response.sendRedirect("login.jsp");
			}
		}
	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request,response);
	}
}

 

  • 简单介绍

    粘代码粘得都心累,比较忙就不做太多介绍了。数据库需要自己新建,对应数据类型建立就可以了。下次有空回头复习时再加上详细介绍吧。附上几张效果图。

 

 

 

  • 效果图

留言板怎么做java javaee留言板_JavaWeb

 

 

 

留言板怎么做java javaee留言板_JavaWeb_02

留言板怎么做java javaee留言板_JavaWeb_03

留言板怎么做java javaee留言板_留言板怎么做java_04

留言板怎么做java javaee留言板_JSP+Servlet+JavaBean_05

留言板怎么做java javaee留言板_JSP+Servlet+JavaBean_06

留言板怎么做java javaee留言板_JavaWeb_07

 

好好学习,天天向上~加油~~~

//LoginServlet.java错误已修改 2016/09/02

//数据库语句添加 2016/12/24

数据库创建语句:

 

create database messageBoard
go
use messageBoard

create table loginss
(
	id int not null primary key,
	name varchar(20) not null,
	password varchar(20) not null,
	role int not null
)

create table messagess
(
	id int not null,
	name varchar(20) not null,
	time datetime not null,
	title varchar(20) not null,
	message varchar(50) not null
)

 

上面的表名称需要与LoginDao.java里面的保持一致。