微信开放平台获取component_verify_ticket,cas客户端获取ticket_PHP教程
微信开放平台获取component_verify_ticket,cas客户端获取ticket
官方文档说明:
在公众号第三方平台创建审核通过后,微信服务器会向其“授权事件接收URL”每隔10分钟定时推送component_verify_ticket。第三方平台方在收到ticket推送后也需进行解密(详细请见【消息加解密接入指引】),接收到后必须直接返回字符串success。
第一步是实例化微信提供的类 WXBizMsgCrypt ,传入开发平台的参数。
<span><span>$pc</span> = <span>new</span> WXBizMsgCrypt(WxPayConfig::Token, WxPayConfig::EncodingAesKey, WxPayConfig::open_AppID);</span>
微信开放平台获取component_verify_ticket时,除了通过GET获取 timestamp nonce encrypt_type msg_sign四个参数外 还需要通过 file_get_contents('php://input') 获取 postdata加密的参数(encryptMsg)。
获取到的 $encryptMsg 是Xml格式的是数据 需要提取出其中的 Encrypt 节点下的数据 如下:
<span><span>1</span> <span>$xml_tree</span> = <span>new</span><span> DOMDocument(); </span><span>2</span> <span>$xml_tree</span>->loadXML(<span>$encryptMsg</span><span>); </span><span>3</span> <span>$array_e</span> = <span>$xml_tree</span>->getElementsByTagName('Encrypt'<span>); </span><span>4</span> <span>$encrypt</span> = <span>$array_e</span>->item(0)->nodeValue;</span>
接下来需要将获取到的密文代入 另一段Xml中通过微信提供的 WXBizMsgCrypt 中的 decryptMsg 函数进行解密 和 通过sha1计算签名(因为 微信提供的 decryptMsg 函数中 要求 $encrypt是 Xml 格式 然后又再次提取 微信提供的做法)
<span>1</span> <span>$format</span> = "<xml><ToUserName><![CDATA[toUser]]></ToUserName><Encrypt><![CDATA[%s]]></Encrypt></xml>"<span>;</span> <span>2</span> <span>$from_xml</span> = <span>sprintf</span>(<span>$format</span>, <span>$encrypt</span>);
这是就可以调用 decryptMsg 函数进行解密了
<span><span> 1</span> <span>$msg</span> = ''<span>; </span><span> 2</span> <span> 3</span> <span>$errCode</span> = <span>$pc</span>->decryptMsg(<span>$msg_sign</span>, <span>$timeStamp</span>, <span>$nonce</span>, <span>$from_xml</span>, <span>$msg</span><span>); </span><span> 4</span> <span> 5</span> <span>if</span> (<span>$errCode</span> == 0<span>) { </span><span> 6</span> <span>//</span><span>由于返回的也是Xml格式的数据 所以这里再次提取ComponentVerifyTicket节点中的内容</span> <span> 7</span> <span>$xml</span> = <span>new</span><span> DOMDocument(); </span><span> 8</span> <span>$xml</span>->loadXML(<span>$msg</span><span>); </span><span> 9</span> <span>$array_e</span> = <span>$xml</span>->getElementsByTagName('ComponentVerifyTicket'<span>); </span><span>10</span> <span>$component_verify_ticket</span> = <span>$array_e</span>->item(0)-><span>nodeValue; </span><span>11</span> <span>//</span><span>获取到了$component_verify_ticket后就可以进行写入数据存储了</span> <span>12</span> <span>echo</span> "success"<span>; </span><span>13</span> }<span>else</span><span>{ </span><span>14</span> <span>echo</span> <span>$errCode</span><span>; </span><span>15</span> }</span>
到此就已经获取到了component_verify_ticket了。
全部代码:
<span>require_once ("wxBizMsgCrypt.php");<br />public</span> <span>function</span><span> index() { </span><span>$timeStamp</span> =<span>$_GET</span>['timestamp'<span>]; </span><span>$nonce</span> =<span>$_GET</span>['nonce'<span>]; </span><span>$encrypt_type</span> =<span>$_GET</span>['encrypt_type'<span>]; </span><span>$msg_sign</span> =<span>$_GET</span>['msg_signature'<span>]; </span><span>$encryptMsg</span> =<span>file_get_contents</span>('php://input'<span>); </span><span>$result</span> = <span>$this</span>->getVerify_Ticket(<span>$timeStamp</span>,<span>$nonce</span>,<span>$encrypt_type</span>,<span>$msg_sign</span>,<span>$encryptMsg</span><span>); </span><span>if</span>(<span>$result</span><span>){ </span><span>echo</span> "success"<span>; } } </span><span>//</span><span>获取component_verify_ticket</span> <span>public</span> <span>function</span> getVerify_Ticket(<span>$timeStamp</span>,<span>$nonce</span>,<span>$encrypt_type</span>,<span>$msg_sign</span>,<span>$encryptMsg</span><span>){ </span><span>$pc</span> = <span>new</span> WXBizMsgCrypt(WxPayConfig::Token, WxPayConfig::EncodingAesKey, WxPayConfig::<span>open_AppID); </span><span>$xml_tree</span> = <span>new</span><span> DOMDocument(); </span><span>$xml_tree</span>->loadXML(<span>$encryptMsg</span><span>); </span><span>$array_e</span> = <span>$xml_tree</span>->getElementsByTagName('Encrypt'<span>); </span><span>$encrypt</span> = <span>$array_e</span>->item(0)-><span>nodeValue; </span><span>$format</span> = "<xml><ToUserName><![CDATA[toUser]]></ToUserName><Encrypt><![CDATA[%s]]></Encrypt></xml>"<span>; </span><span>$from_xml</span> = <span>sprintf</span>(<span>$format</span>, <span>$encrypt</span><span>); </span><span>$msg</span> = ''<span>; </span><span>$errCode</span> = <span>$pc</span>->decryptMsg(<span>$msg_sign</span>, <span>$timeStamp</span>, <span>$nonce</span>, <span>$from_xml</span>, <span>$msg</span><span>); </span><span>if</span> (<span>$errCode</span> == 0<span>) { </span><span>$xml</span> = <span>new</span><span> DOMDocument(); </span><span>$xml</span>->loadXML(<span>$msg</span><span>); </span><span>$array_e</span> = <span>$xml</span>->getElementsByTagName('ComponentVerifyTicket'<span>); </span><span>$component_verify_ticket</span> = <span>$array_e</span>->item(0)-><span>nodeValue; DB</span>::getDB()->delete("wechat_verifyticket",'uptime!=1'<span>); DB</span>::getDB()->insert("wechat_verifyticket",<span>array</span><span>( </span>'component_verify_ticket' => <span>$component_verify_ticket</span>, 'uptime' => <span>time</span><span>())); </span><span>return</span> <span>true</span><span>; }</span><span>else</span><span>{ DB</span>::getDB()->delete("wechat_verifyticket",'uptime!=1'<span>); DB</span>::getDB()->insert("wechat_verifyticket",<span>array</span><span>( </span>'component_verify_ticket' => <span>$errCode</span>, 'uptime' => <span>time</span><span>())); </span><span>return</span> <span>false</span><span>; } }</span>

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

会话劫持可以通过以下步骤实现:1.获取会话ID,2.使用会话ID,3.保持会话活跃。在PHP中防范会话劫持的方法包括:1.使用session_regenerate_id()函数重新生成会话ID,2.通过数据库存储会话数据,3.确保所有会话数据通过HTTPS传输。

JWT是一种基于JSON的开放标准,用于在各方之间安全地传输信息,主要用于身份验证和信息交换。1.JWT由Header、Payload和Signature三部分组成。2.JWT的工作原理包括生成JWT、验证JWT和解析Payload三个步骤。3.在PHP中使用JWT进行身份验证时,可以生成和验证JWT,并在高级用法中包含用户角色和权限信息。4.常见错误包括签名验证失败、令牌过期和Payload过大,调试技巧包括使用调试工具和日志记录。5.性能优化和最佳实践包括使用合适的签名算法、合理设置有效期、

在PHPStorm中如何进行CLI模式的调试?在使用PHPStorm进行开发时,有时我们需要在命令行界面(CLI)模式下调试PHP�...

SOLID原则在PHP开发中的应用包括:1.单一职责原则(SRP):每个类只负责一个功能。2.开闭原则(OCP):通过扩展而非修改实现变化。3.里氏替换原则(LSP):子类可替换基类而不影响程序正确性。4.接口隔离原则(ISP):使用细粒度接口避免依赖不使用的方法。5.依赖倒置原则(DIP):高低层次模块都依赖于抽象,通过依赖注入实现。

如何在系统重启后自动设置unixsocket的权限每次系统重启后,我们都需要执行以下命令来修改unixsocket的权限:sudo...

静态绑定(static::)在PHP中实现晚期静态绑定(LSB),允许在静态上下文中引用调用类而非定义类。1)解析过程在运行时进行,2)在继承关系中向上查找调用类,3)可能带来性能开销。
