.net微信服务号发送红包

本文实例为大家分享了.net微信红包发送代码,供大家参考,具体内容如下

注:需要开通微信支付的服务号!

//跳转微信登录页面
public ActionResult Index()
{
 ViewBag.url = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + {服务号appid} + "&redirect_uri=http%3A%2F%2F" + {微信重定向域名(填写程序域名,例如:www.xxxx.com)} + "%2F"+{程序控制器名,例如:Home}+"%2F"+{程序Action名,例如:RedirectWeChat}+"&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect";
 return View();
}

//获取accesstoken(访问微信接口需要)
public static string accesstoken(string WeChatWxAppId, string WeChatWxAppSecret)
{
 string strJson = HttpRequestUtil.RequestUrl(string.Format("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}", WeChatWxAppId, WeChatWxAppSecret));
 if (strJson.IndexOf("errcode") == -1)
 {
  return GetJsonValue(strJson, "access_token");
 }
 else
 {
  return "";
 }
}
//解析json
public static string GetJsonValue(string jsonStr, string key)
{
 string result = string.Empty;
 if (!string.IsNullOrEmpty(jsonStr))
 {
  key = "\"" + key.Trim('"') + "\"";
  int index = jsonStr.IndexOf(key) + key.Length + 1;
  if (index > key.Length + 1)
  {
   //先截逗号,若是最后一个,截“}”号,取最小值
   int end = jsonStr.IndexOf(',', index);
   if (end == -1)
   {
    end = jsonStr.IndexOf('}', index);
   }
   result = jsonStr.Substring(index, end - index);
   result = result.Trim(new char[] { '"', ' ', '\'' }); //过滤引号或空格
  }
 }
 return result;
}

//请求url
public static string RequestUrl(string url, string method="post")
{
 // 设置参数
 HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;
 CookieContainer cookieContainer = new CookieContainer();
 request.CookieContainer = cookieContainer;
 request.AllowAutoRedirect = true;
 request.Method = method;
 request.ContentType = "text/html";
 request.Headers.Add("charset", "utf-8");
 //发送请求并获取相应回应数据
 HttpWebResponse response = request.GetResponse() as HttpWebResponse;
 //直到request.GetResponse()程序才开始向目标网页发送Post请求
 Stream responseStream = response.GetResponseStream();
 StreamReader sr = new StreamReader(responseStream, Encoding.UTF8);
 //返回结果网页(html)代码
 string content = sr.ReadToEnd();
 return content;
}
//接收微信返回code
//接收微信数据获取用户信息
public ActionResult RedirectWeChat(string code, string state)
{
 if (string.IsNullOrEmpty(code))
 {
  return Content("您拒绝了授权!");
 }
 string access_token = accesstoken(微信AppId, 微信AppSecret);
 string st = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + 微信AppId + "&secret=" + 微信AppSecret + "&code=" + code + "&grant_type=authorization_code";
 string data = RequestUrl(st);
//拿到用户openid
string openid=GetJsonValue(data, "openid");
//获取用户其他信息
 string url = "https://api.weixin.qq.com/cgi-bin/user/info?access_token=" + access_token + "&openid=" + openid + "&lang=zh_CN";
 data = RequestUrl(url);
string subscribe=GetJsonValue(data, "subscribe");
 if (subscribe == "0")
 {
  ///未关注
  return RedirectToAction("");
 }

 return RedirectToAction("");
}

//发送红包Action
public ActionResult HB()
{
 string openid = "";//用户openid
 string url = "https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack";
 string orderNo = 商户号 + DateTime.Now.ToString("yyyymmdd")+"随机10位数字";//商户订单号 组成:mch_id+yyyymmdd+10位一天内不能重复的数字。
 string Code = ""//32为随机字符串; string key="key=" + "";//支付密钥(在商户平台设置32为字符串)
 Dictionary<string, string> data = new Dictionary<string, string>(); data.Add("act_name", "");//活动名称
 data.Add("client_ip", "192.168.1.1");//Ip地址
 data.Add("mch_billno", orderNo);//商户订单号 组成:mch_id+yyyymmdd+10位一天内不能重复的数字。
 data.Add("mch_id", "");//商户号
 data.Add("nonce_str", Code);//随机字符串
 data.Add("re_openid", openid);//用户openid
 data.Add("remark", "");//备注
 data.Add("send_name","");//商户名称
 data.Add("total_amount", "100");//付款金额 单位分
 data.Add("total_num", "1");//红包发放总人数
 data.Add("wishing", "恭喜发财");//红包祝福语
 data.Add("wxappid", );//公众账号appid
 string xml = GetXML(data, key);//签名+拼接xml
 string str=PostWebRequests(url, xml);//微信返回xml err_code=SUCCESS 就是成功
 return View("");
}

