Struts2之图书管理系统

趁着周末,梳理一下前几周学的struts2,回顾起struts2,它和springmvc同是action层的解决方案,讲图书系统的同时,先让我们了解一下三层架构,以SSH框架为例。

参考来源:http://blog.csdn.net/inter_peng/article/details/41021727

1.Action/Service/DAO简介:

Action是管理业务(Service)调度和管理跳转的。

Service是管理具体的功能的。

Action只负责管理,而Service负责实施。

DAO只完成增删改查,虽然可以1-n,n-n,1-1关联,模糊、动态、子查询都可以。但是无论多么复杂的查询,dao只是封装增删改查。至于增删查改如何去实现一个功能,dao是不管的。

总结这三者,通过例子来解释:

Action像是服务员,顾客点什么菜,菜上给几号桌,都是ta的职责;

Service是厨师,action送来的菜单上的菜全是ta做的;

Dao是厨房的小工,和原材料打交道的事情全是ta管。

相互关系是,小工(dao)的工作是要满足厨师(service)的要求,厨师要满足服务员(action)转达的客户(页面用户)的要求,服务员自然就是为客户服务喽。

现在最基本的分层方式,结合了SSH架构。Model层就是对应的数据库表的实体类。Dao层是使用了Hibernate连接数据库、操作数据库(增删改查)。Service层:引用对应的Dao数据库操作。Action层:引用对应的Service层,在这里结合Struts的配置文件,跳转到指定的页面,当然也能接受页面传递的请求数据,也可以做些计算处理。

以上的Hibernate, Struts,都需要注入到Spring的配置文件中,Spring把这些联系起来,成为一个整体。

My understanding is that action是服务员,负责接收前台顾客订餐要求并传达给厨师(service),而厨师需要依赖小工(dao)们处理好的原材料调味、炒成美味的菜.dao层不实现具体功能,只实现单一增删改查,而厨师则需要妙笔生花,将原材料组成美味佳肴,而后服务员把成菜端给前台顾客。

接下来正式开始struts2的学习。

2.action层控制组件不再用servlet,而使用一个个action

1.项目开始时,加入struts2的依赖

<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-core</artifactId>
<version>2.5.5</version>
</dependency>

2.web.xml加上过滤器,拦截所有的.action的请求传递给struts2处理

<filter>
<filter-name>struts2</filter-name>
<filter-class>

<!--每个版本的struts2过滤器类不一致-->
org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

3.struts.xml是struts2使用必备的配置文件,一个字也不能错。

<struts>
<package name="default" namespace="/" extends="struts-default">
<!--action请求通配符,比如book_insert.action转到BookAction中的insert方法处理-->
<!--默认为execute()方法执行-->
<action name="book_*" class="edu.cn.action.BookAction" method="{1}">
<!---返回字符串对应的地址映射-->
<result name="bookList">/bookList.jsp</result>
<result name="editBook">/editBook.jsp</result>
<!--struts2 2.5.5版本不支持通配符映射action,需要设置允许方法的集合-->
<allowed-methods>queryByType,queryAll,insert,edit,editSubmit,delete</allowed-methods>
</action>
</package>
</struts>

3.系统使用dao-service-action三层架构,service层面向接口编程

1.系统包层次

 

2.dao层----负责操作数据库,不实现高层要求的业务功能,只实现简单数据的增删改查。

/**
* dao层之查询所有图书
*
* @return
* @throws Exception
*/
public List<Book> selectAll() throws Exception {
PreparedStatement pstmt = null;
ResultSet result = null;
Connection con = DbConnection.getConnect();
List<Book> list = new ArrayList<Book>();
Book book = null;
try {
pstmt = con.prepareStatement("select isbn,title,type,price from bookta");
result = pstmt.executeQuery();
while (result.next()) {
book = new Book();
book.setIsbn(result.getString(1));
book.setTitle(result.getString(2));
book.setType(result.getString(3));
book.setPrice(result.getDouble(4));
list.add(book);
}

} catch (SQLException e) {
e.printStackTrace();
} finally {
DbConnection.closeResourses(result, pstmt, con);
}

return list;
}

3.service业务层,负责业务逻辑处理,其中包括dao层多个方法的组合调用,包括事务的调用等。

/**
* 调用dao层查询所有图书方法
*
* @return
*/
public List<Book> selectAll() throws Exception {
return bookDao.selectAll();
}

4.action控制层,负责管理service和管理跳转。

/**
* 查询所有图书
*
* @return
* @throws Exception
*/
public String queryAll() throws Exception {
//将bookService.selectAll()返回值命名为booklist属性存入request域,
// 和request.setattribute()方法功能相同
ActionContext.getContext().put("booklist", bookService.selectAll());
msg = "全部图书:";
ActionContext.getContext().put("msg", msg);
return "bookList";
}

5.struts2的属性绑定

但struts2对json数据的支持不好,而springmvc的@ResponseBody(action->ajax为json),@RequestBody(ajax->action为json)支持良好。

6.推荐读取request域中对象属性值使用EL表达式,配合<c:forEach/>标签可以遍历list等集合十分方便。

6.1需要导包

<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>

<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>

6.2写入头标签

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %>
<!--默认不支持EL表达式-->
<%@ page isELIgnored="false" %>

4.完结。

