微信公众号开发(一)打通服务器与微信之间的通信

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: 说来惭愧PHP做了这么久,好像就没有从头开发过一个微信公众号,这次刚好有机会从头接入开发一个完整的公众号,也不能说完整,但是这些微信的接口我基本上都试一试~看看大概是什么情况。首先:打通服务器与微信之间的通信。

说来惭愧PHP做了这么久,好像就没有从头开发过一个微信公众号,这次刚好有机会从头接入开发一个完整的公众号,也不能说完整,但是这些微信的接口我基本上都试一试~看看大概是什么情况。

首先:打通服务器与微信之间的通信。

我这里主要使用的框架是thinkphp5

首先,去百度上找一个微信公众号的类。这种资源很多,基本上找一个就行,下边我是用我找的类中的方法介绍,文末有资源可下载。我这里只贴部分这里需要使用到的代码。

Weixin.php

php

复制代码

/**
   * @name: 验证服务器地址有效性
   * @author: camellia
   * @date: 20200711
   * @email:805795955@qq.com
   * @param:  $TOKEN  string  签名字符串
   * @return: data  type  description
   */
  public function valid($TOKEN)
  {
    $res = $this->checkSignature($TOKEN);
    if($res)
    {
      $echostr = $_GET['echostr'];//随机的字符串
      return $echostr;
    }
    else
    {
      return "Error";
    }
  }
  /**
   * @name: 检查签名
   * @desc: 描述
   * @author: camellia
   * @date: 20200711
   * @email:805795955@qq.com
   * @param:  $TOKEN  string  签名字符串
   * @return: data  type  description
   */
  protected function checkSignature($TOKEN)
  {
    if(empty($_GET))
    {
      return false;
    }
    //一、接收微信服务器GET方式提交过来的4个参数数据
    $signature = $_GET['signature'];//微信加密签名
    $timestamp = $_GET['timestamp'];//时间戳
    $nonce = $_GET['nonce'];//随机数
    //二、加密/校验过程
    // 1. 将token、timestamp、nonce三个参数进行字典序排序;
    // bool sort ( array &$array [, int $sort_flags = SORT_REGULAR ] ) 对数组排序
    $tmpArr = array($TOKEN,$timestamp,$nonce);//将上面三个参数放到一个数组里面
    sort($tmpArr,SORT_STRING);
    // 2. 将三个参数字符串拼接成一个字符串进行sha1加密;
    $tmpStr = implode($tmpArr); //将数组转化成字符串
    $signatureStr = sha1($tmpStr);
    // 3. 开发者获得加密后的字符串与signature对比。
    if($signatureStr == $signature)
    {
      return true;
    }
    else
    {
      return false;
    }
  }

调用:

ini

复制代码

/**
     * 验证微信接口
     */
    public function checkSignature()
    {
        $TOKEN = 'es3b3t41mk3matoji1tgortbctcoxiid';
        $weixin = new weixin();
        //var_dump($weixin); die;
        $res = $weixin->valid($TOKEN);
        echo $res;    
    }

上文中设置的$TOKEN的值,需要和微信公众平台开发配置的相同。如下图所示:

image.png

服务器地址配置你刚刚能访问到你调用的接口的地址,令牌(Token)就是一个随机字符串,啥都可以,但是复杂度最好高点,毕竟看着高级点。

当然这部分微信官方是有文档的,但是微信这个文档吧,第一次做能不能看明白,就得看你自己的了,想看请移步《微信官方文档

至此,服务器链接打通。

有好的建议,请在下方输入你的评论。

欢迎访问个人博客 guanchao.site

欢迎访问我的小程序:打开微信->发现->小程序->搜索“时间里的”

