企业微信加密消息体_微信公众平台开发者中心安全模式消息体加解密实现

关键字:微信公众平台 消息体签名 消息体加解密 EncodingAESKey 安全模式

一、消息体加解密

微信公众平台在配置服务器时,提供了3种加解密的模式供开发者选择,即明文模式、兼容模式、安全模式,选择兼容模式和安全模式前,需在开发者中心填写消息加解密密钥EncodingAESKey。

明文模式:维持现有模式,没有适配加解密新特性,消息体明文收发,默认设置为明文模式

兼容模式:公众平台发送消息内容将同时包括明文和密文,消息包长度增加到原来的3倍左右;公众号回复明文或密文均可,不影响现有消息收发;开发者可在此模式下进行调试

安全模式(推荐):公众平台发送消息体的内容只含有密文,公众账号回复的消息体也为密文,建议开发者在调试成功后使用此模式收发消息

什么是EncodingAESKey?

微信公众平台采用AES对称加密算法对推送给公众帐号的消息体对行加密,EncodingAESKey则是加密所用的秘钥。公众帐号用此秘钥对收到的密文消息体进行解密,回复消息体也用此秘钥加密。AES对称加密算法的原理可以参考 http://www.cnblogs.com/txw1958/p/aes.html

加解密的详细技术方案可以参考官方文档 http://mp.weixin.qq.com/wiki/index.php?title=%E6%8A%80%E6%9C%AF%E6%96%B9%E6%A1%88

二、开发实现及数据分析

1. 配置

假设本次的开发配置中URL为

http://www.fangbei.org/index.php

接口程序中需要配置以下三项参数

/*方倍工作室 http://www.cnblogs.com/txw1958/

CopyRight 2014 All Rights Reserved*/

define("TOKEN", "weixin");define("AppID", "wxbad0b45542aa0b5e");define("EncodingAESKey", "abcdefghijklmnopqrstuvwxyz0123456789ABCDEFG");require_once('wxBizMsgCrypt.php');

2. 加解密实现

当用户向公众账号发送消息时,微信公众账号将会在URL中带上signature、timestamp、nonce、encrypt_type、msg_signature等参数,如下所示

http://www.fangbei.org/index.php?signature=35703636de2f9df2a77a662b68e521ce17c34db4&timestamp=1414243737&nonce=1792106704&encrypt_type=aes&msg_signature=6147984331daf7a1a9eed6e0ec3ba69055256154

同时向该接口推送如下XML消息 ,即一个已加密的消息

这时,程序需要从url中获得以下参数

$timestamp = $_GET['timestamp'];$nonce = $_GET["nonce"];$msg_signature = $_GET['msg_signature'];$encrypt_type = $_GET['encrypt_type'];

这些参数将用于加解密过程

收到消息后,先进行解密,解密部分代码如下

$postStr = $GLOBALS["HTTP_RAW_POST_DATA"];if ($encrypt_type == 'aes'){$pc = new WXBizMsgCrypt(TOKEN, EncodingAESKey,AppID);$this->logger(" D \r\n".$postStr);$decryptMsg = ""; //解密后的明文

$errCode = $pc->DecryptMsg($msg_signature, $timestamp, $nonce, $postStr, $decryptMsg);$postStr = $decryptMsg;

}

解密完成后,把解密内容又返回给$postStr,这是为了保证将消息中解密后的内容和明文模式时的消息统一,方便后续处理,解密后的XML如下

1414243737

6074130599188426998

对消息在自己的原来代码中处理,完成之后,要回复的消息如下

1414243733

技术支持 方倍工作室

http://www.fangbei.org/]]>

把上述消息进行加密,返回给微信公众账号

//加密

if ($encrypt_type == 'aes'){$encryptMsg = ''; //加密后的密文

$errCode = $pc->encryptMsg($result, $timeStamp, $nonce, $encryptMsg);$result = $encryptMsg;$this->logger(" E \r\n".$result);

}

加密后的内容如下

1414243733

这样,一个安全模式下的加解密消息就完成了。

三、完整代码

