Struts2简单的图书管理系统

一、实现的功能:

  • 用户的登录(将登录信息存入到session中)
  • 展示图书列表(从数据库中取出所有图书信息,存入到List集合中)
  • 点击查看详情,可以查看图书的具体信息。

二、项目结构:

这里写图片描述

com.hlk.action—Controller控制层
com.hlk.dao—数据持久层
com.hlk.pojo—普通的bean对象
com.hlk.util—工具类

三、运行截图:

将从数据库中取出的图书信息放到一个List集合中,然后将该集合存到session中。
用户名和图书信息都是从session中获取显示。

主页面:

这里写图片描述

点击查看详情:

这里写图片描述

四:代码实现:

1、数据库的工具类:JdbcUtil.java

public class JdbcUtil {
	
	private static final String driver="com.mysql.jdbc.Driver";
	private static final String url="jdbc:mysql://localhost:3306/book?useUnicode=true&characterEncoding=UTF-8";
	private static final String username="root";
	private static final String password="";
	
	public static Connection getConnection() {
		Connection conn=null;
		try {
			Class.forName(driver);				//注册驱动
			conn = DriverManager.getConnection(url,username,password);//获得连接对象
		} catch (ClassNotFoundException e) {	//捕获驱动类无法找到异常
			e.printStackTrace();										
		} catch (SQLException e) {					//捕获SQL异常
			e.printStackTrace();
		}
		return conn;
	}
	
