这篇文章主要为大家详细使用c#微信开发说明介绍,很有参考价值和实用性,感兴趣的小伙伴们可以参考一下
不想废话,直接写了!因为是留给自己做随笔的,所以大神们看到别喷……
1.必须有微信公众账号
2.你也可以申请测试微信号,链接给你http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login
然后,建立mvc,你只需要点几下vs就帮你搞定了。这不废话
接着,要创建一个一般处理程序,随便起个名字,测试通过才是重点,抓紧时间……
/// <summary>
/// 验证微信签名
/// </summary>
/// <returns></returns>
/// * 将token、timestamp、nonce三个参数进行字典序排序
/// * 将三个参数字符串拼接成一个字符串进行sha1加密
/// * 开发者获得加密后的字符串可与signature对比,标识该请求来源于微信。
private bool checksignature()
{
var token = "token";
var signature = httpcontext.current.request.querystring["signature"];
var timestamp = httpcontext.current.request.querystring["timestamp"];
var nonce = httpcontext.current.request.querystring["nonce"];
var echostr = httpcontext.current.request.querystring["echostr"];
string[] arrtmp = { token, timestamp, nonce };
array.sort(arrtmp); //字典排序
var tmpstr = string.join("", arrtmp);
tmpstr = formsauthentication.hashpasswordforstoringinconfigfile(tmpstr, "sha1");//加密方式
if (tmpstr.tolower() == signature)
{
return true;
}
return false;
}
这代码相当于是跟微信公众号中【开发】--》【基本配置】里面你所写的token 一个一对一令牌通信握手,只要互相通了,那么你就算是搞定了!
搞定是后话,还有工作没做完,接着写!
怎么配置,这是问题,哎只能用花生壳给测试先,至少要知道玩了半天是不是通的!
看下图:左边花生壳配置-----右边iis网站发布绑定
看到这图,你也明白下一步怎么玩了吧。本地iis配上了域名。这简直屌爆了…………
下面。我们加上代码。设置发送和自动回复测试,看看能不能玩
#region 接收消息
/// <summary>
/// 接收微信发送的xml消息并且解析
/// </summary>
private void receivexml()
{
var requeststream = httpcontext.current.request.inputstream;
var requestbyte = new byte[requeststream.length];
requeststream.read(requestbyte, 0, (int)requeststream.length);
var requeststr = encoding.utf8.getstring(requestbyte);
if (!string.isnullorempty(requeststr))
{
//封装请求类
var requestdocxml = new xmldocument();
requestdocxml.loadxml(requeststr);
var rootelement = requestdocxml.documentelement;
if (rootelement == null) return;
var wxxmlmodel = new wxxmlmodel
{
tousername = rootelement.selectsinglenode("tousername").innertext,
fromusername = rootelement.selectsinglenode("fromusername").innertext,
createtime = rootelement.selectsinglenode("createtime").innertext,
msgtype = rootelement.selectsinglenode("msgtype").innertext
};
switch (wxxmlmodel.msgtype)
{
case "text"://文本
wxxmlmodel.content = rootelement.selectsinglenode("content").innertext;
break;
case "image"://图片
wxxmlmodel.picurl = rootelement.selectsinglenode("picurl").innertext;
break;
case "event"://事件
wxxmlmodel.event = rootelement.selectsinglenode("event").innertext;
if (wxxmlmodel.event != "templatesendjobfinish")//关注类型
{
wxxmlmodel.eventkey = rootelement.selectsinglenode("eventkey").innertext;
}
break;
default:
break;
}
responsexml(wxxmlmodel);//回复消息
}
}
#endregion
#region 回复消息
private void responsexml(wxxmlmodel wxxmlmodel)
{
var qrcodeapi = new qrcodeapi();
var xml = "";
switch (wxxmlmodel.msgtype)
{
case "text"://文本回复
xml = responsemessage.gettext(wxxmlmodel.fromusername, wxxmlmodel.tousername, wxxmlmodel.content);
break;
case "event":
switch (wxxmlmodel.event)
{
case "subscribe":
if (string.isnullorempty(wxxmlmodel.eventkey))
{
xml = responsemessage.gettext(wxxmlmodel.fromusername, wxxmlmodel.tousername, "关注成功");
}
else
{
xml = responsemessage.subscanqrcode(wxxmlmodel.fromusername, wxxmlmodel.tousername, wxxmlmodel.eventkey);//扫描带参数二维码先关注后推送事件
}
break;
case "scan":
xml = responsemessage.scanqrcode(wxxmlmodel.fromusername, wxxmlmodel.tousername, wxxmlmodel.eventkey);//扫描带参数二维码已关注 直接推送事件
break;
}
break;
default://默认回复
break;
}
httpcontext.current.response.write(xml);
httpcontext.current.response.end();
}
#endregion
上面一个发送,一个接收,还是在whapi.ashx处理程序文件里面。我就想说清楚,呵呵!
因为你根公众平台握手成功了,你肯定要发点东西过去试试对吧~~
下图是一个接收方法和一个自动匹配回复文件的关联,别急下面我会上传这个文件!
还缺一个配置,就是vs要设置【调试】----【附加到进程】,只需要把下面【显示所有用户进程】一项打勾,你就能找到w3wp.exe 如果有多个这样的进程,那你还是要确认【用户名】那一列,选中跟你程序池名称一样的就ok,点附加,确定附加!
接下来。好玩了…………………………………………………………
微信扫一扫那个测试公众号,发一条自定义消息,看看有什么回复,上面的繁琐配置,可以加断点调试的,不然搞那么多也没意义是吧,看看发送和接收跟你自己设定的吻合,那就ok了。
以上就是使用c#微信开发说明介绍的详细内容。