Struts2框架实现图书管理系统

本文详述了如何利用Struts2框架搭建图书管理系统,包括登录功能、查询图书列表等核心模块的实现,涉及数据库操作、action配置及拦截器等关键部分。

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

用Struts2框架实现图书管理系统

本篇文章主要介绍使用Struts2框架实现图书管理系统的过程,不足之处还请多多提出。

1、首先最基础的是搭建Struts2框架,在框架的基础上完成图书管理系统。

框架的搭建过程这里不做详细讲解,如需参考请看https://blog.csdn.net/weixin_42322648/article/details/83547417
下图是我的框架结构:
在这里插入图片描述
我上图是排列方式纵向排列的,如果和你们有点不同这个没关系。

2、下面我们来分析功能和功能的实现。

首先数据库的建库建表,这里不做详解。
然后就是我们功能的实现,
(1)、登录功能
首先做登录的jsp页面, login.jsp这个页面在user文件夹下,下面附属有完整代码。
然后做登录的action LoginAction.class,这action主要是获取从页面发送过来的数据,对参数进行判断,然后确定是否登录成功。
最后就是配置struts.xml文件,

<package name="user" extends="struts-default" namespace="/user">
		<action name="login" class="com.hnpi.action.LoginAction"
			method="login">
			<result name="success">
				<param name="actionName">bookList</param>
				<param name="namespace">/book</param>
				<param name="method">bookList</param>
			</result>
			<result name="fail" type="redirect">/user/login.jsp</result>
		</action>
</package>

这个只是登录的,会有的地方和下面相连,下面有完整的struts.xml的代码。
(2)、查询图书列表功能
这里就要考虑连接数据库了,要用到工具类,这里命名为DButil.java,然后我们还要用到dao层和service层,这里涉及到接口和接口方法的实现,而主要接口方法的实现在BookDaoImpl.java里面,然后在BookServiceImpl.java里面调用dao层的接口和方法的实现,这样可以做到我们实现一个框架,多写点功能,在BookServiceImpl.java里面调用不同的功能就能实现不能的功能,非常方便。
查询图书列表功能的方法也很简单,首先做图书列表的jsp页面 booklist.jsp,这个页面你在book文件夹下。
然后我们要做查询图书列表的action,这里命名为BookAction.java,这个action里面可以实现多种功能,只要是在dao层和Service层写好接口和方法,这里就可以实现,比如图书的更新,删除,新增图书。

所以以下功能就不再一一介绍,代码如下:
login.jsp 在user文件夹下

<%@ 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>
	</head>
	<body>
		<form action="<%=basePath%>user/login" method="post">
			<table>
				<tr>
					<td>用户名:</td>
					<td><input type="text" name="name" /></td>
				</tr>
				<tr>
					<td>密&nbsp;码:</td>
					<td><input type="text" name="pwd" /></td>
				</tr>
			</table>
			<input type="submit" value="提交" />
		</form>
	</body>
</html>

bookList.jsp 图书列表页面 在book文件夹下:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<%
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>
	<style type="text/css">
		table,table tr th, table tr td {
    		border: 1px solid grey;
   		 }	
	</style>
  </head>
  
  <body>
	  	<a href="<%=basePath %>book/toAddBook">新增图书</a>
	  	<table cellspacing="0">
	  		<thead>
	  			<tr>
	  				<th>编号</th>
	  				<th>书名</th>
	  				<th>作者</th>
	  				<th>ISBN</th>
	  				<th>出版社</th>
	  				<th>操作</th>
	  			</tr>
	  		</thead>
	  		<s:iterator value="#request.books" status="book">
	  			<tr>
	  				<td><s:property value="id"/></td>
	  				<td><s:property value="bookName"/></td>
	  				<td><s:property value="bookAuthor"/></td>
	  				<td><s:property value="bookIsbn"/></td>
	  				<td><s:property value="bookPublish"/></td>
	  				<td><a href='<%=basePath %>book/selectBookById?book.id=<s:property value="id"/>'>更新</a>&nbsp;<a href='<%=basePath %>book/delBook?book.id=<s:property value="id"/>'>删除</a></td>
	  			</tr>
	  		</s:iterator>
	  	</table>
  </bod
一.功能简介 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. 实现用户借书还书时间记录,和借阅时长限制。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值