//发送红包(MD5签名+拼接XML)
public static string GetXML(Dictionary<string, string> data,string paykey)
{
 string retStr;
 MD5CryptoServiceProvider m5 = new MD5CryptoServiceProvider();

 var data1=from d in data orderby d.Key select d;
 string data2 = "";
 string XML = "<xml>";
 foreach (var item in data1)
 {
  //空值不参与签名
  if (item.Value + "" != "")
  {
   data2 += item.Key +"="+ item.Value + "&";
  }
  XML += "<" + item.Key + ">" + item.Value+""+ "</" + item.Key + ">";
 }

 data2 += paykey;
 //创建md5对象
 byte[] inputBye;
 byte[] outputBye;

 //使用GB2312编码方式把字符串转化为字节数组.
 try
 {
  inputBye = Encoding.UTF8.GetBytes(data2);
 }
 catch
 {
  inputBye = Encoding.GetEncoding("GB2312").GetBytes(data2);
 }
 outputBye = m5.ComputeHash(inputBye);

 retStr = System.BitConverter.ToString(outputBye);
 retStr = retStr.Replace("-", "").ToUpper();
 XML += "<sign>" + retStr + "</sign>";//签名
 XML += "</xml>";
 return XML;
}

//发送红包请求Post方法
public static string PostWebRequests(string postUrl, string menuInfo)
{
 string returnValue = string.Empty;
 try
 {
  Encoding encoding = Encoding.UTF8;
  byte[] bytes = encoding.GetBytes(menuInfo);
  string cert = @"E:\cdcert\apiclient_cert.p12";//支付证书路径
  string password = "1212121";//支付证书密码

  ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(CheckValidationResult);
  X509Certificate cer = new X509Certificate(cert, password, X509KeyStorageFlags.MachineKeySet);
  HttpWebRequest webrequest = (HttpWebRequest)HttpWebRequest.Create(postUrl);
  webrequest.ClientCertificates.Add(cer);
  webrequest.Method = "post";
  webrequest.ContentLength = bytes.Length;
  webrequest.GetRequestStream().Write(bytes, 0, bytes.Length);
  HttpWebResponse webreponse = (HttpWebResponse)webrequest.GetResponse();
  Stream stream = webreponse.GetResponseStream();
  string resp = string.Empty;
  using (StreamReader reader = new StreamReader(stream))
  {
    return reader.ReadToEnd();
  }

 }
 catch (Exception ex)
 {
  return "";
 }
}

以下是微信开发官方相关文档

1. 【微信支付】公众号支付开发者文档
2. 微信开放平台
3.企业号开发者接口文档
4.微信公众平台开发者文档

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

(0)

