`
0oliumino0
  • 浏览: 5207 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

腾讯信鸽(Xg-Push-SDK-JAVA-1.1.6)在weblogic下无法推送消息

阅读更多

问题表现:

在tomcat下推送成功,而换到weblogic下推送,会响应提示失败,以下是响应的Json:

 

{"err_msg":"common param missing, check access_id, timestamp and sign","ret_code":-1}   

根据响应的错误提示,发现好像是参数没有接收到,没办法了,只好翻下SDK包里的推送消息的源码,关键推送代码如下:

protected JSONObject callRestful(String url, Map<String, Object> params) 
	{
		String temp;
		String ret="";
		JSONObject jsonRet=null;
		String sign = generateSign("POST", url, params);
		if(sign.isEmpty()) return new JSONObject("{\"ret_code\":-1,\"err_msg\":\"generateSign error\"}");
		params.put("sign", sign);
		try{
			URL u = new URL(url);
			HttpURLConnection conn = (HttpURLConnection)u.openConnection();
			conn.setRequestMethod("POST");
			conn.setConnectTimeout(10000);
			conn.setDoOutput(true);
			conn.setDoInput(true);
			conn.setUseCaches(false);
			StringBuffer param = new StringBuffer();
			for (String key: params.keySet())
			{
				param.append(key).append("=").append(URLEncoder.encode(params.get(key).toString(), "UTF-8")).append("&");
			}
			conn.getOutputStream().write(param.toString().getBytes("UTF-8"));
			conn.getOutputStream().flush();
			conn.getOutputStream().close();
			InputStreamReader isr = new InputStreamReader(conn.getInputStream());  
            BufferedReader br = new BufferedReader(isr);  
            while((temp = br.readLine()) != null){  
                ret += temp;  
            }     
            br.close();  
            isr.close();
            conn.disconnect();
            jsonRet = new JSONObject(ret);
		} catch(java.net.SocketTimeoutException e) {
			jsonRet = new JSONObject("{\"ret_code\":-1,\"err_msg\":\"call restful timeout\"}");
		} catch(Exception e) {
			jsonRet = new JSONObject("{\"ret_code\":-1,\"err_msg\":\"call restful error\"}");
		}
		return jsonRet;
	}

 通过源码我们发现信鸽服务器端SDK是通过HttpURLConnection进行post请求来实现推送消息的动作。

在网上搜索之后,结论是在weblogic上使用HttpsURLConniection时,会默认使用weblogic自己的类weblogic.net.http.SOAPHttpsURLConnection,导致出现问题,而在tomcat下默认的实现类是HttpsURLConnection

在网上看了几篇先关的技术文章后,总结有两个解决办法:

 

1.在WEBLOGIC没有对使用的SSL实现类进行配置的情况下,在程序中如果正常使用java.net.URL的不带 URLStreamHandler 参数的构造方法new 一个URL对象的话,url.openConnection()默认是返回SOAPHttpsURLConnection类型对象,如果我们使用带有 URLStreamHandler参数的构造方法,如下:

 

		URL url = new URL(null,"https://www.etrade.com",
		new com.sun.net.ssl.internal.www.protocol.https.Handler());// 指定了handler后openConnection()返回了HttpsURLConnection类型对象
		HttpsURLConnection conn = (HttpsURLConnection)url.openConnection();

 

 

以上可以在程序中解决返回的HttpURLConnection对象的具体类型。

 

2.对于单机的Weblogic,在startWeblogic.sh文件中添加一行参数:

MEM_ARGS="${MEM_ARGS} -DUseSunHttpHandler=true"

这个参数的目的就是告诉WebLogic使用Sun的HttpHandler而不要使用WebLogic自己的。这样配置后使用url.openConnection()就会返回HttpsURLConnection类型对象了。

    

如果是配置了集群,则不必在启动脚本中增加参数,可以在weblogic控制台中针对特定server配置此参数

 

总结:方法一测试了下有点问题...weblogic环境就没再去测试了。方法二没有问题。

 

分享到:
评论

相关推荐

    Rockchip-Developer-Guide-Android11-SDK-V1.1.6-CN.pdf

    Rockchip_Developer_Guide_Android11_SDK_V1.1.6_CN.pdf

    canal.adapter-1.1.6.zip

    2. **适配器(Adapter)角色**:在Canal框架中,适配器起到了桥梁的作用,它允许用户自定义数据同步的目标端,比如将MySQL的变更事件转换为其他格式,如JSON,然后推送到目标系统。 3. **版本1.1.6**:此版本可能...

    canal.deployer-1.1.6

    3. **数据订阅与推送**:支持多种消息订阅和推送模型,如单向推送、双向同步等。 **二、Canal Deployer组件** Canal Deployer是Canal的部署和管理组件,主要包含以下几个部分: 1. **bin**:包含了启动和停止...

    XinGePush:腾讯信鸽.NET SDK

    腾讯信鸽.NET SDK 参照官方Java SDK V1.1.6 详细说明可查阅信鸽官方wiki 移植过程中参考了 在此向yeanzhi致敬 修复了一些bug,同时添加了部分API,如引入快捷方式、创建大批量推送消息并推送的接口 1 快捷方式 1.1 ...

    canal-1.1.6-SNAPSHOT.rar

    它能够监听 MySQL 数据库的 binlog(二进制日志),并将 binlog 事件转化为结构化的数据,然后推送给各种订阅者,如 Elasticsearch、Hadoop 或其他自定义的服务,实现数据的实时备份、数据迁移或数据分析等场景。...

    opentsdb-java-sdk:用Java语言封装了openTSDB的http api

    opentsdb-java-sdk目前实现的功能查询数据,支持同步和异步写入数据,支持异步回调删除数据查询最新数据查询metric、tag_key和tag_value,支持auto_complete`源码中CrudTest类提供了一些使用说明和测试,包括并发...

    u-boot-1.1.6.tar.bz & u-boot-1.1.6_jz2440.patch

    《深入解析u-boot-1.1.6与JZ2440平台的集成实践》 在嵌入式系统开发领域,u-boot是一款广泛应用的开放源码引导加载程序,它负责初始化硬件,加载操作系统内核,并提供了一种交互式的命令行环境。本文将围绕u-boot-...

    canal-1.1.6

    【标题】"Canal-1.1.6" 是一个重要的数据库同步工具,主要用于实现MySQL数据的实时增量复制。在IT行业中,数据同步是确保多系统间数据一致性和实时性的关键环节,尤其在分布式系统、大数据处理和云计算环境中。Canal...

    canal-1.1.6(deployer admin deployer)

    github下载太慢,放一份到这方便大家 官方下载地址 https://github.com/alibaba/canal/releases 资源包括 canal.adapter-1.1.6.tar canal.admin-1.1.6.tar canal.deployer-1.1.6.tar

    jaxen-1.1.6_jaxen_

    Jaxen提供了与DOM、DOM3、JDOM、XOM、DOM4J、NEWT等多种XML处理模型的接口集成,使得开发者可以在不关心底层XML处理方式的情况下,使用统一的XPath表达式进行操作。 **XPath语言** XPath的语法简洁而强大,可以...

    s3c-u-boot-1.1.6设置SD启动模式

    ### S3C-U-Boot-1.1.6设置SD启动模式详解 #### 一、背景介绍 在嵌入式开发领域,U-Boot(Universal Boot Loader)是一种广泛使用的开源引导加载程序,能够支持多种处理器架构及外围设备。本文档详细介绍如何在S3C-...

    u-boot-1.1.6移植学习笔记

    ### U-Boot 1.1.6 移植学习笔记 #### 一、U-Boot 1.1.6 目录结构解析 U-Boot(Universal Boot Loader)是一款广泛应用于嵌入式系统的引导加载程序,它支持多种处理器架构及各种外围设备。U-Boot 1.1.6 的目录结构...

    数据库同步中间canal-1.1.6合集

    数据库同步中间件合集 canal.deployer-1.1.6.tar.gz ; canal.admin-1.1.6.tar.gz ; canal.adapter-1.1.6.tar.gz ; canal.example-1.1.6.tar.gz

    unbescape-1.1.6.RELEASE-API文档-中文版.zip

    赠送jar包:unbescape-1.1.6.RELEASE.jar; 赠送原API文档:unbescape-1.1.6.RELEASE-javadoc.jar; 赠送源代码:unbescape-1.1.6.RELEASE-sources.jar; 赠送Maven依赖信息文件:unbescape-1.1.6.RELEASE.pom; ...

    canal.deployer-1.1.6.tar.gz

    《Canal Deployer 1.1.6:MySQL 数据库实时同步工具详解》 Canal Deployer 是阿里巴巴开源的一款高效、稳定、轻量级的 MySQL 数据库增量日志解析组件,其主要功能是实现 MySQL 数据库到其他系统(如 Elasticsearch...

    Mina-1.1.6-api

    Mina-1.1.6-api

    dom4j-1.6.1-jaxen-1.1.6-jar包.zip

    在`dom4j-1.6.1-jaxen-1.1.6-jar包.zip`中,包含了这两个库的jar文件,它们可以被添加到Java项目的类路径中,以便在项目中直接使用。在使用时,确保先导入对应的jar包,然后就可以调用它们提供的类和方法来处理XML...

    u-boot-1.1.6 原始Makefile

    u-boot-1.1.6 原始Makefile

    canal.admin-1.1.6-SNAPSHOT.tar.gz

    在IT行业中,数据同步和管理是企业信息化建设的重要环节,尤其在分布式系统和大数据背景下,实时的数据复制和变更捕获显得尤为重要。Canal,作为阿里巴巴开源的一款高效、稳定、轻量级的数据库增量日志订阅与消费...

Global site tag (gtag.js) - Google Analytics