企业微信 AES 加密 回调模式 细节决定成败之Java踩坑日记(一)


		String msgSignature = request.getParameter("msg_signature");
		String nonce = request.getParameter("nonce");
		String timestamp = request.getParameter("timestamp");
		String echostr = request.getParameter("echostr");
		response.setContentType("text/html;charset=utf-8");
		response.setStatus(HttpServletResponse.SC_OK);
		if (StringUtils.isNotBlank(echostr)) {
				try {
					WXBizMsgCrypt wxcpt  = new WXBizMsgCrypt("vqbyk2JG", "bG9IAGJT9XoytBRnbVzR5q7bgub755Fnj7Ny7IBVkzX", "wwc6ab8d2ebbe64348");
					String sEchoStr = wxcpt.VerifyURL(msgSignature, nonce,timestamp, echostr);
					System.out.println(sEchoStr);
					System.out.println("===wwwww================");  				                
                   response.getWriter().println(sEchoStr);
				} catch (Exception e) {
					// TODO Auto-generated catch block

					System.out.println(e);
				}
//				 企业号应用在开启回调模式的时候,会传递加密echostr给服务器,企业应该对echostr参数解密并原样返回echostr明文(不能加引号,不能带bom头,不能带换行符),则接入验证生效,回调模式才能开启
				
                   
				System.out.println("====================");
				
				
//	        
			
				return;

		}

这是我使用企业微信提供的工具类进行的解密过程 点击下载

上面的代码,打开一看是没有什么问题, 但是在请求企业微信后,一直提示明文不正确,到时无法进行下一步,昨天晚上一直在网上研究方法, 更换jce策略包、更换配置等等等。 进行到8点钟,一直没进展,企业微信客服也下班了,就回去了。

今天重新研究,从头到尾排查可能性, 最后的最后, 真的是细节成败,希望你们也注意

response.getWriter().println(sEchoStr);  就是这一句导致无法验证???

至于为什么,相信有大神已经看出来了。  就是因为println而不是print 导致了换行符出现无限报错 对不上。

哈哈哈哈

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值