微信公众平台接入:其实很简单,把两个参数(地址和token)填入微信公众平台后台,暂时选择明文模式 ,其中token自己定义。微信服务器会根据后台填写的地址访问,并且带上对于的参数 如 url+&signature=0dab3e6f983b6bdccfdbe3ceca01526f1522748a&timestamp=1436257899&nonce=1868246535&echostr=echostr 根据参数用微信文档中指定的方法加密检验是否来自微信然后返回随机数echostr(当然你可以直接返回随机数,好处是简单,但是这样非微信服务器也可以访问你的服务器)

此处的方法是:新建一个一般处理程序(通常的做法是有伪静态处理,不生成伪静态地址也可以)代码如下 token自定义,token类似密码,如果泄露和微信的密钥一样可以修改。因为接入非常简单这里就不多写,可以直接看代码。

我写的demo测试地址为:http://wxdemo.sohovan.com/API.ashx  token:sohovan 下载源码的github地址:https://github.com/xiejun-net/weixin

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Web;
  5. using System.Web.SessionState;
  6. using System.Web.Security;
  7.  
  8. namespace sohovan.com.wxdemo
  9. {
  10. /// <summary>
  11. /// API 的摘要说明
  12. /// </summary>
  13. public class API : IHttpHandler, IRequiresSessionState
  14. {
  15.  
  16. public void ProcessRequest(HttpContext context)
  17. {
  18. context.Response.ContentType = "text/plain";
  19. if (context.Request.HttpMethod.ToLower() == "post")
  20. {
  21. //回复消息的时候也需要验证消息,这个很多开发者没有注意这个,存在安全隐患
  22. //微信中 谁都可以获取信息 所以 关系不大 对于普通用户 但是对于某些涉及到验证信息的开发非常有必要
  23. if (CheckSignature())
  24. {
  25. //接收消息
  26. }
  27. else
  28. {
  29. HttpContext.Current.Response.Write("消息并非来自微信");
  30. HttpContext.Current.Response.End();
  31. }
  32. }
  33. else
  34. {
  35. CheckWechat();
  36. }
  37. }
  38.  
  39. #region 验证微信签名
  40. /// <summary>
  41. /// 返回随机数表示验证成功
  42. /// </summary>
  43. private void CheckWechat()
  44. {
  45. if (string.IsNullOrEmpty(HttpContext.Current.Request.QueryString["echoStr"]))
  46. {
  47. HttpContext.Current.Response.Write("消息并非来自微信");
  48. HttpContext.Current.Response.End();
  49. }
  50. string echoStr = HttpContext.Current.Request.QueryString["echoStr"];
  51. if (CheckSignature())
  52. {
  53. HttpContext.Current.Response.Write(echoStr);
  54. HttpContext.Current.Response.End();
  55. }
  56. }
  57.  
  58. /// <summary>
  59. /// 验证微信签名
  60. /// </summary>
  61. /// <returns></returns>
  62. /// * 将token、timestamp、nonce三个参数进行字典序排序
  63. /// * 将三个参数字符串拼接成一个字符串进行sha1加密
  64. /// * 开发者获得加密后的字符串可与signature对比,标识该请求来源于微信。
  65. private bool CheckSignature()
  66. {
  67. string access_token = "sohovan";
  68.  
  69. string signature = HttpContext.Current.Request.QueryString["signature"].ToString();
  70. string timestamp = HttpContext.Current.Request.QueryString["timestamp"].ToString();
  71. string nonce = HttpContext.Current.Request.QueryString["nonce"].ToString();
  72. string[] ArrTmp = { access_token, timestamp, nonce };
  73. Array.Sort(ArrTmp); //字典排序
  74. string tmpStr = string.Join("", ArrTmp);
  75. tmpStr = FormsAuthentication.HashPasswordForStoringInConfigFile(tmpStr, "SHA1");
  76.  
  77. if (tmpStr.ToLower() == signature)
  78. {
  79. return true;
  80. }
  81. else
  82. {
  83. return false;
  84. }
  85. }
  86. #endregion
  87.  
  88. public bool IsReusable
  89. {
  90. get
  91. {
  92. return false;
  93. }
  94. }
  95. }
  96. }

本文版权归作者(谢俊)和博客园所有,欢迎转载,转载请标明出处。

原文地址:http://www.cnblogs.com/net-xiejun/

微信开发群

完整源码下载:https://github.com/xiejun-net/weixin

个人公众账号:

