微信公众号服务器验证Token步骤图解


Posted in Javascript onDecember 30, 2019

这篇文章主要介绍了微信公众号服务器验证Token步骤图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

服务器验证Token验证分为以下及步骤

一,在微信公众号平台上设置

1.1打开微信公众号平台

1.2打开”开发“中的<基本配置>

微信公众号服务器验证Token步骤图解

1.3点击基本配置页面里的修改配置

微信公众号服务器验证Token步骤图解

1.4输入URL:

url填写:http://外网IP:端口号/wx 。外网IP请到腾讯云购买成功处查询, http的端口号固定使用80,不可填写其他。

Token:自主设置,这个token与公众平台wiki中常提的access_token不是一回事。这个token只用于验证开发者服务器。(注:Token可以随便写 写完记住留着备用)

EncodingAESKey:点击随机生成

微信公众号服务器验证Token步骤图解

现在选择提交肯定是验证token失败,因为还需要完成代码逻辑。改动原先main.py文件,新增handle.py 也可以用wbe文件

二,编写后台程序

我选用的是web,ashx一般处理程序页面

微信公众号服务器验证Token步骤图解

代码源码:

namespace WEF
{
  /// <summary>
  /// Token 的摘要说明
  /// </summary>
  public class Token : IHttpHandler
  {

    public void ProcessRequest(HttpContext context)
    {
      ProcesyanzhengsRequest(context);//执行下面方法

    }

    public bool IsReusable
    {
      get
      {
        return false;
      }
    }

    public void ProcesyanzhengsRequest(HttpContext context)
    {
      context.Response.ContentType = "text/plain";
      string token = " ";//输入你上面自己编写的Token
      if (string.IsNullOrEmpty(token))
      {
        return;
      }

//取到Token接收到的值
      string echoString = HttpContext.Current.Request.QueryString["echoStr"];
      string signature = HttpContext.Current.Request.QueryString["signature"];
      string timestamp = HttpContext.Current.Request.QueryString["timestamp"];
      string nonce = HttpContext.Current.Request.QueryString["nonce"];
      if (CheckSignature(token, signature, timestamp, nonce)) //判断验证是否正确
      {
        if (!string.IsNullOrEmpty(echoString))  正确返回微信服务器
        {
          HttpContext.Current.Response.Write(echoString);
          HttpContext.Current.Response.End();
        }

      }

    }
    /// <summary>
    /// 验证微信签名
    /// </summary>
    public static bool CheckSignature(string token, string signature, string timestamp, string nonce)
    {
      string[] ArrTmp = { token, timestamp, nonce };
      //字典排序
      Array.Sort(ArrTmp);
      //拼接
      string tmpStr = string.Join("", ArrTmp);
      //sha1验证
      tmpStr = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(tmpStr, "SHA1");
      //tmpStr = Membership.CreateUser(tmpStr, "SHA1");
      tmpStr = tmpStr.ToLower();
      if (tmpStr == signature) //如果计算后得到的数值与传过来的数值相等
      {
        return true;  //返回正确
      }
      else
      {
        return false; //不相等 返回错误
      }
    }

  }
}

三,上传到服务器

1.打开D:Web.config

<connectionStrings>
<add name="SqlConnectionString"
connectionString="server=.;database=WEF;uid=sa;pwd=1@#;Enlist=true;Pooling=true;Max Pool Size=300;Min Pool Size=0;Connection Lifetime=300;user id=sa;packet size=1000"/>
</connectionStrings>

2.将server地址改成。

将database文件夹名称改成你写的代码文件夹名称

3.右键点击文件 点击发布

微信公众号服务器验证Token步骤图解

4.点击发布

微信公众号服务器验证Token步骤图解

5.打开文件夹 右键点击将文件解压

微信公众号服务器验证Token步骤图解微信公众号服务器验证Token步骤图解

6.打开服务器

微信公众号服务器验证Token步骤图解

7.将解压的文件 粘贴到桌面上 粘贴好解压成文件

微信公众号服务器验证Token步骤图解

9.将解压好的文件放到你的服务器C盘自定义的文件夹内

三。部署服务器

1.点击服务器开始菜单 打开IIS管理器

点击IP

微信公众号服务器验证Token步骤图解

2.右键点击网站 点击添加网站网站

网站名称自己写

路径选择你文件粘贴到C盘的文件夹

主机名称填写你部署网站的网址

点击确定就行了

微信公众号服务器验证Token步骤图解

3.点击应用程序池

微信公众号服务器验证Token步骤图解