1 <?php2 /*

3 方倍工作室 http://www.cnblogs.com/txw1958/4 CopyRight 2014 All Rights Reserved5 */

6 define("TOKEN", "weixin");7 define("AppID", "wxbad0b45542aa0b5e");8 define("EncodingAESKey", "abcdefghijklmnopqrstuvwxyz0123456789ABCDEFG");9 require_once('wxBizMsgCrypt.php');10

11 $wechatObj = newwechatCallbackapiTest();12 if (!isset($_GET['echostr'])) {13 $wechatObj->responseMsg();14 }else{15 $wechatObj->valid();16 }17

18 classwechatCallbackapiTest19 {20 //验证签名

21 public functionvalid()22 {23 $echoStr = $_GET["echostr"];24 $signature = $_GET["signature"];25 $timestamp = $_GET["timestamp"];26 $nonce = $_GET["nonce"];27 $tmpArr = array(TOKEN, $timestamp, $nonce);28 sort($tmpArr);29 $tmpStr = implode($tmpArr);30 $tmpStr = sha1($tmpStr);31 if($tmpStr == $signature){32 echo $echoStr;33 exit;34 }35 }36

37 //响应消息

38 public functionresponseMsg()39 {40 $timestamp = $_GET['timestamp'];41 $nonce = $_GET["nonce"];42 $msg_signature = $_GET['msg_signature'];43 $encrypt_type = (isset($_GET['encrypt_type']) && ($_GET['encrypt_type'] == 'aes')) ? "aes" : "raw";44

45 $postStr = $GLOBALS["HTTP_RAW_POST_DATA"];46 if (!empty($postStr)){47 //解密

48 if ($encrypt_type == 'aes'){49 $pc = new WXBizMsgCrypt(TOKEN, EncodingAESKey,AppID);50 $this->logger(" D \r\n".$postStr);51 $decryptMsg = ""; //解密后的明文

52 $errCode = $pc->DecryptMsg($msg_signature, $timestamp, $nonce, $postStr, $decryptMsg);53 $postStr = $decryptMsg;54 }55 $this->logger(" R \r\n".$postStr);56 $postObj = simplexml_load_string($postStr, 'SimpleXMLElement',LIBXML_NOCDATA);57 $RX_TYPE = trim($postObj->MsgType);58

59 //消息类型分离

60 switch ($RX_TYPE)61 {62 case "event":

63 $result = $this->receiveEvent($postObj);64 break;65 case "text":

66 $result = $this->receiveText($postObj);67 break;68 }69 $this->logger(" R \r\n".$result);70 //加密

71 if ($encrypt_type == 'aes'){72 $encryptMsg = ''; //加密后的密文

73 $errCode = $pc->encryptMsg($result, $timeStamp, $nonce, $encryptMsg);74 $result = $encryptMsg;75 $this->logger(" E \r\n".$result);76 }77 echo $result;78 }else{79 echo "";80 exit;81 }82 }83

84 //接收事件消息

85 private function receiveEvent($object)86 {87 $content = "";88 switch ($object->Event)89 {90 case "subscribe":

91 $content = "欢迎关注方倍工作室 ";92 break;93 }94

95 $result = $this->transmitText($object, $content);96 return $result;97 }98

99 //接收文本消息

100 private function receiveText($object)101 {102 $keyword = trim($object->Content);103 if (strstr($keyword, "文本")){104 $content = "这是个文本消息";105 }else if (strstr($keyword, "单图文")){106 $content = array();107 $content[] = array("Title"=>"单图文标题", "Description"=>"单图文内容", "PicUrl"=>"http://discuz.comli.com/weixin/weather/icon/cartoon.jpg", "Url" =>"http://m.cnblogs.com/?u=txw1958");108 }else if (strstr($keyword, "图文") || strstr($keyword, "多图文")){109 $content = array();110 $content[] = array("Title"=>"多图文1标题", "Description"=>"", "PicUrl"=>"http://discuz.comli.com/weixin/weather/icon/cartoon.jpg", "Url" =>"http://m.cnblogs.com/?u=txw1958");111 $content[] = array("Title"=>"多图文2标题", "Description"=>"", "PicUrl"=>"http://d.hiphotos.bdimg.com/wisegame/pic/item/f3529822720e0cf3ac9f1ada0846f21fbe09aaa3.jpg", "Url" =>"http://m.cnblogs.com/?u=txw1958");112 $content[] = array("Title"=>"多图文3标题", "Description"=>"", "PicUrl"=>"http://g.hiphotos.bdimg.com/wisegame/pic/item/18cb0a46f21fbe090d338acc6a600c338644adfd.jpg", "Url" =>"http://m.cnblogs.com/?u=txw1958");113 }else if (strstr($keyword, "音乐")){114 $content = array();115 $content = array("Title"=>"最炫民族风", "Description"=>"歌手:凤凰传奇", "MusicUrl"=>"http://121.199.4.61/music/zxmzf.mp3", "HQMusicUrl"=>"http://121.199.4.61/music/zxmzf.mp3");116 }else{117 $content = date("Y-m-d H:i:s",time())."\n".$object->FromUserName."\n技术支持 方倍工作室";118 }119

120 if(is_array($content)){121 if (isset($content[0])){122 $result = $this->transmitNews($object, $content);123 }else if (isset($content['MusicUrl'])){124 $result = $this->transmitMusic($object, $content);125 }126 }else{127 $result = $this->transmitText($object, $content);128 }129 return $result;130 }131

132 //回复文本消息

133 private function transmitText($object, $content)134 {135 $xmlTpl = "136 137 138 %s139 140 141 ";142 $result = sprintf($xmlTpl, $object->FromUserName, $object->ToUserName, time(), $content);143 return $result;144 }145

146 //回复图文消息

147 private function transmitNews($object, $newsArray)148 {149 if(!is_array($newsArray)){150 return;151 }152 $itemTpl = "153 154 155 156 157 158 ";159 $item_str = "";160 foreach ($newsArray as $item){161 $item_str .= sprintf($itemTpl, $item['Title'], $item['Description'], $item['PicUrl'], $item['Url']);162 }163 $xmlTpl = "164 165 166 %s167 168 %s169 170 $item_str171 ";172

173 $result = sprintf($xmlTpl, $object->FromUserName, $object->ToUserName, time(), count($newsArray));174 return $result;175 }176

177 //回复音乐消息

178 private function transmitMusic($object, $musicArray)179 {180 $itemTpl = "181 182 183 184 185 ";186

187 $item_str = sprintf($itemTpl, $musicArray['Title'], $musicArray['Description'], $musicArray['MusicUrl'], $musicArray['HQMusicUrl']);188

189 $xmlTpl = "190 191 192 %s193 194 $item_str

195 ";196

197 $result = sprintf($xmlTpl, $object->FromUserName, $object->ToUserName, time());198 return $result;199 }200

201 //日志记录

202 public function logger($log_content)203 {204 if(isset($_SERVER['HTTP_APPNAME'])){ //SAE

205 sae_set_display_errors(false);206 sae_debug($log_content);207 sae_set_display_errors(true);208 }else if($_SERVER['REMOTE_ADDR'] != "127.0.0.1"){ //LOCAL

209 $max_size = 500000;210 $log_filename = "log.xml";211 if(file_exists($log_filename) and (abs(filesize($log_filename)) > $max_size)){unlink($log_filename);}212 file_put_contents($log_filename, date('Y-m-d H:i:s').$log_content."\r\n",FILE_APPEND);213 }214 }215 }216 ?>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/561143.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