目录
相关文章
|
2月前
|
JavaScript 前端开发 应用服务中间件
【Vue面试题三十】、vue项目本地开发完成后部署到服务器后报404是什么原因呢?
这篇文章分析了Vue项目在服务器部署后出现404错误的原因,主要是由于history路由模式下服务器缺少对单页应用的支持,并提供了通过修改nginx配置使用`try_files`指令重定向所有请求到`index.html`的解决方案。
【Vue面试题三十】、vue项目本地开发完成后部署到服务器后报404是什么原因呢?
|
2月前
|
开发框架 JavaScript 前端开发
震撼!破解 ASP.NET 服务器控件 Button 执行顺序之谜,颠覆你的开发认知!
【8月更文挑战第16天】在ASP.NET开发中,通过Button控件实现先执行JavaScript再触后台处理的需求十分常见。例如,在用户点击按钮前需前端验证或提示,确保操作无误后再传递数据至后台深度处理。此过程可通过设置Button的`OnClientClick`属性调用自定义JavaScript函数完成验证;若验证通过,则继续触发后台事件。此外,结合jQuery也能达到相同效果,利用`__doPostBack`手动触发服务器端事件。这种方式增强了应用的交互性和用户体验。
40 8
|
1月前
|
开发框架 JavaScript 前端开发
|
3月前
|
小程序
尝试使用阿里云服务器搭建微信小程序
华北电力大学核工程大一学生,出于对编程的热爱与大创项目需求,涉足微信小程序搭建。初期在实验指导下克服不熟悉编程的困难,但后期发现教程引导不足,尤其是对于代码定位缺乏清晰指引。建议加强网页图像指导,以适应不同编程水平用户,尤其是新手。
尝试使用阿里云服务器搭建微信小程序
|
2月前
|
前端开发 大数据 数据库
🔥大数据洪流下的决战:JSF 表格组件如何做到毫秒级响应?揭秘背后的性能魔法!💪
【8月更文挑战第31天】在 Web 应用中,表格组件常用于展示和操作数据,但在大数据量下性能会成瓶颈。本文介绍在 JavaServer Faces(JSF)中优化表格组件的方法,包括数据处理、分页及懒加载等技术。通过后端分页或懒加载按需加载数据,减少不必要的数据加载和优化数据库查询,并利用缓存机制减少数据库访问次数,从而提高表格组件的响应速度和整体性能。掌握这些最佳实践对开发高性能 JSF 应用至关重要。
45 0
|
2月前
|
前端开发 安全 开发者
JSF文件上传,让Web应用如虎添翼!一招实现文件上传,让用户爱不释手!
【8月更文挑战第31天】在现代Web应用开发中,文件上传是重要功能之一。JSF(JavaServer Faces)框架提供了强大的文件上传支持,简化了开发流程。本文将介绍JSF文件上传的基本步骤:创建前端表单、处理上传文件的后端Action类、将文件保存到服务器指定目录以及返回结果页面。通过示例代码,我们将展示如何利用JSF实现文件上传功能,包括使用`h:inputFile`控件和`ManagedBean`处理上传逻辑。此外,JSF文件上传还具备类型安全、解耦合和灵活性等优点,有助于提升程序的健壮性和可维护性。
28 0
|
2月前
|
缓存 前端开发 测试技术
Angular 与 Angular Universal 超厉害!实现服务器端渲染,开启高效开发与优质用户体验之旅!
【8月更文挑战第31天】在现代前端开发中,用户体验至关重要。Angular Universal 为 Angular 应用提供服务器端渲染(SSR)解决方案,显著提升性能和可访问性。本文介绍 SSR 的优势,包括更快的首屏加载时间、更好的 SEO 和更稳定的用户体验。接着详细讲解安装和配置 Angular Universal 的步骤,并提供优化 SSR 性能的方法,如延迟加载、缓存和预取技术。同时讨论了处理动态内容的策略,并介绍了测试和部署的最佳实践。通过遵循这些实践,可以确保应用高效稳定运行,提升用户体验。附带的示例代码展示了如何在服务器端和客户端处理数据。
23 0
|
2月前
|
存储 设计模式 运维
Angular遇上Azure Functions:探索无服务器架构下的开发实践——从在线投票系统案例深入分析前端与后端的协同工作
【8月更文挑战第31天】在现代软件开发中,无服务器架构因可扩展性和成本效益而备受青睐。本文通过构建一个在线投票应用,介绍如何结合Angular前端框架与Azure Functions后端服务,快速搭建高效、可扩展的应用系统。Angular提供响应式编程和组件化能力,适合构建动态用户界面;Azure Functions则简化了后端逻辑处理与数据存储。通过具体示例代码,详细展示了从设置Azure Functions到整合Angular前端的全过程,帮助开发者轻松上手无服务器应用开发。
16 0
|
2月前
|
前端开发 安全 Java
在Java服务器端开发的浩瀚宇宙中,Servlet与JSP犹如两颗璀璨的明星,它们联袂登场,共同编织出动态网站的绚丽篇章。
在Java服务器端开发的浩瀚宇宙中,Servlet与JSP犹如两颗璀璨的明星,它们联袂登场,共同编织出动态网站的绚丽篇章。
18 0
支付系统35-----支付成功异步通知----数据锁,微信那边是有一个服务器集群的,不单单是有一个通知发送过来,有可能有两台更多台的服务器发送过来,把锁加到我们处理通知里面,在对业务数据进行状态检查和
支付系统35-----支付成功异步通知----数据锁,微信那边是有一个服务器集群的,不单单是有一个通知发送过来,有可能有两台更多台的服务器发送过来,把锁加到我们处理通知里面,在对业务数据进行状态检查和

热门文章

最新文章

下一篇
无影云桌面