4.将刚添加的网站端口从2.0改成4.0 保存即可

再点你添加的网站 击浏览网站

微信公众号服务器验证Token步骤图解微信公众号服务器验证Token步骤图解

将会出现”服务器错误页面“ 出现这个页面就算已经部署完毕

微信公众号服务器验证Token步骤图解

四,打开微信公众号平台 修改配置页面

直接点击提交可能会登陆超时 的从新登陆 编写修改配置

从新填写一遍 并把URL Token 填写正确 确保跟上次填写的一样

点击提交即可

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js中判断控件是否存在
Aug 25 Javascript
jquery css 设置table的奇偶行背景色示例
Jun 03 Javascript
基于jQuery滑动杆实现购买日期选择效果
Sep 15 Javascript
JS提交form表单实例分析
Dec 10 Javascript
javascript防篡改对象实例详解
Apr 10 Javascript
js事件on动态绑定数据,绑定多个事件的方法
Sep 15 Javascript
微信小程序中转义字符的处理方法
Mar 28 Javascript
微信小程序如何实现全局重新加载
Jun 05 Javascript
Vue移动端右滑屏幕返回上一页附源码下载
Jun 26 Javascript
JS面向对象之单选框实现
Jan 17 Javascript
JavaScript oncopy事件用法实例解析
May 13 Javascript
js实现删除json中指定的元素
Sep 22 Javascript
微信小程序封装多张图片上传api代码实例
Dec 30 #Javascript
使用pkg打包ThinkJS项目的方法步骤
Dec 30 #Javascript
微信小程序实现一个简单swiper代码实例
Dec 30 #Javascript
JavaScript switch语句使用方法简介
Dec 30 #Javascript
微信小程序自定义菜单切换栏tabbar组件代码实例
Dec 30 #Javascript
详解Vue的watch中的immediate与watch是什么意思
Dec 30 #Javascript
jQuery模仿ToDoList实现简单的待办事项列表
Dec 30 #jQuery
You might like
PL-880隐藏功能
2021/03/01 无线电
php redis实现对200w用户的即时推送
2017/03/04 PHP
jquery 选择器引擎sizzle浅析
2013/02/06 Javascript
技术男用来对妹子表白的百度首页
2014/07/23 Javascript
JavaScript实现继承的4种方法总结
2014/10/16 Javascript
Python脚本后台运行的几种方式
2015/03/09 Javascript
JavaScript使用pop方法移除数组最后一个元素用法实例
2015/04/06 Javascript
jQuery soColorPacker 网页拾色器
2016/06/22 Javascript
jquery 实现复选框的全选操作实例代码
2017/01/24 Javascript
Vue中添加过渡效果的方法
2017/03/16 Javascript
Javascript别踩白块儿(钢琴块儿)小游戏实现代码
2017/07/20 Javascript
移动端网页开发调试神器Eruda的介绍与使用技巧
2017/10/30 Javascript
使用webpack-dev-server处理跨域请求的方法
2018/04/18 Javascript
详解从react转职到vue开发的项目准备
2019/01/14 Javascript
vue控制多行文字展开收起的实现示例
2019/10/11 Javascript
Node.js中console.log()输出彩色字体的方法示例
2019/12/01 Javascript
js实现列表向上无限滚动
2020/01/13 Javascript
Python实现自动添加脚本头信息的示例代码
2016/09/02 Python
python 接口返回的json字符串实例
2018/03/27 Python
PyQt5每天必学之QSplitter实现窗口分隔
2018/04/19 Python
Django使用AJAX调用自己写的API接口的方法
2019/03/06 Python
浅谈pandas dataframe对除数是零的处理
2020/07/20 Python
Python基于locals返回作用域字典
2020/10/17 Python
建筑设计所实习生自我鉴定
2013/09/25 职场文书
工地标语大全
2014/06/18 职场文书
高中教师先进事迹材料
2014/08/22 职场文书
总经理检讨书
2014/09/15 职场文书
企业法人授权委托书
2014/09/25 职场文书
全国法制宣传日活动总结2014
2014/11/01 职场文书
2014年乡镇个人工作总结
2014/12/03 职场文书
爱国主义电影观后感
2015/06/18 职场文书
公文写作:教你写“建议书”
2019/05/07 职场文书
MySQL触发器的使用
2021/05/24 MySQL
Python趣味挑战之实现简易版音乐播放器
2021/05/28 Python
实现一个简单得数据响应系统
2021/11/11 Javascript
MySQL Server 层四个日志
2022/03/31 MySQL