hadoop没有datanode_Hadoop运行在Kubernetes平台实践

Hadoop与Kubernetes就好像江湖里的两大绝世高手&#xff0c;一个是成名已久的长者&#xff0c;至今仍然名声远扬&#xff0c;一个则是初出茅庐的青涩少年&#xff0c;骨骼惊奇&#xff0c;不走寻常路&#xff0c;一出手便惊诧了整个武林。Hadoop与Kubernetes之间有很深的渊源&a…

mysql text类型 使用方法_MySQL使用TEXT/BLOB类型的知识点详解

一、TEXT和BLOB的区别TEXT和BLOB家族之间仅有的不同是BLOB类型存储的是二进制数据&#xff0c;没有排序规则或字符集&#xff0c;而TEXT类型有字符集或排序规则。说白了如果要储存中文则选择TEXT。二、默认值问题Strict Mode下不能设置默认值&#xff0c;否则会报cant have a d…

git 修改commit_Git从8到13 深入了解Git特性

上一章简单的介绍了一些常用的Git命令&#xff0c;这一章主要是深入了解一下Git的稍微高级的一些知识和指令。8.首先我们先来通过查看Git目录里面的文件来深入了解一下Git版本控制的构造。 查看HEAD可以知道当前所在的分支。在config文件里面存储着Git里面的一些配置信息&#…

