package com.easyjf.struts.action;
import org.apache.struts.action.*;
import com.easyjf.example.business.IUserService;
import com.easyjf.example.business.IUser;
import com.easyjf.struts.form.*;
import javax.servlet.http.*;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.WebApplicationContextUtils;
//import org.springframework.beans.BeansException;
import com.easyjf.util.*;
import java.util.*;
import com.easyjf.web.tools.*;
import com.easyjf.util.CommUtil;
public class UserManageAction extends Action
{
private IUserService userService;
public IUserService getUserService()
{
return userService;
}
public void setUserService(IUserService userService)
{
this.userService=userService;
}
public ActionForward execute(ActionMapping mapping,ActionForm form,HttpServletRequest request,HttpServletResponse response) throws Exception
{
WebApplicationContext wac=WebApplicationContextUtils.getRequiredWebApplicationContext(this.getServlet().getServletContext());
this.userService=(IUserService)wac.getBean("userService");
String command=request.getParameter("easyJWebCommand");
if(command==null||"".equals(command)||"list".equals(command)||"query".equals(command))
{
return doQuery(mapping,form,request,response);
}
else if("new".equals(command))
{
return mapping.findForward("edit");
}
else if("add".equals(command))
{
return doAdd(mapping,form,request,response);
}
else if("edit".equals(command))
{
return doEdit(mapping,form,request,response);
}
else if("update".equals(command))
{
return doUpdate(mapping,form,request,response);
}
else if("delete".equals(command))
{
return doDelete(mapping,form,request,response);
}
return super.execute(mapping, form, request, response);
}
public ActionForward doEdit(ActionMapping mapping,ActionForm form,HttpServletRequest request,HttpServletResponse response)
{
UserForm vf=(UserForm)form;
IUser user=null;
if(vf.getCid()!=null&&!vf.getCid().equals(""))
{
user=userService.read(vf.getCid());
}
if(user==null)
{
user=userService.newUser();
}
if(user!=null)
{
vf.setCid(user.getCid());
vf.setUsername(user.getUsername());
vf.setPassword(user.getPassword());
vf.setTel(user.getTel());
vf.setEmail(user.getEmail());
vf.setIntro(user.getIntro());
vf.setBirthday(user.getBirthday());
return mapping.findForward("edit");
}
else
{
request.setAttribute("msg", "找不到数据");
return doQuery(mapping,form,request,response);
}
}
public ActionForward doUpdate(ActionMapping mapping,ActionForm form,HttpServletRequest request,HttpServletResponse response)
{
IUser user=(IUser)form2Po(form);
if(userService.update(user))
{
request.setAttribute("msg", "数据修改成功!");
return doQuery(mapping,form,request,response);
}
else
{
request.setAttribute("msg", "数据修改失败!");
return mapping.getInputForward();
}
}
public ActionForward doAdd(ActionMapping mapping,ActionForm form,HttpServletRequest request,HttpServletResponse response)
{
IUser user=(IUser)form2Po(form);
if(user==null)
{
request.setAttribute("msg", "无法创建要保存的对象,添加失败!");
return mapping.getInputForward();
}
if(userService.save(user))
{
request.setAttribute("msg", "数据添加成功!");
return doQuery(mapping,form,request,response);
}
else
{
request.setAttribute("msg", "数据添加失败!");
return mapping.getInputForward();
}
}
public ActionForward doQuery(ActionMapping mapping,ActionForm form,HttpServletRequest request,HttpServletResponse response)
{
int currentPage=CommUtil.null2Int(request.getParameter("page"));
int pageSize=CommUtil.null2Int(request.getParameter("pageSize"));
if(currentPage<1)
{
currentPage=1;
}
if(pageSize<1)
{
pageSize=15;
}
String scope="1=1";
Collection paras=new ArrayList();
String orderType=CommUtil.null2String(request.getParameter("orderType"));
String orderField=CommUtil.null2String(request.getParameter("orderField"));
String userName=CommUtil.null2String(request.getParameter("queryUserName"));
String tel=CommUtil.null2String(request.getParameter("queryTel"));
if(!userName.equals(""))
{
scope+=" and username like ?";
paras.add("%"+userName+"%");
}
if(!tel.equals(""))
{
scope+=" and tel like ?";
paras.add("%"+tel+"%");
}
if(orderField.equals(""))
{
orderField="username";
orderType="desc";
}
if(!orderField.equals(""))
{
scope+=" order by "+orderField;
if(!orderType.equals(""))
{
scope+=" "+orderType;
}
}
IPageList pList=new PageList(new ListQuery(userService.query(scope, paras)));
pList.doList(pageSize, currentPage, "", "");
if(pList!=null)
{
request.setAttribute("list", pList.getResult());
request.setAttribute("pages", new Integer(pList.getPages()));
request.setAttribute("rows", new Integer(pList.getRowCount()));
request.setAttribute("page", new Integer(pList.getCurrentPage()));
request.setAttribute("gotoPageHTML", CommUtil.showPageHtml(pList.getCurrentPage(), pList.getPages()));
}
request.setAttribute("orderType", orderType);
request.setAttribute("orderField",orderField);
return mapping.findForward("list");
}
public ActionForward doDelete(ActionMapping mapping,ActionForm form,HttpServletRequest request,HttpServletResponse response)
{
UserForm uf=(UserForm)form;
IUser user=null;
if(uf.getCid()!=null&&!uf.getCid().equals(""))
{
user=userService.read(uf.getCid());
}
if(user!=null&&userService.delete(user))
{
request.setAttribute("msg", "数据删除成功!");
}
else
{
request.setAttribute("msg", "数据删除失败!");
}
return doQuery(mapping,form,request,response);
}
public IUser form2Po(ActionForm form)
{
UserForm vf=(UserForm)form;
IUser user=null;
if(vf.getCid()!=null&&!vf.getCid().equals(""))
{
user=userService.read(vf.getCid());
}
if(user==null)
{
user=userService.newUser();
}
user.setUsername(vf.getUsername());
user.setBirthday(vf.getBirthday());
user.setEmail(vf.getEmail());
user.setTel(vf.getTel());
user.setPassword(vf.getPassword());
user.setIntro(vf.getIntro());
return user;
}
}
java ss1h框架增删改查
Java SSH 框架是企业级Web应用开发的常用组合,由Spring、Struts和Hibernate三个开源框架集成。本教程将深入讲解如何利用这三个组件构建一个具备增删改查功能的MVC模式应用。 Spring框架是核心的依赖注入(DI)和面向切面编程(AOP)容器,它负责管理应用中的对象和事务。在Java SS1H框架中,Spring提供了对其他两个框架的整合支持,使得业务逻辑和持久层操作可以无缝衔接。 Struts作为MVC模式的前端控制器,处理HTTP请求,将用户交互转发到对应的业务逻辑,并返回响应结果。在"java ss1h框架增删改查"的场景下,Struts的Action类是关键,它接收请求,调用Service层的方法,执行相应的CRUD操作,并将结果转发给视图层展示。 Hibernate则是负责数据库操作的ORM(对象关系映射)框架,它允许开发者以面向对象的方式操作数据库,减少了SQL的编写工作。在增删改查操作中,Hibernate通过实体类映射数据库表,使用Session接口进行CRUD操作,如save()、delete()、update()和load()等方法。 在实现列表翻页功能时,我们需要结合Struts的拦截器和Hibernate的分页查询。Struts的拦截器可以统计总记录数,而Hibernate的Criteria或HQL查询则用于根据当前页码和每页记录数获取对应的数据子集。 在具体开发过程中,我们通常会定义以下组件: 1. **实体类(Entities)**:与数据库表相对应,包含属性和getter/setter方法。 2. **Hibernate配置文件(Hibernate.cfg.xml)**:配置数据库连接信息和映射文件。 3. **映射文件(.hbm.xml)**:定义实体类和数据库表之间的映射关系。 4. **DAO(Data Access Object)**:处理与数据库的交互,包括增删改查操作。 5. **Service(Service层)**:业务逻辑层,调用DAO实现具体功能。 6. **Action(Struts Action)**:接收和处理HTTP请求,调用Service层并控制流程。 7. **JSP(视图)**:显示数据,可能包含JSTL标签和EL表达式来简化页面逻辑。 在进行增删改查操作时,需要注意以下几个关键点: 1. **事务管理**:Spring通过AOP进行事务管理,确保在出现异常时能够回滚,保证数据一致性。 2. **错误处理**:使用Struts的异常拦截器捕获并处理可能出现的业务异常,提供友好的错误提示。 3. **安全性**:防止SQL注入和XSS攻击,对输入数据进行校验和过滤。 4. **性能优化**:合理设计数据库索引,避免全表扫描,使用缓存提高访问速度。 在实际项目中,为了提高代码复用性和可维护性,可以采用Maven或Gradle进行依赖管理,使用Spring Boot简化配置,以及引入MyBatis等现代ORM工具替换部分Hibernate功能。同时,可以结合前端框架如Vue.js或React实现更复杂的交互效果,提升用户体验。 总结来说,"java ss1h框架增删改查"涉及了Spring、Struts和Hibernate的协同工作,涵盖了MVC模式的核心概念,以及数据库操作、事务管理、安全控制和性能优化等多个方面。理解并熟练掌握这些知识点,对于开发高效、稳定的Web应用至关重要。
- 1
- 2
- #完美解决问题
- #运行顺畅
- #内容详尽
- #全网独家
- #注释完整
- 粉丝: 1
- 资源: 5
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- ssm基于Vue框架的订餐系统+vue.zip
- ssm基于Vue.js的在线购物系统的设计与实现+vue.zip
- ssm基于Tomcat技术的车库智能管理平台+jsp.zip
- ssm基于SSM框架云趣科技客户管理系统+jsp.zip
- ssm基于SSM框架的微博系统+vue.zip
- ssm基于SSM框架的校园代购服务订单管理系统的设计与实现+vue.zip
- ssm基于SSM框架的网上拍卖系统的设计与实现+vue.zip
- ssm基于SSM框架的企业博客网站的设计与实现+vue.zip
- 昆仑通态MCGS与力士乐VFC-x610变频器通讯 实现昆仑通态触摸屏与力士乐VFC-x610变频器通讯,程序稳定可靠 器件:昆仑通态TPC7062KD触摸屏,力士乐VFC-x610变频器,附送接线说
- MATLAB simulink MIL SIL单元测试,模型在环测试,软件在环测试,测试步骤文档,包含期望输出和实际输出的比较,输出测试报告pass或fail状态
- 台达DVP PLC与力士乐VFC-x610变频器通讯程序程序带注释,并附送昆仑通态程序,有接线方式,设置 器件:台达DVP ES系列的PLC,力士乐VFC-x610系列变频器,昆仑通态 功能:实现频
- 知识付费管理系统源码,移动端uniApp开发,app h5 小程序一套代码多端运行,后端php(tp6)+layui+MySQL,功能齐全,直播,点播,管理,礼物等等功能应有尽有
- Step7-Mricro win S7-200 485轮询 西门子485 modbus RTU 200 ModbusRTU通信S7-200与最大32个从站RS 485主站程序,程序块自动轮询,无需编写
- 2024年度项目总结1.0
- Java 正则表达式的应用及其实现 - 基于Pattern与Matcher类的邮件和电话匹配
- fpga数据手册杂七杂八1.0