	public static void close(Connection conn,Statement st,ResultSet rs){
		try {
			if(rs!=null)
				rs.close();
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		try {
			if(st!=null)
				st.close();
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		try {
			if(conn!=null)
				conn.close();
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
}

2、Dao层(数据持久层)

UserDao.java:

public class UserDao {
	
	public User findUser(String username,String password) {
		Connection conn = JdbcUtil.getConnection();
		PreparedStatement stmt = null;	
		ResultSet rs = null;
		User user = null;
		String sql = "SELECT username,password FROM user WHERE";
		sql+=" username = ? AND password = ?";
		try {
			stmt = conn.prepareStatement(sql);
			stmt.setString(1, username);
	        stmt.setString(2, password);
	        rs = stmt.executeQuery();
	        while (rs.next()) {
	        	user = new User();
	        	user.setUsername(rs.getString(1));
	        }
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} finally {
			JdbcUtil.close(conn, stmt, rs);
		}
        return user;
	}
}

BookDao.java:

public class BookDao {
	
	public List<Book> list() {
		List<Book> books = new ArrayList<Book>();
		Connection conn = JdbcUtil.getConnection();
		Statement st = null;
		ResultSet rs = null;
		try {
			st = conn.createStatement();
			String sql = "select * from book";
			rs = st.executeQuery(sql);
			while(rs.next()) {
				Book book = new Book();
				book.setId(rs.getInt("id"));
				book.setName(rs.getString("name"));
				book.setInfo(rs.getString("info"));
				book.setDate(rs.getDate("date"));
				book.setAuthor(rs.getString("author"));
				books.add(book);
			}
			return books;
		} catch (Exception e) {
			// TODO: handle exception
			e.printStackTrace();
		} finally {
			JdbcUtil.close(conn, st, rs);
		}
		return null;
	}
}

3、Action类:(Controller控制层)

UserAction.java:

public class UserAction extends ActionSupport implements ModelDriven<User>,SessionAware {
	
	private static final long serialVersionUID = 1L;
	private Map<String,Object> session;
	public Map<String, Object> getSession() {
		return session;
	}
	public void setSession(Map<String, Object> session) {
		this.session = session;
	}
	
	User user = new User();
	public User getModel() {
		return user;
	}
	
 	public String login() throws Exception {
 		
 		UserDao userDao = new UserDao();
 		User session_user = userDao.findUser(user.getUsername(),user.getPassword());
 		if(session_user == null) {
 			return "error";
 		} else {
 			session.put("session_user", user.getUsername());
 			return "success";
 		}
	}
 
}

BookAction.java:

public class BookAction extends ActionSupport implements SessionAware {
	
	private static final long serialVersionUID = 1L;
	
	private Map<String, Object> session;
	
	public Map<String, Object> getSession() {
		return session;
	}
	public void setSession(Map<String, Object> session) {
		this.session = session;
	}

	List<Book> books = new ArrayList<Book>();
	public String list() throws Exception {
		// TODO Auto-generated method stub
		BookDao bookDao = new BookDao();
		books = bookDao.list();
		session.put("books", books);
		return "success";
	}

}

4、View层:

book.jsp:

<body>
    <div class="container">
        <h1>图书管理系统</h1>
		系统提示:您好,<s:property value="#session.session_user"/>,登录成功!
		<hr/>
        <h3>所有图书 <a href="" type="button" class="btn btn-primary btn-sm">添加</a></h3>

           <table class="table table-bordered table-striped" id="table">
               <tr>
                   <th>ID</th>
                   <th>书名</th>
                   <th>照片</th>
                   <th>信息</th>
                   <th>发布日期</th>
                   <th>作者</th>
                   <th>操作</th>
               </tr>
               <s:iterator id="book" value="#session.books" status="vs">
                 <tr>
                     <td><s:property value="#book.id"/></td>
                     <td>《<s:property value="#book.name"/>》</td>
                     <td><img src="images/<s:property value="#book.name"/>.jpg" /></td>
                     <td><s:property value="#book.info"/></td>
                     <td><s:property value="#book.date"/></td>
                     <td><s:property value="#book.author"/></td>
                     <td>
                         <a id="<s:property value="#vs.index+1"/>" onclick="editInfo(this)" type="button" class="btn btn-sm btn-success" data-toggle="modal" data-target="#my_modal">详情</a>
                         <a type="button" class="btn btn-sm btn-warning">修改</a>
                         <a type="button" class="btn btn-sm btn-danger">删除</a>
                     </td>
                 </tr>
               </s:iterator>
           </table>
    </div>
	
	<div class="modal" id="my_modal" tabindex="-1" role="dialog" aria-labelleby="myModallabel">
		<div class="modal-dialog">
			<div class="modal-content">
				<div class="modal-header">
					<button  type="button" class="close" data-dismiss="modal" aria-label="Close">
						<span aria-hidden="true">&times;</span>
					</button>
					<h4 class="modal-title" id="myModallabel">详细信息</h4>
				</div>
				<div class="modal-body" id="b">
					书名:	<scan id="b_name"></scan><hr/>
					信息:	<scan id="b_info"></scan><hr/>
					作者:	<scan id="b_author"></scan><hr/>
					日期: 	<scan id="b_date"></scan>
				</div>
				<div class="modal-footer">
					<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
					<button type="button" class="btn btn-primary">Save</button>
				</div>
			</div>
		</div>
	</div>
</body>
<script type="text/javascript">
	function editInfo(obj) {
		var id = $(obj).attr("id");
	    //获取表格中的一行数据  
	    var t = $('#table')[0];
	    var name = t.rows[id].cells[1].innerText;  
	    var info = t.rows[id].cells[3].innerText;  
	    var date = t.rows[id].cells[4].innerText;  
	    var author = t.rows[id].cells[5].innerText;  
	    //向模态框中传值  
	    $('#b_name').text(name);
	    $('#b_info').text(info);  
	    $('#b_date').text(date); 
	    $('#b_author').text(author);
	}
</script>
<script type="text/javascript" src="js/jquery-2.1.1.min.js"></script>
<script type="text/javascript" src="js/bootstrap.min.js"></script>

在这里使用了<s:iterator></s:iterator>迭代标签,通过stutus.index遍历元素的索引。这里注意一下,元素的索引是从0开始的。

<a id="<s:property value="#vs.index+1"/>" onclick="editInfo(this)" type="button" class="btn btn-sm btn-success" data-toggle="modal" data-target="#my_modal">详情</a>

点击详情,启动了模态框的同时,调用了editInfo的方法,向模态框中写入了信息。

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
一.功能简介 1. 实现一个图书管理系统。图书信息存放到一个数据库中。图书包含信息:图书号、图书名、作者、价格、备注字段。 2. 系统实现如下的基本管理功能: (1)用户分为两类:系统管理员,一般用户。 (2)提供用户注册和用户登录验证功能;其中登录用户的信息有:登录用户名,登录密码等。 (3)管理员可以实现对注册用户的管理(删除),并实现对图书的创建、查询、修改和删除等有关的操作。 (4)一般用户,只能查询图书,并进行借书、还书操作,每个用户最多借阅8本,即当目前借书已经是8本,则不能再借书了,只有还书后,才可以再借阅。 二.涉及技术 Struts2框架、MySQL数据库、C3P0数据池、Jsp、HTML、CSS、JavaScript等技术。 三.设计思路 1. 基于Struts2框架进行编程设计,连接MySQL数据库实现数据的增删查改,应用Jsp、HTML、CSS、JavaScript对访问页面进行编写和美化。 2. 分别创建book表和user表,用以存放图书信息和用户数据。其中user表中,设有flag以区分管理员和普通用户。 3. 分别创建Book类和User类,与数据表相对应。每本书和每个用户都有唯一的id与之对应。 4. 创建C3P0属性文件和数据库连接工具类。 5. 设计数据库操作类:UserDao类和BookDao类。UserDao用于实现所有对user表的操作,BookDao用于实现所有对book表的操作。 6. 创建分别对应UserDao类和BookDao类的Action:UserAction和BookAction。采用基于注解的方式进行Action配置。 7. 用户账号分为管理员账号和普通用户账号,注册时加以区分,登录时即可自动判断进入对应的操作主页面。 8. 管理员可实现对用户的查询显示,模糊查询,删除,批量删除,全选和取消全选等功能;可实现对图书的查询显示,模糊查询,添加,删除,批量删除,全选和取消全选等功能。 9. 普通用户可实现借书和还书功能,借书功能通过对book表的查询,将未借出的图书按照id顺序排列显示,点击表格后方的“借阅”按钮,进行确认借阅,将book表中本书的borrowperson列的值改为本用户账号。对于借阅成功的图书可以在“当前借阅”中进行查看。还书功能通过在“当前借阅”中点击“还书”按钮,进行确认还书,将book表中本书的borrowperson列的值改为“空”,本书信息将可以在“借书”界面查看。 四.存在的问题 1. 原本希望能为每一个用户创建一个对应的以其账号命名的数据表,用以存放用户所借图书信息,但创建表的SQL语句无法在java代码中执行,所以只好在book表中添加一列borrowperson,用来存放借阅本书的用户账号,这样查询用户当前借阅记录时,以“where borrowperson=‘account’”为条件对book表进行查询即可。但是每个用户要当前查询借阅记录时都需要对整个book表进行遍历,效率太低。 2. 模糊查询时,因同时需要进行where筛选,SQL语句无法执行,只好分开查询,先进行模糊查询,查询结果存放到list表中,再通过遍历list表进行判断是否符合where的条件,若符合,则存入另一个list表中。这种方法虽然实现了查询,但效率太低,代码过于繁重。 五.改进预想 这些本不应该是预想,原本希望在本次作业中实现的,但时间不够充分,只能作为下一步的改建预想。 1. 希望实现登录时验证码验证登录; 2. 希望实现查询时,查询结果分页浏览; 3. 进一步优化Action之间的传值方法; 4. 页面进一步优化、美化; 5. 实现用户借书还书时间记录,和借阅时长限制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值