C#/ASP.NET MVC微信公众号接口开发之从零开发(一) 接入微信公众平台的更多相关文章

  1. Java开发微信公众号(二)---开启开发者模式,接入微信公众平台开发

    接入微信公众平台开发,开发者需要按照如下步骤完成: 1.填写服务器配置 2.验证服务器地址的有效性 3.依据接口文档实现业务逻辑 资料准备: 1.一个可以访问的外网,即80的访问端口,因为微信公众号接 ...

  2. http80端口转发(实现微信公众号接口绑定IP时,同时支持多个公众号)

    http80端口转发 背景 微信公众平台接口绑定服务器时,如果使用IP需要使用80端口,此组件可实现一个IP上绑定多个公众平台接口 使用方法 http://(IP)/WeixinMP/(转发的地址Ba ...

  3. C#/ASP.NET MVC微信公众号接口开发之从零开发(四) 微信自定义菜单(附源码)

    C#/ASP.NET MVC微信接口开发文章目录: 1.C#/ASP.NET MVC微信公众号接口开发之从零开发(一) 接入微信公众平台 2.C#/ASP.NET MVC微信公众号接口开发之从零开发( ...

  4. C#/ASP.NET MVC微信公众号接口开发之从零开发(三)回复消息 (附源码)

    C#/ASP.NET MVC微信接口开发文章目录: 1.C#/ASP.NET MVC微信公众号接口开发之从零开发(一) 接入微信公众平台 2.C#/ASP.NET MVC微信公众号接口开发之从零开发( ...

  5. C#/ASP.NET MVC微信公众号接口开发之从零开发(二) 接收微信消息并且解析XML(附源码)

    文章导读: C#微信公众号接口开发之从零开发(一) 接入微信公众平台 微信接入之后,微信通过我们接入的地址进行通信,其中的原理是微信用户发送消息给微信公众账号,微信服务器将消息以xml的形式发送到我们 ...

  6. C#微信公众号接口开发,灵活利用网页授权、带参数二维码、模板消息,提升用户体验之完成用户绑定个人微信及验证码获取

    一.前言 当下微信公众号几乎已经是每个公司必备的,但是大部分微信公众账号用户体验都欠佳,特别是涉及到用户绑定等,需要用户进行复杂的操作才可以和网站绑定,或者很多公司直接不绑定,而是每次都让用户填写账号 ...

  7. 微信公众号接口类(PHP版本)

    [项目需求] 通过微信提供的接口,实现微信公众号与后端的应用程序数据交互.消息响应等功能. [项目疑难点] 理解接口工作方式,统一接口API,响应速度.安全性等   [代码举例]   WeixinAp ...

  8. h5开发微信公众号重定向到关注页面没有关注按钮 (微信你个坑)

    搜索微信公众号是这样的 微信公众号重定向到关注页面没有关注按钮 如何微信公众号重定向到关注页面没有关注按钮,请看上篇笔记 无解,微信一直在封这种通过链接跳转到公众号关注页面的方法.只有放个二维码提示长 ...

  9. 如何玩转小程序+公众号?手把手教你JeeWx小程序CMS与公众号关联

    随着微信小程序新功能.新入口的不断更新,小程序的商业价值逐步增强,特别是小程序与公众号的深度融合,已经让小程序成为各行业新的营销渠道.Jeewx平台专注小程序的开发,逐步完善小程序生态圈,通过简单操作 ...

随机推荐

  1. Oracle 正则表达式函数-REGEXP_LIKE 使用例子

    原文在这 戳 REGEXP_LIKE 3个参数 第一个是输入的字符串 第二个是正则表达式 第三个是取值范围: i:大小写不敏感: c:大小写敏感: n:点号 . 不匹配换行符号: m:多行模式: x: ...

  2. c/c++ 指针理解(1)

    指针是一个变量,存放变量的地址

  3. ajax是什么

    1.ajax是什么? ajax: asynchronous javascript and xml: 异步的javascript和xml. ajax是一种用来改善用户体验的技术,其本质是利用浏览器内置的 ...

  4. 夺命雷公狗-----React---1--页面的渲染

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. UICollectionView介绍

    文章原出处未知,如有朋友知道,请告诉我,我会补上. 1.1. Collection View 全家福: UICollectionView, UITableView, NSCollectionView ...

  6. Jquery 处理字符串

    1.去掉空格var txt=$.trim($("txt1").val()); 2.转为数字 txtNum=Number($.trim(txt)) + 1; var thisEle ...

  7. TBB 学习笔记

    #include <tbb/task_scheduler_init.h> #include <tbb/blocked_range.h> #include <tbb/par ...

  8. Chrom 浏览器一些命令

    https://webkit.org/build-tools/  开发环境搭建 开源:http://www.17ky.net/kyxm/4_0_3_2_0_0/ http://www.chromium ...

  9. [问题2014A07] 解答

    [问题2014A07]  解答 我们分三步进行证明. \(1^\circ\) 先证 \(\alpha_1,\alpha_2\) 线性无关. 用反证法, 设 \(\alpha_1,\alpha_2\) ...

  10. 安装DotNetCore.1.0.0-VS2015Tools.Preview2失败解决方案

    1.把安装文件放入非系统盘 2.命令行带参数运行: DotNetCore.1.0.0-VS2015Tools.Preview2.0.1.exe SKIP_VSU_CHECK=1 或 DotNetCor ...