SpringBoot精选Java学习笔记Spring Boot

Struts2 crud功能实现+高级查询+分页查询

2017-07-02  本文已影响376人  CoderZS

后台功能的实现:

1.创建员工表:t_employee
2.根据表结构创建实体类:Employee
3.定义DAO接口:IEmployeeDAO
4.定义DAO的实现类:EmployeeDAOImpl(暂不实现, 测试先行)
5.定义对应的测试类:EmployeeDAOTest(编写对每个dao方法的测试代码)
6:使用druid连接池抽取JdbcUtil和db.properties文件.
7:编写通用的DAO操作模板JdbcTemplate.
8:编写通用的结果集处理器:BeanHander/BeanListHandler.

前台功能的实现:

01.集成Struts2框架
02.编写EmployeeAction代码和JSP代码
03.网页基本的CRUD测试通过
04.完成高级查询操作(前台)
05.完成分页查询操作(前台)

高级查询+分页查询

1.查询对象的封装(EmployeeQueryObject,QueryObject)
该对象是用户提交的数据的封装,将高级查询和分页数据都封装到该对象中,方便数据的传递
在该对象中提供sql条件字符串的拼接,和sql参数的存放
2.分页结果对象的封装(PageResult)
该对象是对页面中需要显示数据的封装(结果集数据和分页条相关的数据)
3.高级查询+分页查询方法设计
思考用户需要什么数据(返回值的类型)和用户应该要提供什么数据(方法的参数列表的定义)

项目结构划分


DAO暂时不进行叙述了我们把重点放在Struts2上

我们想对下面表格使用struts2进行CRUD+高级查询+分页查询

先把struts2引入项目中

<filter>
<filter-name>Struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>Struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

domain模型

struts.xml

<struts>
<!--开发者模式 -->
<constant name="struts.devMode" value="true"></constant>
<constant name="struts.ui.theme" value="simple" />
<package name="empPkg" extends="struts-default" namespace="/">
    <action name="emp_*" class="com.jd.pss.web.action.EmployeeAction"
        method="{1}">
        <result name="list" type="dispatcher">
            /WEB-INF/views/employee/list.jsp
        </result>
        <result name="success" type="redirectAction">
            emp
        </result>
        <result name="input">
            /WEB-INF/views/employee/input.jsp
        </result>
    </action>
</package>
</struts>

list.jsp

<s:form class="form-inline" role="form">
            <s:hidden name="qo.currentPage" id="currentPage"></s:hidden>
            <div class="form-group">
                <label class="sr-only" for="exampleInputEmail2"></label>
                <s:textfield name="qo.username" class="form-control"
                    id="exampleInputEmail2" placeholder="姓名" />
            </div>
            <div class="form-group">
                <label class="sr-only" for="exampleInputEmail2"></label>
                <s:textfield name="qo.email" class="form-control"
                    id="exampleInputEmail2" placeholder="邮箱" />
            </div>

input.jsp

<s:form id="account_register" name="account_register" namespace="/"
                    action="emp_saveOrUpdate" class="form-horizontal">

                    <s:hidden name="e.id"></s:hidden>

                    <div class="form-group">
                        <label for="account_register_account_username"
                            class="col-sm-2 control-label">用户名</label>
                        <div class="col-sm-4">
                            <s:textfield name="e.username"
                                id="account_register_account_username" class="form-control"
                                placeholder="请输入用户名" />
                        </div>
                        <div class="col-sm-6"></div>
                    </div>
                    <div class="form-group">
                        <label for="account.password" class="col-sm-2 control-label">密码</label>
                        <div class="col-sm-4">
                            <s:password name="e.password" showPassword="true"
                                id="account_register_account_password" class="form-control"
                                placeholder="请输入密码" />
                        </div>

我们需要理解的是以下逻辑:

这就是我们需要现实的界面前提是DAO的crud正常

第一步
第二步 第三步 第四部 第五步 第六步 第七步 第二步

到action类中找到对应的input()方法

第三步 第四步

跳转到input.jsp界面

第五步
e.id做了那些事?这是我们必须要知道的
提交表单会操作action 第六步 第七步 第八步 第九步

更新数据请求转发跳转到list.jsp界面

第一步 第二步 第三步 第四部 第五步 第六步

最后更新数据请求转发跳转到list.jsp界面

第七步

查询结果

查询结果

常见的type值(结果类型):
dispatcher: 表示从Action请求转发到页面(JSP).缺省值
redirect: 表示从Action重定向到页面(JSP).
chain: 表示从Action请求转发到另一个Action.
redirectAction: 表示从Action重定向到另一个Action.

上一篇下一篇

猜你喜欢

热点阅读