趁着周末,梳理一下前几周学的struts2,回顾起struts2,它和springmvc同是action层的解决方案,讲图书系统的同时,先让我们了解一下三层架构,以SSH框架为例。

参考来源:http://blog.csdn.net/inter_peng/article/details/41021727

1.Action/Service/DAO简介:

Action是管理业务(Service)调度和管理跳转的。

Service是管理具体的功能的。

Action只负责管理,而Service负责实施。

DAO只完成增删改查,虽然可以1-n,n-n,1-1关联,模糊、动态、子查询都可以。但是无论多么复杂的查询,dao只是封装增删改查。至于增删查改如何去实现一个功能,dao是不管的。

总结这三者,通过例子来解释:

Action像是服务员,顾客点什么菜,菜上给几号桌,都是ta的职责;

Service是厨师,action送来的菜单上的菜全是ta做的;

Dao是厨房的小工,和原材料打交道的事情全是ta管。

相互关系是,小工(dao)的工作是要满足厨师(service)的要求,厨师要满足服务员(action)转达的客户(页面用户)的要求,服务员自然就是为客户服务喽。

现在最基本的分层方式,结合了SSH架构。Model层就是对应的数据库表的实体类。Dao层是使用了Hibernate连接数据库、操作数据库(增删改查)。Service层:引用对应的Dao数据库操作。Action层:引用对应的Service层,在这里结合Struts的配置文件,跳转到指定的页面,当然也能接受页面传递的请求数据,也可以做些计算处理。

以上的Hibernate, Struts,都需要注入到Spring的配置文件中,Spring把这些联系起来,成为一个整体。

My understanding is that action是服务员,负责接收前台顾客订餐要求并传达给厨师(service),而厨师需要依赖小工(dao)们处理好的原材料调味、炒成美味的菜.dao层不实现具体功能,只实现单一增删改查,而厨师则需要妙笔生花,将原材料组成美味佳肴,而后服务员把成菜端给前台顾客。

接下来正式开始struts2的学习。

2.action层控制组件不再用servlet,而使用一个个action

1.项目开始时,加入struts2的依赖

<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-core</artifactId>
<version>2.5.5</version>
</dependency>

2.web.xml加上过滤器,拦截所有的.action的请求传递给struts2处理

<filter>
<filter-name>struts2</filter-name>
<filter-class>

<!--每个版本的struts2过滤器类不一致-->
org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

3.struts.xml是struts2使用必备的配置文件,一个字也不能错。

<struts>
<package name="default" namespace="/" extends="struts-default">
<!--action请求通配符,比如book_insert.action转到BookAction中的insert方法处理-->
<!--默认为execute()方法执行-->
<action name="book_*" class="edu.cn.action.BookAction" method="{1}">
<!---返回字符串对应的地址映射-->
<result name="bookList">/bookList.jsp</result>
<result name="editBook">/editBook.jsp</result>
<!--struts2 2.5.5版本不支持通配符映射action,需要设置允许方法的集合-->
<allowed-methods>queryByType,queryAll,insert,edit,editSubmit,delete</allowed-methods>
</action>
</package>
</struts>

3.系统使用dao-service-action三层架构,service层面向接口编程

1.系统包层次

 

2.dao层----负责操作数据库,不实现高层要求的业务功能,只实现简单数据的增删改查。

/**
* dao层之查询所有图书
*
* @return
* @throws Exception
*/
public List<Book> selectAll() throws Exception {
PreparedStatement pstmt = null;
ResultSet result = null;
Connection con = DbConnection.getConnect();
List<Book> list = new ArrayList<Book>();
Book book = null;
try {
pstmt = con.prepareStatement("select isbn,title,type,price from bookta");
result = pstmt.executeQuery();
while (result.next()) {
book = new Book();
book.setIsbn(result.getString(1));
book.setTitle(result.getString(2));
book.setType(result.getString(3));
book.setPrice(result.getDouble(4));
list.add(book);
}

} catch (SQLException e) {
e.printStackTrace();
} finally {
DbConnection.closeResourses(result, pstmt, con);
}

return list;
}

3.service业务层,负责业务逻辑处理,其中包括dao层多个方法的组合调用,包括事务的调用等。

/**
* 调用dao层查询所有图书方法
*
* @return
*/
public List<Book> selectAll() throws Exception {
return bookDao.selectAll();
}

4.action控制层,负责管理service和管理跳转。

/**
* 查询所有图书
*
* @return
* @throws Exception
*/
public String queryAll() throws Exception {
//将bookService.selectAll()返回值命名为booklist属性存入request域,
// 和request.setattribute()方法功能相同
ActionContext.getContext().put("booklist", bookService.selectAll());
msg = "全部图书:";
ActionContext.getContext().put("msg", msg);
return "bookList";
}

5.struts2的属性绑定

  

但struts2对json数据的支持不好,而springmvc的@ResponseBody(action->ajax为json),@RequestBody(ajax->action为json)支持良好。

6.推荐读取request域中对象属性值使用EL表达式,配合<c:forEach/>标签可以遍历list等集合十分方便。

6.1需要导包

<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>

<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>

6.2写入头标签

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %>
<!--默认不支持EL表达式-->
<%@ page isELIgnored="false" %>

4.完结。

 

若有问题欢迎在下面留言,源代码下载请点击五角星

一.功能简介 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. 实现用户借书还书时间记录,和借阅时长限制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值