操作失败,没有该服务权限![ 机构号:99 ,用户ID:50000009 ,服务号:0101030112 ]
操作失败,没有该服务权限![ 机构号:99 ,用户ID:50000009 ,服务号:0101030112 ]
此时我们可以把代码 SERVICE_NO 改成 10个0 即 0000000000 ,就可以进行权限查看.
然后把response响应大对象打印出来看看,就知道连到哪里去了

package com.isoftstone.common;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.apache.log4j.Logger;
import com.isoftstone.core.common.tools.XmlTool;
import com.isoftstone.core.dto.RequestBusinessObject;
import com.isoftstone.core.dto.ResponseBusinessObject;
import com.isoftstone.fwk.dao.DaoException;
import com.isoftstone.fwk.util.SpringUtils;
import com.isoftstone.httpclient.ESBClient;
import com.isoftstone.platform.constants.PltmConstants;
import com.isoftstone.platform.service.PltmPacketService;
import com.isoftstone.platform.vo.PltmPacketVO;
public class JavaCTool {//需要晓飞最新esb.jar支持
/** 创建一个logger对象 **/
private static Logger logger = Logger.getLogger(JavaCTool.class);
/**
* 在进行特殊判断以后 , 调用javac保存与平台通信报文
* 当前特殊判断只针对投保查询检验是不进行核心同步保存的,而是返回false
* @param recvOutMap
* @param pltmPacketVO
* @param sendOutMap
* @return
*/
public static boolean callJavaCAfterJudgement(Map<String, List<Map<String, Object>>> recvOutMap ,PltmPacketVO pltmPacketVO,Map sendOutMap){
// boolean flag = true;
// if(sendOutMap != null){//此处的判断主是要因为 投保查询检验时,核心不需要第一次平台返回的提问报文,只需要第二次和平台通信的报文即可.所以如果是查询检验问题,那么return false,从而不发送报文给核心
// List list = (List) sendOutMap.get("CHECKCODE");
// if(list != null && list.size() > 0){//判断投保查询校验list是否存在
// Map innerMap = (Map) list.get(0);
// String renewalFlag = (String) innerMap.get("RENEWAL_FLAG") ;
// if( renewalFlag != null ){
// if( "1".equals( renewalFlag ) ){
// flag = false ;
// }
// }
// }
// }
// if(flag == true){
return callJavaC(recvOutMap,pltmPacketVO,sendOutMap);
// }else{
// return false;
// }
}
/*
* @param recvOutMap 接收外围map
* @param pltmPacketVo 本系统返回的大日志对象,包含接收外围,上平台,平台返回,发送外围,成功失败等内容.
* @param sendOutMap 发送给外围map
*/
public static boolean callJavaC(Map<String, List<Map<String, Object>>> recvOutMap ,PltmPacketVO pltmPacketVO,Map sendOutMap){
PltmPacketService pltmPacketService = (PltmPacketService) SpringUtils.getSpringBean("pltmPacketService");
ResponseBusinessObject responseBO = null;
Map<String, List<Map<String, Object>>> sendV5Map = new HashMap<String, List<Map<String, Object>>>();//发送V5的通信 map
try {
List<Map<String, Object>> recvOutBaseList = recvOutMap.get("BASE");
List<Map<String, Object>> recvOutVhlList = recvOutMap.get("VHL");
if( (recvOutVhlList == null)||(recvOutVhlList.size()== 0) )
return false;
String dptcde = (String) recvOutBaseList.get(0).get("DPT_CDE");//8位出单机构
List headList = (List) sendOutMap.get("HEAD");//ERROR_CODE start
if( (headList == null)||(headList.size()== 0) )
return false;
Map headMap = (Map)headList.get(0);
List vhlList = (List) sendOutMap.get("VHL");//QUERY_SEQUENCE_NO start
if( (vhlList == null)||(vhlList.size()== 0) )
return false;
Map vhlmap = (Map)vhlList.get(0);
Map<String, Object> recvOutVhlMap = recvOutVhlList.get(0);
//错误码如果是0000表示平台通信完全正常,此时才继续往下走和v5通信
if("0000".equals(headMap.get("ERROR_CODE")) &&PltmConstants.FOUR.equals(pltmPacketVO.getCSucMrk()) && PltmConstants.V5FAIL_MRK.equals(pltmPacketVO.getCSendV5Mrk()) ){
//如果和平台交互标志为4
//准备javaC通信,将数据填充到sendV5Map
List<Map<String, Object>> baseList =
Map<String,Object> baseMap = new HashMap<String,Object>();
String cQueryCde = (String)vhlmap.get("QUERY_CDE");
String cCarMark = (String)recvOutVhlMap.get("CAR_MARK");
String cEngineNo = (String)recvOutVhlMap.get("ENGINE_NO");
String cRackNo = (String)recvOutVhlMap.get("RACK_NO");
baseMap.put("DPT_CDE",dptcde);//DPT_CDE end
baseMap.put("CAR_MARK",cCarMark);//CAR_MARK end
baseMap.put("ENGINE_NO",cEngineNo);//ENGINE_NO end
baseMap.put("RACK_NO",cRackNo);//RACK_NO end
baseMap.put("QUERY_SEQUENCE_NO",cQueryCde);//QUERY_SEQUENCE_NO end
baseMap.put("REQUESTXML", pltmPacketVO.getCSendPltm().replace("</", "$($").replace("/>", "$)$").replace("<", "#(#").replace(">", "#)#"));
baseMap.put("RESPONSEXML", pltmPacketVO.getCRecvPltm().replace("</", "$($").replace("/>", "$)$").replace("<", "#(#").replace(">", "#)#"));
baseList.add(baseMap);
sendV5Map.put("BASE",baseList);
//填充完毕
//开始调用javaC通信,v5通信成功后
logger.info("同步查询码为 "+cQueryCde+" 的[请求与返回]报文给核心,开始");
SaveQueryInfoService(recvOutMap,sendV5Map);
logger.info("同步查询码为 "+cQueryCde+" 的[请求与返回]报文给核心,结束");
//v5通信成功后,置通信成功标志
pltmPacketService.updateSendV5Mrk(pltmPacketVO.getCPkId(),PltmConstants.V5SUCC_MRK);
logger.info("把 查询码为 "+cQueryCde+" 的与核心通信成功标志修改为1");
}else{
return false;
}
}
logger.warn("[生成V5交互报文失败] : "+npE);
return false;
}
logger.warn("[更新日志失败]:"+daoE);
return false;
}
logger.error(e.getMessage());
logger.error("与核心数据同步失败,可能原因:超时");
return false;
}
return true;
}
/*
* @author
* @param recvOutMap 用于提取部分Head信息到sendV5Map中云
* @param sendV5Map 缺少Head信息的map,在设置完Head之后,转成requestBO,用于和V5进行通信
*/
public static ResponseBusinessObject SaveQueryInfoService(Map<String, List<Map<String, Object>>> recvOutMap ,Map sendV5Map )throws Exception{
ESBClient esbClient = new ESBClient();
List list = new ArrayList();
Map head = new HashMap();
head.put("REQUEST_TYPE", "");
head.put("SYSNAME", "platproxy");
head.put("SYSCODE", "02");
head.put("USERCDE", "100009999");
head.put("DPTCDE", recvOutMap.get("HEAD").get(0).get("DPTCDE"));
head.put("TYPE", "Q");
head.put("DATA", "A");
head.put("SERVICE_NO","0000000000");
head.put("SERVICENAME","SaveQueryInfo");
head.put("USERID", "50000009");
list.add(head);
sendV5Map.put("HEAD", list);
//esb设置连接超时
ESBClient client = new ESBClient(30*1000,30*1000,30*1000);
RequestBusinessObject requestBO = null;
ResponseBusinessObject responseObject = null;
try {
requestBO = XmlTool.getFromCoreMap(sendV5Map);
// String s = XmlTool.convertToXml(requestBO);
responseObject = client.invoke(requestBO);
String s = XmlTool.convertToXml(responseObject);
System.out.println("核心返回信息________________+:\n"+s);
} catch (Exception e) {
throw e;
}
return responseObject;
}
//
}
操作失败,没有该服务权限![ 机构号:99 ,用户ID:50000009 ,服务号:0101030112 ]的更多相关文章
- Linux下文件权限(一)用户ID和用户组ID
最近在读<unix环境高级编程>,看到文件权限这里比较糊涂,主要设计多个用户ID和用户组ID,包括下面两个: (1)实际用户ID和实际用户组ID:这一部分表示我们究竟是谁.这两个字段在登录 ...
- win7 提升windows服务权限使非管理员用户可以控制windows服务的开启和关闭
#include <windows.h>#include <tchar.h>#include <strsafe.h>#include <aclapi.h> ...
- 解决在iOS8环境下,当用户关闭定位服务总开关时,无法将APP定位子选项加入定位权限列表的问题
关键点:- (void)locationManager:(CLLocationManager *)manager didChangeAuthorizationStatus:(CLAuthorizati ...
- 如何排查sharepoint2010用户配置文件同步服务启动问题
用户配置文件同步服务与 Microsoft Forefront Identity Manager (FIM) 交互,以与外部系统(如目录服务和业务系统)同步配置文件信息.启用用户配置文件同步服务时,将 ...
- UNIX文件的权限之“设置用户ID位”
用stat函数可以获取一个文件的状态信息,原型是这样的: int stat(const char *path, struct stat *buf); 其中结构体stat的结构: struct stat ...
- php 微信登录 公众号 获取用户信息 微信网页授权
php 微信登录 公众号 获取用户信息 微信网页授权 先自己建立两个文件: index.php 和 getUserInfo.php index.php <?php //scope=snsap ...
- 用户id,组id和文件访问权限
实际用户ID和实际组ID:标示了我们究竟是谁,这两个字段在登录时取自口令文件中的登录项 有效用户ID和有效组ID以及附属组ID:决定了我们的文件的访问权限(通常有效用户ID等于实际用户ID,有效组ID ...
- paip.花生壳 服务启动失败 以及不能安装服务,权限失败的解决
paip.花生壳 服务启动失败 以及不能安装服务,权限失败的解决 系统win7 NewPhDDNS_1.0.0.30166.exe 作者Attilax 艾龙, EMAIL:1466519819@ ...
- (2.2)学习笔记之mysql基础操作(登录及账户权限设置)
本系列学习笔记主要讲如下几个方面: 本文笔记[三:mysql登录][四:账户权限设置][五:mysql数据库安全配置] 三.mysql登录 常用登录方式如下: 四.账户权限设置 (4.1)查看用户表, ...
随机推荐
- Repeater上下排序按钮
aspx代码 <table cellspacing="0" cellpadding="0" width="100%" align=&q ...
- CodeIgniter的缓存设置
数据库缓存 数据库缓存类允许你把数据库查询结果保存在文本文件中以减少数据库访问. 激活缓存需要三步: 在服务器上创建一个可写的目录以便保存缓存文件. 在文件 application/config/da ...
- scala学习笔记(8): 列表的map,flatMap,zip和reduce
map,flatMap,zip和reduce函数可以让我们更容易处理列表函数. 1 map函数map将一个函数应用于列表的每一个元素并且将其作为一个新的列表返回.我们可以这样对列表的元素进行平方: s ...
- ecshop 无限分类解析(转)
对ecshop无限级分类的解析,认真分析后发现真的其算法还是比较精典的其实并不难理解,有举例方便大家理解 function cat_options($spec_cat_id, $arr) { stat ...
- 【英语】Bingo口语笔记(75) - 元音辅音的辨读
- js中substring和substr的用法
js中substring和substr的用法 substring 方法用于提取字符串中介于两个指定下标之间的字符 substring(start,end) 开始和结束的位置,从零开始的索引 参数 ...
- Java 循环语句之多重循环
循环体中包含循环语句的结构称为多重循环.三种循环语句可以自身嵌套,也可以相互嵌套,最常见的就是二重循环.在二重循环中,外层循环每执行一次,内层循环要执行一圈. 如下所示: 例如:使用 * 打印长方形: ...
- 利用命令控制台cmd进入某个硬盘的某个文件夹的命令是什么?
在命令行窗口中输入F:后回车就可以切换到F盘,如果想查看F盘的内容,可以再输入dir后回车 (输入“F”后要再输入一个“ :”再回车才行哦)
- HDU5808Price List Strike Back (BestCoder Round #86 E) cdq分治+背包
严格按题解写,看能不能形成sum,只需要分割当前sum怎么由两边组成就好 #include <cstdio> #include <cstring> #include <c ...
- 转--优化临时表使用,SQL语句性能提升100倍
转自:http://www.51testing.com/html/01/n-867201-2.html [问题现象] 线上mysql数据库爆出一个慢查询,DBA观察发现,查询时服务器IO飙升,IO占用 ...