相关推荐

  • .NET微信公众号 用户分组管理

    本文实例为大家分享了.NET微信用户分组管理代码,供大家参考,具体内容如下 Model层实体类: public class UserList { public string total { get; set; } public string count { get; set; } public userlistopenid data { get; set; } public string next_openid { get; set; } } public class userlistopeni

  • 微信小程序 教程之事件

    系列文章: 微信小程序 教程之WXSS 微信小程序 教程之引用 微信小程序 教程之事件 微信小程序 教程之模板 微信小程序 教程之列表渲染 微信小程序 教程之条件渲染 微信小程序 教程之数据绑定 微信小程序 教程之WXML 什么是事件 事件是视图层到逻辑层的通讯方式. 事件可以将用户的行为反馈到逻辑层进行处理. 事件可以绑定在组件上,当达到触发事件,就会执行逻辑层中对应的事件处理函数. 事件对象可以携带额外信息,如id, dataset, touches. 事件的使用方式 在组件中绑定一个事件处

  • 微信开发 微信授权详解

    最近有机会做到一个微信项目:把其中自己整理的笔记分享给大家,有不足或错误的地方望大家指正! 1关于微信授权这块的流程图,如下 一些代码碎片仅供参考: var myNickname; var myHeadimgurl; var activityId; function saveData() { //$("#divShow").show(); var obj = {}; obj.openId = myOpenId; obj.nickname = myNickname;// 微信昵称 obj

  • 微信小程序 教程之wxapp 视图容器 view

    相关文章: 微信小程序 教程之wxapp视图容器 swiper 微信小程序 教程之wxapp视图容器 scroll-view 微信小程序 教程之wxapp 视图容器 view View 视图容器. 示例: <view class="section"> <view class="section__title">flex-direction: row</view> <view class="flex-wrp"

  • 微信小程序 教程之WXSS

    系列文章: 微信小程序 教程之WXSS 微信小程序 教程之引用 微信小程序 教程之事件 微信小程序 教程之模板 微信小程序 教程之列表渲染 微信小程序 教程之条件渲染 微信小程序 教程之数据绑定 微信小程序 教程之WXML WXSS WXSS(WeiXin Style Sheets)是MINA设计的一套样式语言,用于描述WXML的组件样式. WXSS用来决定WXML的组件应该怎么显示. 为了适应广大的前端开发者,我们的WXSS具有CSS大部分特性. 同时为了更适合开发微信小程序,我们对CSS进行

  • 微信小程序 教程之模块化

    系列文章: 微信小程序 教程之模块化 微信小程序 教程之注册页面 微信小程序 教程之注册程序 文件作用域 在JavaScript文件中声明的变量和函数只在该文件中有效:不同的文件中可以声明相同名字的变量和函数,不会互相影响. 通过全局函数getApp()可以获取全局的应用实例,如果需要全局的数据可以在App()中设置,如: // app.js App({ globalData: 1 }) // a.js // The localValue can only be used in file a.j

  • 微信小程序 教程之小程序配置

    微信小程序--配置 以下就是小编对小程序配置的资料进行的系统的整理,希望能对开发者有帮助. 我们使用app.json文件来对微信小程序进行全局配置,决定页面文件的路径.窗口表现.设置网络超时时间.设置多 tab 等. 以下是一个包含了所有配置选项的简单配置app.json : { "pages": [ "pages/index/index", "pages/logs/index" ], "window": { "na

  • 微信小程序 教程之引用

    系列文章: 微信小程序 教程之WXSS 微信小程序 教程之引用 微信小程序 教程之事件 微信小程序 教程之模板 微信小程序 教程之列表渲染 微信小程序 教程之条件渲染 微信小程序 教程之数据绑定 微信小程序 教程之WXML 引用 WXML提供两种文件引用方式import和include. import import可以在该文件中使用目标文件定义的template,如: 在item.wxml中定义了一个叫item的template: <!-- item.wxml --> <template

  • 微信小程序 教程之注册程序

    系列文章: 微信小程序 教程之模块化 微信小程序 教程之注册页面 微信小程序 教程之注册程序 App() App()函数用来注册一个小程序.接受一个object参数,其指定小程序的生命周期函数等. object参数说明: 属性 类型 描述 触发时机 onLaunch Function 生命周期函数--监听小程序初始化 当小程序初始化完成时,会触发onLaunch(全局只触发一次) onShow Function 生命周期函数--监听小程序显示 当小程序启动,或从后台进入前台显示,会触发onSho

  • 微信小程序 地图定位简单实例

    微信小程序开发地图定位. 微信小程序 刚刚公布没多久,自己学习一下内容,以便以后的开发,想落后别人,这里做了一个简单的小程序示例,大家可以参考下 要求要完成的功能: 1.要完成的要点是城市定位. 2.就是切换城市. 首页我们先参照微信小程序开放的官方文档找到: 在这里我们可以找到"当前位置经纬度" getLocation: function () { var that = this wx.getLocation( { success: function (res) { console.

随机推荐