微信第三方平台开发,component_verify_ticket的接收

首先是接收component_verify_ticket 

大家在创建完成第三方平台之后,微信服务器就会以10分钟左右的时间通过当时填写的授权事件接收URL。发送ticket。但是在接收之后,需要进行解密操作。具体的解密方式(消息加解密接入指引)在里面。找到自己对应的加解密信息就可以了。

当大家下载之后,先运行下其中的测试WXBizMsgCryptTest这个类的时候,就回遇到这个错误java.security.InvalidKeyException: Illegal key size。因为jdk的问题。其中具体原因大家可以参考别人的方案,这里不解释这个了http://www.cnblogs.com/gdayq/p/5919252.html

其中jdk1.8的jar包。有需要的可以私信我。因为我下载了jdk1.8的

大家打开测试类的时候,看见下面的信息,其实这些信息,对于接受component_verify_ticket 没有什么用处的。

public class WXBizMsgCryptTest {
	String encodingAesKey = "abcdefghijklmnopqrstuvwxyz0123456789ABCDEFG";
	String token = "pamtest";
	String timestamp = "1409304348";
	String nonce = "xxxxxx";
	String appId = "wxb11529c136998cb6";
	String replyMsg = "我是中文abcd123";
	String xmlFormat = "<xml><ToUserName><![CDATA[toUser]]></ToUserName><Encrypt><![CDATA[%1$s]]></Encrypt></xml>";
	String afterAesEncrypt = "jn1L23DB+6ELqJ+6bruv21Y6MD7KeIfP82D6gU39rmkgczbWwt5+3bnyg5K55bgVtVzd832WzZGMhkP72vVOfg==";
	String randomStr = "aaaabbbbccccdddd";

	String replyMsg2 = "<xml><ToUserName><![CDATA[oia2Tj我是中文jewbmiOUlr6X-1crbLOvLw]]></ToUserName><FromUserName><![CDATA[gh_7f083739789a]]></FromUserName><CreateTime>1407743423</CreateTime><MsgType><![CDATA[video]]></MsgType><Video><MediaId><![CDATA[eYJ1MbwPRJtOvIEabaxHs7TX2D-HV71s79GUxqdUkjm6Gs2Ed1KF3ulAOA9H1xG0]]></MediaId><Title><![CDATA[testCallBackReplyVideo]]></Title><Description><![CDATA[testCallBackReplyVideo]]></Description></Video></xml>";
	String afterAesEncrypt2 = "jn1L23DB+6ELqJ+6bruv23M2GmYfkv0xBh2h+XTBOKVKcgDFHle6gqcZ1cZrk3e1qjPQ1F4RsLWzQRG9udbKWesxlkupqcEcW7ZQweImX9+wLMa0GaUzpkycA8+IamDBxn5loLgZpnS7fVAbExOkK5DYHBmv5tptA9tklE/fTIILHR8HLXa5nQvFb3tYPKAlHF3rtTeayNf0QuM+UW/wM9enGIDIJHF7CLHiDNAYxr+r+OrJCmPQyTy8cVWlu9iSvOHPT/77bZqJucQHQ04sq7KZI27OcqpQNSto2OdHCoTccjggX5Z9Mma0nMJBU+jLKJ38YB1fBIz+vBzsYjrTmFQ44YfeEuZ+xRTQwr92vhA9OxchWVINGC50qE/6lmkwWTwGX9wtQpsJKhP+oS7rvTY8+VdzETdfakjkwQ5/Xka042OlUb1/slTwo4RscuQ+RdxSGvDahxAJ6+EAjLt9d8igHngxIbf6YyqqROxuxqIeIch3CssH/LqRs+iAcILvApYZckqmA7FNERspKA5f8GoJ9sv8xmGvZ9Yrf57cExWtnX8aCMMaBropU/1k+hKP5LVdzbWCG0hGwx/dQudYR/eXp3P0XxjlFiy+9DMlaFExWUZQDajPkdPrEeOwofJb";

	

	@Test
	public void testNormal() throws ParserConfigurationException, SAXException, IOException {
		try {
			WXBizMsgCrypt pc = new WXBizMsgCrypt(token, encodingAesKey, appId);
			String afterEncrpt = pc.encryptMsg(replyMsg, timestamp, nonce);

			DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
			DocumentBuilder db = dbf.newDocumentBuilder();
			StringReader sr = new StringReader(afterEncrpt);
			InputSource is = new InputSource(sr);
			Document document = db.parse(is);

			Element root = document.getDocumentElement();
			NodeList nodelist1 = root.getElementsByTagName("Encrypt");
			NodeList nodelist2 = root.getElementsByTagName("MsgSignature");

			String encrypt = nodelist1.item(0).getTextContent();
			String msgSignature = nodelist2.item(0).getTextContent();
			String fromXML = String.format(xmlFormat, encrypt);

			// 第三方收到公众号平台发送的消息
			String afterDecrpt = pc.decryptMsg(msgSignature, timestamp, nonce, fromXML);
			System.out.println(afterDecrpt);
		} catch (AesException e) {
			fail("正常流程,怎么就抛出异常了??????");
		}
	}

具体如何去接收并解密component_verify_ticket 呢,大家只需要看下面这个就行了。

            // 第三方收到公众号平台发送的消息

             WXBizMsgCrypt pc = new WXBizMsgCrypt(token, encodingAesKey, appId);
            String afterDecrpt = pc.decryptMsg(msgSignature, timestamp, nonce, fromXML);
            System.out.println(afterDecrpt);

其中msgSignature,timestamp,nonce就是你接收msg_signaturetimestamp,nonce的参数。

fromXML 这个需要讲一下,这个就需要大家去解析传送进来的信息了。在下面的代码中,可以看见fromXML是什么值。


		logger.info("接收ticket");
		String msgSignature = request.getParameter("msg_signature");
	        String timeStamp = request.getParameter("timestamp");
	        String nonce = request.getParameter("nonce");
	 
	        logger.info("开始接受postdata---"+request.getInputStream());
	        BufferedReader br = new BufferedReader(new InputStreamReader(request.getInputStream()));
	        StringBuffer sb = new StringBuffer();
	        String line = null;
	        while ((line=br.readLine()) != null) {
	            sb = sb.append(line);
	        }
	        String postData = sb.toString();
	        System.out.println(msgSignature+"------"+ timeStamp+"------"+ nonce+"------"+ postData);
	        
                WXBizMsgCrypt pc = new WXBizMsgCrypt(this.getTOKEN(), this.getENCODINGAESKEY(), this.getAPPID());
	        String result = pc.decryptMsg(msgSignature, timeStamp, nonce, postData);
	        System.out.println(result + ".................");

下面可以搜一下xml转换成map 的类。转换一下。就可以取到所需的component_verify_ticket 的内容了。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值