zoukankan      html  css  js  c++  java
  • JSP第十周作业5.8

    图书管理器

    数据库设计

    CREATE TABLE bookmanage(
    b_id BIGINT AUTO_INCREMENT PRIMARY KEY NOT NULL, 
    b_name VARCHAR(40) NOT NULL,
    b_author VARCHAR(40) NOT NULL,
    b_date DATETIME NOT NULL, b_type INT NOT NULL )ENGINE=INNODB DEFAULT CHARSET=utf8;

      

    主界面:index.jsp

    <%@ page import="com.jjy.bean.BookManage"%>
    <%@ page import="com.jjy.dao.BookManageDao"%>
    <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
    <%
    	String path = request.getContextPath();
    	String basePath = request.getScheme() + "://"
    			+ request.getServerName() + ":" + request.getServerPort()
    			+ path + "/";
    %>
    
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    <head>
    <base href="<%=basePath%>">
    
    <title>个人图书管理</title>
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
    <!--
    	<link rel="stylesheet" type="text/css" href="styles.css">
    	-->
    </head>
    
    <body>
    	<h1>图书信息</h1>
    	<table border="1">
    		<tr>
    			<td>图书编号</td>
    			<td>图书名称</td>
    			<td>图书作者</td>
    			<td>购买时间</td>
    			<td>图书分类</td>
    			<td>操作</td>
    		</tr>
    		<%
    			BookManageDao book = new BookManageDao();
    			List<BookManage> list = book.selectBookAll();
    			for (int i = 0; i < list.size(); i++) {
    		%>
    		<tr>
    			<td><%=list.get(i).getB_id()%></td>
    			<td><%=list.get(i).getB_name()%></td>
    			<td><%=list.get(i).getB_author()%></td>
    			<td><%=list.get(i).getB_time()%></td>
    			<td><%int x = list.get(i).getB_type();
    					if (x == 1) {
    				%> <label>小说/文摘</label> <%
     					} else if (x == 2) {
     				%> <label>计算机/软件</label> <%
     					} else if (x == 3) {
    				%> <label>杂项</label> <%
    				 	}
    				%>
    			</td>
    			<td><a href="del.jsp?b_id=<%=list.get(i).getB_id()%>" onclick="del()">删除</a></td>
    		</tr>
    		<%
    			}
    		%>
    	</table>
    	<a href="newbook.jsp">新增图书信息</a>
    </body>
    <script type="text/javascript">
    function del(){ 
    if(confirm('确定要删除吗?')){
    
    }else{
    
    }
    }
    </script>
    </html>
    

      

    添加图书界面 newbook.jsp

    <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
    <%
    	String path = request.getContextPath();
    	String basePath = request.getScheme() + "://"
    			+ request.getServerName() + ":" + request.getServerPort()
    			+ path + "/";
    %>
    
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    <head>
    <base href="<%=basePath%>">
    
    <title>添加图书信息</title>
    
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
    <!--
    	<link rel="stylesheet" type="text/css" href="styles.css">
    	-->
    
    </head>
    
    <body>
    	<form action="getnewbook.jsp" onsubmit="return validate_form(this)"
    		method="post">
    		<table>
    			<tr>
    				<th>新增图书信息</th>
    			</tr>
    			<tr>
    				<td>图书名称:</td>
    				<td><input type="text" name="newbookname">
    				</td>
    			</tr>
    			<tr>
    				<td>图书作者:</td>
    				<td><input type="text" name="newbookauthor">
    				</td>
    			</tr>
    			<tr>
    				<td>购买日期:</td>
    				<td><input type="text" name="newbookdate">
    				</td>
    				<td>yyyy-MM-dd格式</td>
    			</tr>
    			<tr>
    				<td>图书类别:</td>
    				<td><select id="select" name="select">
    						<option value="">选择所属分类</option>
    						<option value="1">小说/文摘</option>
    						<option value="2">计算机/软件</option>
    						<option value="3">杂项</option>
    				</select>
    			</tr>
    		</table>
    		<input type="submit" value="添加图书">
    	</form>
    
    	<script type="text/javascript">
    function validate_required(field,alerttxt)
    {
    with (field)
      {
      if (value==null||value=="")
        {alert(alerttxt);return false}
      else {return true}
      }
    }
    
    function validate_form(thisform)
    {
    
    var slt=document.getElementById("select");
    if(slt.value==""){
    alert("请选择分类");
    return false;
    }
    with (thisform)
      {
      if (validate_required(newbookname,"书名不能为空")==false)
        {newbookname.focus();return false}
        if (validate_required(newbookauthor,"作者不能为空")==false)
        {newbookauthor.focus();return false}
        if (validate_required(newbookdate,"时间不能为空")==false)
        {newbookdate.focus();return false}
      }
    }
    </script>
    </body>
    </html>
    

    添加图书内容收集界面getnewbook.jsp

    <%@ page import="com.jjy.bean.BookManage"%>
    <%@ page import="com.jjy.dao.BookManageDao"%>
    <%@ page import="java.util.*"%>
    <%@ page import="java.text.*"%>
    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%
    	String path = request.getContextPath();
    	String basePath = request.getScheme() + "://"
    			+ request.getServerName() + ":" + request.getServerPort()
    			+ path + "/";
    %>
    
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'getnewbook.jsp' starting page</title>
    
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
    <!--
    	<link rel="stylesheet" type="text/css" href="styles.css">
    	-->
    
    </head>
    
    <body>
    	<%
    		request.setCharacterEncoding("utf-8");
    		BookManage m = new BookManage();
    		String b_name = request.getParameter("newbookname");
    		b_name.trim();
    		m.setB_name(b_name);
    		String b_author = request.getParameter("newbookauthor");
    		b_author.trim();
    		m.setB_author(b_author);
    		String b_date = request.getParameter("newbookdate");
    		SimpleDateFormat smt = new SimpleDateFormat("yyyy-MM-dd");
    		Date d_datein = smt.parse(b_date);
    		m.setB_time(d_datein);
    		String b_type = request.getParameter("select");
    		int bb_type= Integer.parseInt(b_type);
    		m.setB_type(bb_type);
    		BookManageDao sd = new BookManageDao();
    		if (sd.addbook(m) > 0) {
    	%><p>添加成功</p><a href="index.jsp">点击返回主页面</a>
    	<%
    		} else {
    	%>
    	<p>输入错误,请重新注册</p>
    	<%
    		}
    	%>
    </body>
    </html>

    删除图书内容收集界面 delbook.jsp

    <%@ page import="com.jjy.bean.BookManage"%>
    <%@ page import="com.jjy.dao.BookManageDao"%>
    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    %>
    
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
      <head>
        <base href="<%=basePath%>">
        
        <title>My JSP 'del.jsp' starting page</title>
        
    	<meta http-equiv="pragma" content="no-cache">
    	<meta http-equiv="cache-control" content="no-cache">
    	<meta http-equiv="expires" content="0">    
    	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    	<meta http-equiv="description" content="This is my page">
    	<!--
    	<link rel="stylesheet" type="text/css" href="styles.css">
    	-->
    
      </head>
      
      <body>
      <% 
      request.setCharacterEncoding("utf-8");
    	int b_id=Integer.parseInt(request.getParameter("b_id"));
    	BookManageDao id=new BookManageDao();
    	id.delbook(b_id);
    	request.getRequestDispatcher("index.jsp").forward(request, response);
      %>
        
      </body>
    </html>
    

      

    =====================================================================================

    BookManage.java

    package com.jjy.bean;
    
    import java.util.Date;
    
    public class BookManage {
    	private int b_id;
    	private String b_name;
    	private String b_author;
    	private Date b_time;
    	private int b_type;
    	public int getB_id() {
    		return b_id;
    	}
    	public void setB_id(int b_id) {
    		this.b_id = b_id;
    	}
    	public String getB_name() {
    		return b_name;
    	}
    	public void setB_name(String b_name) {
    		this.b_name = b_name;
    	}
    	public String getB_author() {
    		return b_author;
    	}
    	public void setB_author(String b_author) {
    		this.b_author = b_author;
    	}
    	public Date getB_time() {
    		return b_time;
    	}
    	public void setB_time(Date b_time) {
    		this.b_time = b_time;
    	}
    	public int getB_type() {
    		return b_type;
    	}
    	public void setB_type(int b_type) {
    		this.b_type = b_type;
    	}
    	public BookManage(int b_id, String b_name, String b_author, Date b_time,int b_type) {
    		super();
    		this.b_id = b_id;
    		this.b_name = b_name;
    		this.b_author = b_author;
    		this.b_time = b_time;
    		this.b_type = b_type;
    	}
    	public BookManage() {
    		super();
    		// TODO Auto-generated constructor stub
    	}
    	
    
    }
    

      BookManageDao.java

    package com.jjy.dao;
    
    import java.sql.*;
    import java.util.ArrayList;
    import java.util.List;
    
    import com.jjy.bean.BookManage;
    
    public class BookManageDao extends BaseDao {
    	//显示数据列表
    	public List<BookManage> selectBookAll() {
    		List<BookManage> list = new ArrayList<BookManage>();
    		Connection conn=getConnection();
    		String sql  = "SELECT b_id,b_name,b_author,b_date,b_type FROM bookmanage";
    		PreparedStatement ps = null;
    		ResultSet rs=null;
    		try {
    			
    			ps = conn.prepareStatement(sql);
    			rs=ps.executeQuery();
    			while(rs.next()) {
    				BookManage m = new BookManage();
    				m.setB_id(rs.getInt(1));
    				m.setB_name(rs.getString(2));
    				m.setB_author(rs.getString(3));
    				m.setB_time(rs.getDate(4));
    				m.setB_type(rs.getInt(5));
    				list.add(m);
    			}
    		} catch (SQLException e) {
    			e.printStackTrace();
    		}finally {
    			closeAll(conn,ps,rs);
    		}
    		return list;
    	}
    	//增加数据
    	public int addbook(BookManage m){
    		int i=0;
    		
    		Connection conn=getConnection();
    		String sql="insert into bookmanage(b_name,b_author,b_date,b_type) values(?,?,?,?)";
    		PreparedStatement ps=null;
    		try {
    			ps = conn.prepareStatement(sql);
    		
    			ps.setString(1, m.getB_name());
    			ps.setString(2, m.getB_author());
    			ps.setDate(3,new Date(m.getB_time().getTime()));
    			ps.setInt(4, m.getB_type());
    			i=ps.executeUpdate();
    			
    		} catch (SQLException e) {
    			// TODO Auto-generated catch block
    			e.printStackTrace();
    		}finally{
    			closeAll(conn, ps, null);
    		}	
    		return i;
    	}
    	
    	//删除数据
    	public void delbook(int id){
    		Connection con=getConnection();
    		PreparedStatement ps=null;
    		String sql="delete from bookmanage where b_id=?";
    		try {
    			ps=con.prepareStatement(sql);
    			ps.setInt(1, id);
    			ps.executeUpdate();
    		} catch (SQLException e) {
    			// TODO Auto-generated catch block
    			e.printStackTrace();
    		}finally{
    			closeAll(con, ps, null);
    		}
    		
    		
    	}
    
    
    }
    

      BaseDao.java

    package com.jjy.dao;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    public class BaseDao {
    	//获取连接
    		protected Connection getConnection(){
    			Connection conn=null;
    				try {
    					Class.forName("com.mysql.jdbc.Driver");
    					// 2.建立连接
    					conn = DriverManager.getConnection(
    							"jdbc:mysql://localhost:3306/jsp", "root", "root");
    				} catch (Exception e) {
    					e.printStackTrace();
    				} 
    				return conn;
    		}	
    		
    		
    		//关闭连接
    		protected void closeAll(Connection conn,PreparedStatement ps,ResultSet rs){		
    		try {
    			if(rs != null)
    				rs.close();
    			if(ps != null)
    				ps.close();
    			if(conn != null)
    				conn.close();
    			
    			} catch (SQLException e) {
    				e.printStackTrace();
    			}
    		}
    
    }
    

      

  • 相关阅读:
    SpringBoot 系列教程 web 篇之自定义请求匹配条件 RequestCondition
    SpringBoot 系列教程 JPA 错误姿势之环境配置问题
    react中constructor()和super()的具体含义以及如何使用
    原生js之canvas时钟组件
    js求和运算在可变参数的情况下ES3、ES5和ES6的写法区别
    好用的jquery.animateNumber.js数字动画插件
    sublime text3中设置Emmet输入标签自动闭合
    原生js移动端列表无缝间歇向上滚动
    原生js实现preAll和nextAll方法
    基于SwiperJs的H5/移动端下拉刷新上拉加载更多
  • 原文地址:https://www.cnblogs.com/a000/p/14754830.html
Copyright © 2011-2022 走看看