案例53-crm练习修改客户功能实现
1 CustomerAction
完整代码:
package www.test.web.action; import java.io.File; import org.apache.commons.lang3.StringUtils;
import org.hibernate.criterion.DetachedCriteria;
import org.hibernate.criterion.Restrictions; import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven; import www.test.domain.Customer;
import www.test.service.CustomerService;
import www.test.utils.PageBean; public class CustomerAction extends ActionSupport implements ModelDriven<Customer>{ private Customer customer = new Customer(); private CustomerService cs;
private Integer currentPage;
private Integer pageSize; //上传的文件会自动封装到File对象中
//在后台提供一个与前台<input type=file name=photo/> 组件name相同的属性即可。
private File photo;
//在提交的键名后加上固定的后缀FileName,文件的名称会自动封装到属性中。
private String photoFileName;
//在提交的键名后加上固定的后缀ContentType,文件的MIME类型值会自动封装到属性中。
private String photoContentType; //1 获取客户列表
public String list() throws Exception {
//封装离线查询对象
DetachedCriteria dc = DetachedCriteria.forClass(Customer.class); //判断并封装参数
if(StringUtils.isNotBlank(customer.getCust_name())){
dc.add(Restrictions.like("cust_name", "%"+customer.getCust_name()+"%"));
} //1 调用Service查询分页数据(PageBean)
PageBean pb = cs.getPageBean(dc,currentPage,pageSize);
//2 将PageBean放入request域,转发到列表页面显示
ActionContext.getContext().put("pageBean", pb);
return "list";
} //2 保存客户
public String add() throws Exception { if(photo!=null){
System.out.println("文件名称:"+photoFileName);
System.out.println("文件MIME类型:"+photoContentType); //将上传文件保存到指定位置
//renameTo相当于剪切==>复制
photo.renameTo(new File("C:/Users/jepson/Pictures/Saved Pictures/"+photoFileName));
}
//=============================================== //调用service,保存Customer对象
cs.save(customer);
//重定向到Action
return "toList"; } // 3 修改客户
public String toEdit() throws Exception {
// 1调用service层根据id查询客户
Customer c = cs.getById(customer.getCust_id()); // 2将获取到的客户放入request域中
ActionContext.getContext().put("customer", c); return "edit"; } @Override
public Customer getModel() { return customer;
} public CustomerService getCs() {
return cs;
} public void setCs(CustomerService cs) {
this.cs = cs;
} public Integer getCurrentPage() {
return currentPage;
} public void setCurrentPage(Integer currentPage) {
this.currentPage = currentPage;
} public Integer getPageSize() {
return pageSize;
} public void setPageSize(Integer pageSize) {
this.pageSize = pageSize;
} public File getPhoto() {
return photo;
} public void setPhoto(File photo) {
this.photo = photo;
} public String getPhotoFileName() {
return photoFileName;
} public void setPhotoFileName(String photoFileName) {
this.photoFileName = photoFileName;
} public String getPhotoContentType() {
return photoContentType;
} public void setPhotoContentType(String photoContentType) {
this.photoContentType = photoContentType;
}
}
2 CustomerService&CustomerServiceImpl
完整代码:
package www.test.service; import org.hibernate.criterion.DetachedCriteria; import www.test.domain.Customer;
import www.test.utils.PageBean; public interface CustomerService { PageBean getPageBean(DetachedCriteria dc, Integer currentPage, Integer pageSize); //保存客户
void save(Customer customer); //根据id查询客户
Customer getById(Long cust_id); }
package www.test.service.impl; import java.util.List; import org.hibernate.criterion.DetachedCriteria; import www.test.dao.CustomerDao;
import www.test.domain.Customer;
import www.test.service.CustomerService;
import www.test.utils.PageBean; public class CustomerServiceImpl implements CustomerService { private CustomerDao cd;
@Override
// 1 封装一个PageBean返回给web层
public PageBean getPageBean(DetachedCriteria dc, Integer currentPage, Integer pageSize) { // 1 调用dao层查询总记录数
Integer totalCount = cd.getTotalCount(dc); // 2创建pageBean对象
PageBean pb = new PageBean(currentPage, pageSize, totalCount); // 3查询客户列表
List<Customer> list = cd.getPageList(dc,pb.getStart(),pb.getPageSize()); // 4返回pageBean
pb.setList(list);
return pb;
} @Override
// 2 保存客户
public void save(Customer customer) {
//1 维护Customer与数据字典对象的关系
//正常情况下:应该调用Dao取出数据字典对象,将数据字典对象设置到Customer对象的对应属性中。
//但是:由于struts的参数封装会将参数封装到数据字典的id属性。那么无需手动维护关系。 //2调用Dao保存客户
cd.saveOrUpdate(customer);
} @Override
// 3 根据id查询客户
public Customer getById(Long cust_id) {
Customer customer = cd.getById(cust_id);
return customer;
} public CustomerDao getCd() {
return cd;
}
public void setCd(CustomerDao cd) {
this.cd = cd;
} }
3 BaseDao&BaseDaoImpl
package www.test.dao; import java.io.Serializable;
import java.util.List; import org.hibernate.criterion.DetachedCriteria; public interface BaseDao<T> { //增或修改 [实质是根据要保存的对象是否有id属性判断的]
void saveOrUpdate(T t); //增
void save(T t); //删
void delete(T t); //删 Serializable包括了8大包装类型
void delete(Serializable id); //改
void update(T t); //查 根据id查询
T getById(Serializable id); //查 符合条件的总记录数
Integer getTotalCount(DetachedCriteria dc); //查 查询分页列表数据
List<T> getPageList(DetachedCriteria dc,Integer start,Integer pageSize); }
package www.test.dao.impl; import java.io.Serializable;
import java.lang.reflect.ParameterizedType;
import java.util.List; import org.hibernate.criterion.DetachedCriteria;
import org.hibernate.criterion.Projections;
import org.springframework.orm.hibernate5.support.HibernateDaoSupport; import www.test.dao.BaseDao; public class BaseDaoImpl<T> extends HibernateDaoSupport implements BaseDao<T> { private Class clazz; // 用于接收运行期泛型类型 public BaseDaoImpl() {
// 获得当前类型的带有泛型类型的父类
// this.getClass().getGenericSuperclass();运行在BaseDaoImpl的儿子(谁继承了它)
// 所以它的父类就是BaseDaoImpl
ParameterizedType ptClass = (ParameterizedType) this.getClass().getGenericSuperclass(); // 获得运行期的泛型类型
clazz = (Class) ptClass.getActualTypeArguments()[0];
} @Override
//保存或者修改
public void saveOrUpdate(T t) {
super.getHibernateTemplate().saveOrUpdate(t);
} @Override
public void save(T t) {
super.getHibernateTemplate().save(t);
} @Override
public void delete(T t) {
super.getHibernateTemplate().delete(t);
} @Override
public void delete(Serializable id) {
// 先获取,然后在删除
T t = this.getById(id);
super.getHibernateTemplate().delete(t);
} @Override
public void update(T t) {
super.getHibernateTemplate().update(t);
} @Override
public T getById(Serializable id) {
return (T) super.getHibernateTemplate().get(clazz, id); } @Override
public Integer getTotalCount(DetachedCriteria dc) {
// 设置查询聚合函数,总记录数
dc.setProjection(Projections.rowCount()); List<Long> list = (List<Long>) super.getHibernateTemplate().findByCriteria(dc); // 清空之前设置的聚合函数
dc.setProjection(null); if (list != null && list.size() > 0) {
Long count = list.get(0);
return count.intValue();
} else {
return null;
}
} @Override
public List<T> getPageList(DetachedCriteria dc, Integer start, Integer pageSize) { List<T> list = (List<T>) super.getHibernateTemplate().findByCriteria(dc, start, pageSize); return list;
} }
4 add.jsp(重点)
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<TITLE><s:property value="#customer==null?'添加':'修改'"/>客户</TITLE>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<LINK href="${pageContext.request.contextPath }/css/Style.css" type=text/css rel=stylesheet>
<LINK href="${pageContext.request.contextPath }/css/Manage.css" type=text/css
rel=stylesheet>
<script type="text/javascript" src="${pageContext.request.contextPath }/js/jquery-1.4.4.min.js"></script>
<script type="text/javascript" src="${pageContext.request.contextPath }/js/my.js"></script>
<script type="text/javascript">
$(function(){
//cust_level.dict_id是对象驱动的提交方式
loadSelect("006","level","cust_level.dict_id"<s:if test="#customer.cust_level!=null">,<s:property value="#customer.cust_level.dict_id"/></s:if>); /* <s:if test="#customer.cust_level!=null">
,<s:property value="#customer.cust_level.dict_id"/>
</s:if>
*/
/* 编译器报错,看不懂是正常的 */
loadSelect("002","source","cust_source.dict_id"<s:if test="#customer.cust_source!=null">,<s:property value="#customer.cust_source.dict_id"/></s:if>);
loadSelect("001","industry","cust_industry.dict_id"<s:if test="#customer.cust_industry!=null">,<s:property value="#customer.cust_industry.dict_id"/></s:if>);
});
</script> <META content="MSHTML 6.00.2900.3492" name=GENERATOR>
</HEAD>
<BODY>
<!-- 文件上传页面的三个要求
1.表单必须是post提交
2.表单提交类型必须为enctype,多段式提交。
3.文件上传使用<input type="file"/> --> <FORM id=form1 name=form1
action="${pageContext.request.contextPath }/CustomerAction_add"
method=post enctype="multipart/form-data"> <!-- 使用隐藏域将客户的id保存 -->
<input type="hidden" name="cust_id" value="<s:property value="#customer.cust_id"/>"> <TABLE cellSpacing=0 cellPadding=0 width="98%" border=0>
<TBODY>
<TR>
<TD width=15><IMG src="${pageContext.request.contextPath }/images/new_019.jpg"
border=0></TD>
<TD width="100%" background="${pageContext.request.contextPath }/images/new_020.jpg"
height=20></TD>
<TD width=15><IMG src="${pageContext.request.contextPath }/images/new_021.jpg"
border=0></TD>
</TR>
</TBODY>
</TABLE>
<TABLE cellSpacing=0 cellPadding=0 width="98%" border=0>
<TBODY>
<TR>
<TD width=15 background=${pageContext.request.contextPath }/images/new_022.jpg><IMG
src="${pageContext.request.contextPath }/images/new_022.jpg" border=0></TD>
<TD vAlign=top width="100%" bgColor=#ffffff>
<TABLE cellSpacing=0 cellPadding=5 width="100%" border=0>
<TR>
<TD class=manageHead>当前位置:客户管理 > <s:property value="#customer==null?'添加':'修改'"/>客户</TD>
</TR>
<TR>
<TD height=2></TD>
</TR>
</TABLE> <TABLE cellSpacing=0 cellPadding=5 border=0> <TR>
<td>客户名称:</td>
<td>
<INPUT class=textbox id=sChannel2 value="<s:property value="#customer.cust_name"/>"
style="WIDTH: 180px" maxLength=50 name="cust_name">
</td>
<td>客户级别 :</td>
<td id="level"> </td>
</TR> <TR> <td>信息来源 :</td>
<td id="source"> </td>
<td>客户行业:</td>
<td id="industry"> </td>
</TR> <TR>
<td>固定电话 :</td>
<td>
<INPUT class=textbox id=sChannel2 value="<s:property value="#customer.cust_phone"/>"
style="WIDTH: 180px" maxLength=50 name="cust_phone">
</td>
<td>移动电话 :</td>
<td>
<INPUT class=textbox id=sChannel2 value="<s:property value="#customer.cust_mobile"/>"
style="WIDTH: 180px" maxLength=50 name="cust_mobile">
</td>
</TR>
<!-- 文件上传页面的三个要求
1.表单必须是post提交
2.表单提交类型必须为enctype,多段式提交。
3.文件上传使用<input type="file"/> -->
<TR>
<td>图片上传 :</td>
<td>
<input type="file" name="photo">
</td> </TR> <tr>
<td rowspan=2>
<INPUT class=button id=sButton2 type=submit
value="保存 " name=sButton2>
</td>
</tr>
</TABLE> </TD>
<TD width=15 background="${pageContext.request.contextPath }/images/new_023.jpg">
<IMG src="${pageContext.request.contextPath }/images/new_023.jpg" border=0></TD>
</TR>
</TBODY>
</TABLE>
<TABLE cellSpacing=0 cellPadding=0 width="98%" border=0>
<TBODY>
<TR>
<TD width=15><IMG src="${pageContext.request.contextPath }/images/new_024.jpg"
border=0></TD>
<TD align=middle width="100%"
background="${pageContext.request.contextPath }/images/new_025.jpg" height=15></TD>
<TD width=15><IMG src="${pageContext.request.contextPath }/images/new_026.jpg"
border=0></TD>
</TR>
</TBODY>
</TABLE>
</FORM>
</BODY>
</HTML>
5 list.jsp
6 struts.xml
案例53-crm练习修改客户功能实现的更多相关文章
- 【JAVAEE学习笔记】hibernate01:简介、搭建、配置文件详解、API详解和CRM练习:保存客户
今日学习:hibernate是什么 一.hibernate是什么 框架是什么: 1.框架是用来提高开发效率的 2.封装了好了一些功能.我们需要使用这些功能时,调用即可.不需要再手动实现. 3.所以框架 ...
- JAVAEE学习——hibernate01:简介、搭建、配置文件详解、API详解和CRM练习:保存客户
今日学习:hibernate是什么 一.hibernate是什么 框架是什么: 1.框架是用来提高开发效率的 2.封装了好了一些功能.我们需要使用这些功能时,调用即可.不需要再手动实现. 3.所以框架 ...
- .net Mvc文件下载的功能,大文件下载完成之后修改数据库功能
原文:.net Mvc文件下载的功能,大文件下载完成之后修改数据库功能 我服务器上文件只能下载一次,下载了之后就不能下载了,大文件或网速不好时,可能服务端文件流发送完了,客户端还没下载完,导致下载失败 ...
- JAVAEE——SSH项目实战05:用户注册、登陆校验拦截器、员工拜访客户功能和MD5加密
作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7170519.html 一.用户注册 显示错误信息到页面上的另一种方法: public ...
- CRM系统对管理客户的帮助
我们可以把客户关系看做是一种长期的投资,在资源有限的基础上,把人力财力物力放到那些能够持续创造价值的客户身上,从而为企业带来源源不断的收益.通过进行客户关系管理,能够让企业与客户之间建立沟通的渠道,形 ...
- 企业管理CRM不只是客户录入系统
企业在举办营销活动或者展会之后,将会收集到大量的客户信息,将这些信息有效地整理.完善.储存也是一个不小的工程.如果您的企业经常面遇到这样的情况,不妨使用Zoho CRM系统来帮您完成.但是,Zoho ...
- oracle修改审计功能
oracle修改审计功能 如果没有关闭审计功能,审计日志文件默认保存在位置为$ORACLE_BASE/admin/$ORACLE_SID/adump/ 关闭审计:alter system set au ...
- Microsoft Dynamics CRM 如何修改域密码
一.安装IIS6脚本工具,如下图所示: 二.复制iisadmpwd文件夹到AD Server的C:\Windows\SysWOW64\inetsrv文件夹下 三.注册Iisadmpwd目录下的IISp ...
- Oracle块修改跟踪功能
块修改跟踪功能是指使用二进制文件记录数据库中数据库更改的过程. 其目的是提高增量备份操作的性能,因为RMAN可以使用快修改跟踪文件找到上次执行备份操作后被修改的数据块.这可以节省大量时间,因为如果不这 ...
随机推荐
- java求几个数字的和输出详细步骤
设计思想:要求几个数字的和,就要把输入的字符串转换成浮点型,然后求和再输出. 程序流程图: 程序源代码: //此程序用于从命令行接收多个数字,就和并输出. //作者:赵东睿 //2015.9.26 p ...
- left join和right join、inner join 区别
left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录 inner join(等值连接) ...
- android studio中Fragment使用webview返回上一页的问题
在Fragment中使用了腾讯的X5 webview,虽然好用,但是在Fragment中传递消息困难,想要返回上一页,还得各种消息传递什么的,麻烦.可是在Fragment中又不能使用onKeyDown ...
- mysql字段名与关键字冲突(near "to":syntax error)
今天遇到个问题,mysql字段为 to ,但是插入时报语法错误,仔细分析to是关键词 使用单引号和双引号 全部失败!!!! 仔细看 mysql的字段都是`(键盘Esc下面那个符号)括起来的, 试了一下 ...
- 【C#】 创建和调用webapi
二,,通过普通的路由调用,,路径写到http://localhost:29920/api/Players 即 Api/controller 为止
- Django之博客系统邮件分享博客
在上一章中,我们创建了一个基础的博客应用,我们能在http://127.0.0.1:8000/blog/显示我们的博客.在这一章我们将尝试给博客系统添加一些高级的特性,比如通过email来分享帖子,添 ...
- iOS开发:setNeedsLayOut和setNeedsDisplay区别
1.layoutSubviews方法 1.1 根据苹果官方帮助文档对layoutSubviews方法的解释: 此方法用来重新定义子元素的位置和大小.当子类重写此方法,用来实现UI元素的更精确布局.如果 ...
- LinkExtractor 构造器各参数说明
LinkExtractor 构造器各参数说明 特例: LinkExtractor构造器的所有参数都有默认值 各参数说明: allow 接收一个正则表达式或一个正则表达式列表,提取绝对url与正则表达式 ...
- 【bzoj2186】: [Sdoi2008]沙拉公主的困惑 数论-欧拉函数
[bzoj2186]: [Sdoi2008]沙拉公主的困惑 考虑当 gcd(a,b)=1 则 gcd(nb+a,b)=1 所以[1,N!]与M!互质的个数就是 筛出[1,M]所有的素数p[i] 以及逆 ...
- 最短路【洛谷P3393】 逃离僵尸岛
P3393 逃离僵尸岛 题目描述 小a住的国家被僵尸侵略了!小a打算逃离到该国唯一的国际空港逃出这个国家. 该国有N个城市,城市之间有道路相连.一共有M条双向道路.保证没有自环和重边. K个城市已经被 ...