1 学习计划

1、定区关联客户

n 完善CRM服务中的客户查询方法

n 在BOS项目中配置代理对象远程调用crm服务

n 调整定区关联客户页面

n 实现定区关联客户

2、查看定区中包含的分区

n 页面调整

n 服务端实现

3、查看定区关联的客户列表数据

n 页面调整

n 服务端通过代理对象远程调用CRM服务活动客户信息

 

定区关联客户

2.1 在BOS项目中配置代理对象远程调用crm

第一步:在BOS项目的pom.xml中引入CXF的依赖

        <dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-frontend-jaxws</artifactId>
<version>3.0.1</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http</artifactId>
<version>3.0.1</version>
</dependency>

第二步:使用wsimport命令解析wsdl文件生成本地代码,只需要接口文件和实体类

第三步:在spring配置文件中注册crm客户端代理对象

<!-- 注册crm客户端代理对象 -->
<jaxws:client id="crmClient"
serviceClass="com.itheima.crm.ICustomerService"
address="http://192.168.115.89:8080/crm_heima32/service/customer"/>

第四步:通过注解方式将代理对象注入给Action

2.2 完善CRM服务中的客户查询方法

l 在crm服务中的接口中扩展两个方法

l 在实现类中实现方法

    //查询未关联到定区的客户
public List<Customer> findListNotAssociation() {
String sql = "select * from t_customer where decidedzone_id is null";
List<Customer> list = jdbcTemplate.query(sql, new RowMapper<Customer>(){
public Customer mapRow(ResultSet rs, int arg1) throws SQLException {
int id = rs.getInt("id");//根据字段名称从结果集中获取对应的值
String name = rs.getString("name");
String station = rs.getString("station");
String telephone = rs.getString("telephone");
String address = rs.getString("address");
String decidedzone_id = rs.getString("decidedzone_id");
return new Customer(id, name, station, telephone, address, decidedzone_id);
}
});
return list;
} //查询已经关联到指定定区的客户
public List<Customer> findListHasAssociation(String decidedzoneId) {
String sql = "select * from t_customer where decidedzone_id = ?";
List<Customer> list = jdbcTemplate.query(sql, new RowMapper<Customer>(){
public Customer mapRow(ResultSet rs, int arg1) throws SQLException {
int id = rs.getInt("id");//根据字段名称从结果集中获取对应的值
String name = rs.getString("name");
String station = rs.getString("station");
String telephone = rs.getString("telephone");
String address = rs.getString("address");
String decidedzone_id = rs.getString("decidedzone_id");
return new Customer(id, name, station, telephone, address, decidedzone_id);
}
},decidedzoneId);
return list;
}

注意:服务端扩展了新的方法,需要客户端重新生成客户端代码

2.3 调整定区关联客户页面

页面:WEB-INF/pages/base/decidedzone.jsp

第一步:修改定区页面中关联客户按钮绑定事件处理函数

function doAssociations(){
//获取当前数据表格所有选中的行,返回数组
var rows = $("#grid").datagrid("getSelections");
if(rows.length != 1){
//弹出提示
$.messager.alert("提示信息","请选择一个定区操作!","warning");
}else{
//选中了一个定区
$('#customerWindow').window('open');
//清理下拉框
$("#noassociationSelect").empty();
$("#associationSelect").empty();
//发送ajax请求,请求定区Action,在定区Action中通过crm代理对象完成对于crm服务远程调用获取客户数据
var url_1 = "decidedzoneAction_findListNotAssociation.action";
$.post(url_1,function(data){
//遍历json数组
for(var i=0;i<data.length;i++){
var id = data[i].id;
var name = data[i].name;
var telephone = data[i].telephone;
name = name + "(" + telephone + ")";
$("#noassociationSelect").append("<option value='"+id+"'>"+name+"</option>");
}
}); //发送ajax请求,请求定区Action,在定区Action中通过crm代理对象完成对于crm服务远程调用获取客户数据
var url_2 = "decidedzoneAction_findListHasAssociation.action";
var decidedzoneId = rows[0].id;
$.post(url_2,{"id":decidedzoneId},function(data){
//遍历json数组
for(var i=0;i<data.length;i++){
var id = data[i].id;
var name = data[i].name;
var telephone = data[i].telephone;
name = name + "(" + telephone + ")";
$("#associationSelect").append("<option value='"+id+"'>"+name+"</option>");
}
});
}
}

第二步:在定区Action中注入crm代理对象,并且提供方法远程调用crm服务

第三步:为关联客户窗口中左右移动两个按钮绑定事件

第四步:为定区关联客户窗口中的“关联客户”按钮绑定事件

2.4 在crm服务端扩展定区关联客户方法

注意:crm服务端扩展方法后,需要bos客户端重新生成客户端代码

2.5 在定区Action中提供关联客户方法

查看定区中包含的分区

页面:WEB-INF/pages/base/decidedzone.jsp

3.1 页面调整

第一步:为datagrid绑定数据事件

第二步:定义doDblClickRow函数

3.2 服务端实现

l 在分区Action中提供方法,根据定区id查询关联的分区

l 在SubareaServiceImpl中提供方法,根据定区id查询关联的分区

查看定区中关联的客户信息

    public String findListHasAssociation(){
List<Customer> list2 = customerService.findByHasAssociation(model.getId());
ObjectToJson(list2, null);
return NONE;
}

 

最新文章

  1. 分享一个自己用的Objective-C的Http接连类
  2. javascript给不能修改的函数增加额外处理的方法
  3. 动态设置uitableview高度,参考
  4. java常见机试题目(1)
  5. Http,Https (SSL)的Url绝对路径,相对路径解决方案Security Switch 4.2 中文帮助文档 分类: ASP.NET 2014-10-28 14:09 177人阅读 评论(1) 收藏
  6. 深入了解HTTP协议、HTTP协议原则
  7. Linux系统开机启动流程
  8. 旅行,说走就走 Help? [C++数据类型和表达式]
  9. 【原创】NVIC中断
  10. Codeforces 700 C. Break Up(Tarjan求桥)
  11. forEach、for in、for of 三者对比
  12. HYSBZ 4034 【树链剖分】+【线段树 】
  13. redis配置(redis.conf)
  14. cl 命令行配置
  15. 删除centos7中自带有python2.7
  16. tornado请求头/状态码/接口 笔记
  17. html A标签 绑定点击事件。跳转页面。处理
  18. mongo启动
  19. 文件io之——read/write
  20. C语言实现数组及链表的快速排序

热门文章

  1. Python模拟登录成功与失败处理方式(不涉及前端)
  2. Android动态改变App在Launcher里面的icon
  3. TI Davinci DM6446开发攻略——开发环境搭建
  4. ffmpeg tutorial01 再分析
  5. 【mongodb系统学习之八】mongodb shell常用操作
  6. Linux显示一行显示列总计
  7. directX显示采集源(摄像头)filter
  8. Django学习-5-模板渲染
  9. pat1121-1131
  10. maven项目转eclipse