mysql商品表_MySQL数据库创建商品表

(注&#xff1a;若直接复制上去会报错&#xff0c;可能是标点符号问题&#xff0c;所有标点符号均为英文状态&#xff01;)1.商品分类表创建商品分类表(选择mydb数据库)use mydb;create table sh_good_category(id int unsigned primary key auto_increment comment ‘分类id’…

win执行mysql建库脚本_linux执行mysql脚本文件连接本地windows数据库

又开始玩linux了&#xff0c;小白一个&#xff0c;连ls命令都是这两天新学的&#xff0c;今天又学了点东西&#xff0c;贴上来备忘&#xff1a;需求&#xff1a;我是想要在linux执行一个.py文件&#xff0c;这个文件执行后可以远程连接我的本地windows的mysql数据库&#xff0c…

eclipse maven打包jar 部分jsp无法访问_Maven系列教材 (九)- 在Eclipse中创建maven风格的java web项目...

Maven系列教材 &#xff08;九&#xff09;- 在Eclipse中创建maven风格的java web项目步骤1:删除j2ee目录步骤2:新建Maven 项目步骤3:这个界面点下一步步骤4: 这个界面使用webapp&#xff0c;点下一步 步骤5:这一步填写如图所示的信息步骤6:此时得到的maven web 项目的问题步骤…

php mysql预处理_PHP MySQL 预处理语句

预处理语句对于防止 MySQL 注入是非常有用的。SQL注入&#xff0c;就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串&#xff0c;最终达到欺骗服务器执行恶意的SQL命令。预处理语句及绑定参数预处理语句用于执行多个相同的 SQL 语句&#xff0c;并且执行效…

final关键字_深入分析Java中的final关键字

Java中被final修饰的变量与普通变量有何区别&#xff1f;被final修饰的变量不可更改、被final修饰的方法不可重写是怎样做到的&#xff1f;带着疑问我们一点点拨开云雾。一、final的内存定义及规则对于final关键字&#xff0c;编译器、处理器从读写两个角度限制了其使用规则&am…

嵌入式和fpga哪个好前景_Java 和 go 哪个就业前景好一点?面向金钱编程,这个回答太现实...

有个朋友问我&#xff1a;ava 和 go 哪个就业前景好一点&#xff1f;现在纠结中&#xff0c;差不多一年半就要毕业了。我也问了几个朋友程序员朋友&#xff1a;朋友A: 可以参考 Boss 直聘&#xff0c;面向金钱编程&#xff0c;我身边的 Java 都是 15k 左右&#xff0c;反正干就…

php解决mysql主从同步_Mysql读写分离,主从同步实现

随着用户量的增多&#xff0c;数据库操作往往会成为一个系统的瓶颈所在&#xff0c;因此我们可以通过实现数据库的读写分离来提高系统的性能。通过设置主从数据库实现读写分离&#xff0c;主库负责“写”操作&#xff0c;从库负责“读”操作&#xff0c;根据压力情况&#xff0…

python创建数组的方法_numpy创建array的方法汇总

创建numpy.array&#xff0c;是使用numpy这个核武器的基础&#xff0c;本文尽量汇总常用创建numpy.array的方法。array函数>>> import numpy as np>>> a np.array([1,2,3,4,5])>>> aarray([1, 2, 3, 4, 5])>>> a.shape(5,)>>> a…

mysql_install_db is deprecated_MySQL5.7源码安装问题汇总

编译安装mysql5.7版本&#xff0c;想试用一下新的版本特性&#xff0c;发现跟之前的5.6版本编译有了一些变化&#xff0c;总结一下避免以后继续入坑。5.6安装方式cmake版本5.7编译cmake要求版本最低为2.8&#xff0c;当前为2.6&#xff0c;所以需要升级cmake版本。信息如下shel…

验证码图片显示不出来怎么办_pr 的蒙版不显示了怎么办?

小白自学pr一路会遇到很多坑&#xff0c;我也是在一个个坑里爬过的。画好的蒙版不显示了&#xff0c;这只能算是一个小坑。解决方法很简单&#xff0c;只需要记住一条&#xff1a;在pr里想要调整或者显示什么东西&#xff0c;首先必须要选中它。举例说明&#xff1a;我给小猫的…

gb2312编码表_汉字编码输入系统模型(一)

通过前面介绍的通信系统模型来分析汉字编码输入系统&#xff0c;将汉字编码输入系统的特殊性整合到通信系统模型中&#xff0c;从而建立起一种基于信息论的汉字编码输入系统模型&#xff08;参见图3.2&#xff09;&#xff0c;以便指导我们的汉字编码输入实践&#xff0c;设计和…

python dict hash_【python-dict】dict的使用及实现原理

以下内容是针对&#xff1a;python源码剖析中的第五章——python中Dict对象 的读书笔记(针对书中讲到的内容进行了自己的整理&#xff0c;并且针对部分内容根据自己的需求进行了扩展)一、Dict的用法Dict的对象在使用到了所谓的关联关系的时候&#xff0c;就是通过key-value的形…

python参考文献_[zotero/python]库中参考文献条目删除后,清除残留PDF的脚本

更新&#xff1a;使用 滏阳河边捉蚯蚓 https://zhuanlan.zhihu.com/p/41297136上获取系统PDF文件和zotero.sqlite文件的代码&#xff0c;在此感谢&#xff01;在zotero的library中删除参考文献条目后&#xff0c;有时PDF不会同步删除&#xff0c;尤甚是安装了zotfile插件后&…

java中sql语句怎么把开始和结束时间作为参数写sql查询_JDBC数据库连接怎么操作?...

之前一直听说过JDBC&#xff0c;但从来不知道它是何物的小伙伴们看过来啦&#xff01;一、概述JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API&#xff0c;可以为多种关系数据库提供统一访问&#xff0c;它由一组用Java语言编写的类和接口组…

spring boot整合shiro继承redis_spring-boot-plus集成Shiro+JWT权限管理

SpringBootShiroJWT权限管理ShiroApache Shiro是一个强大且易用的Java安全框架,执行身份验证、授权、密码和会话管理。使用Shiro的易于理解的API,您可以快速、轻松地获得任何应用程序,从最小的移动应用程序到最大的网络和企业应用程序。三个核心组件&#xff1a;Subject, Secur…

java 整数变负数_一文帮你读懂Java整数的存储原理

前言大家应该都知道&#xff0c;整数包括负数&#xff0c;零&#xff0c;和正数。在Java中&#xff0c;基本类型中byte(8位)、short(16位)、int(32位)、long(64位)属于整数&#xff0c;并且没有无符号数&#xff0c;均是有符号的。对于计算机来说&#xff0c;它只认识二进制&am…

server2019 sqlcmd命令安装_Ubuntu20.04LTS安装MS sql-server2019的方法

在本文中&#xff0c;我将向您展示如何在Ubuntu 20.04 Focal Fossa上安装Microsoft SQL Server。小广告&#xff1a;喜欢网络技术的朋友可以加W信&#xff1a;xfiles_sky一起学习进步。步骤一&#xff1a;更新ubuntu源sudo apt update && sudo apt upgrade步骤二&#…