做微信支付前期准备:

1,服务好开通微信支付。

2,公众账号ID:AppId。

3,公众账号密钥:AppSecret。

4,微信支付密钥:Key。

第一步:获取用户信息并跳转到需要微信支付的页面

    public void ProcessRequest (HttpContext context) {var returnUrl = "http://wap.yueyangdujia.com/ActivityOrder.aspx?id="+context.Request["id"];var state = string.Format("{0}", "111");//自定义参数var url = OAuthApi.GetAuthorizeUrl(AppId, returnUrl, state, OAuthScope.snsapi_userinfo);context.Response.Redirect(url);}

PS:这里的id在我们这里是产品ID。

第二步:在回调页面获取所需的用户数据。(我这里把用户临时数据存储在Session里)

     var code = Request["code"];OAuthAccessTokenResult result;try{result = OAuthApi.GetAccessToken(AppId, AppSecret, code);}catch (Exception ex){Response.Write(ex.Message);return;}Session["OAuthAccessToken"] = result;

如果这里需要使用卡包功能可以调用以下代码(例子为代金券)

public class WeChatCard: CardListItem
{public string price { get; set; }public string Name { get; set; }
}

 var token = CommonApi.GetToken(AppId, AppSecret).access_token;try{CardListItems = CardApi.GetCardList(token, result.openid).card_list;if (CardListItems != null){WeChatCards = new List<WeChatCard>();foreach (var item in CardListItems){var weChatCard = CardApi.CardDetailGet(token, item.card_id);WeChatCards.Add(new WeChatCard(){price = (weChatCard.card.cash.reduce_cost / 100).ToString(),Name = weChatCard.card.cash.base_info.title,code = item.code,card_id = item.card_id});}}}catch (Exception ex){}

卡包代码

第三步:准备好JSAPI验证程序

 public void ProcessRequest (HttpContext context) {string url = context.Request["url"];//这里是当前页面的地址string timeStamp = Senparc.Weixin.MP.TenPayLib.TenPayUtil.GetTimestamp();string nonceStr = Senparc.Weixin.MP.TenPayLib.TenPayUtil.GetNoncestr();string jsTicket = "";if (Base.Core.Container.CacheService.GetItem("wap", "jsTicket") == null){jsTicket= Senparc.Weixin.MP.CommonAPIs.JsApiTicketContainer.TryGetTicket(AppId, AppSecret);Base.Core.Container.CacheService.SetItem("wap", "jsTicket", jsTicket, 7000);}else{jsTicket = Base.Core.Container.CacheService.GetItem("wap", "jsTicket") as string;}string signature = "";Senparc.Weixin.MP.TenPayLib.RequestHandler paySignReqHandler = new Senparc.Weixin.MP.TenPayLib.RequestHandler(null);paySignReqHandler.SetParameter("jsapi_ticket", jsTicket);paySignReqHandler.SetParameter("noncestr", nonceStr);paySignReqHandler.SetParameter("timestamp", timeStamp);paySignReqHandler.SetParameter("url", url);//LOGstring sRawString = "jsapi_ticket=" + jsTicket + "&noncestr=" +nonceStr + "&timestamp=" +timeStamp + "&url=" + url;signature = FormsAuthentication.HashPasswordForStoringInConfigFile(sRawString, "SHA1");var hashtable = new System.Collections.Hashtable{{"appId", AppId},{"timeStamp", timeStamp},{"nonceStr", nonceStr},{"signature", signature}};var js=new JavaScriptSerializer();context.Response.Write(js.Serialize(hashtable));Base.Core.Container.LogService.Error("验证成功");}

JsApi验证程序

因为jsTicket有获取次数限制,最好存入缓存中。

  Base.Core.Container.CacheService.SetItem("wap", "jsTicket", jsTicket, 7000);这段代码是我这里的缓存jsTicket代码。(请自行实现缓存代码)

第四步:在需要支付的页面,也就是第二步的前台页面引入JS,微信JSAPI验证调用等代码。

引入JSAPI

<script type="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>

JSAPI验证

    $(function() {$.ajax({type: 'POST',url: "/WeChat/GetYueyangConfig.ashx",data: { url: '<%=Request.Url.ToString() %>' },dataType: "json",success: function(data) {wx.config({debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。appId: data.appId, // 必填,公众号的唯一标识timestamp: data.timeStamp, // 必填,生成签名的时间戳nonceStr: data.nonceStr, // 必填,生成签名的随机串signature: data.signature, // 必填,签名,见附录1jsApiList: ['chooseWXPay'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
                });wx.ready(function() {// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
});wx.error(function(res) {// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
});}});});

调起支付代码

cardiD和Cardcode都是调用卡卷接口回传的,在第二步那里有调用卡卷代码
            $.ajax({type: 'POST',url: "/WeChat/ActivityPySign.ashx",data: {id: <%=Request["id"]%>,cardiD:cardiD,Cardcode:Cardcode},dataType: "json",success: function(data) {if (data.msg) {alert(data.msg);}wx.chooseWXPay({timestamp: data.timeStamp, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符nonceStr: data.nonceStr, // 支付签名随机串,不长于 32 位package: data.package, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)signType: "MD5", // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'paySign: data.paysign, // 支付签名success: function(res) {//成功之后的处理                                                     location.href = data.backUrl;}});}});

第四步:支付后台代码

 var token=CommonApi.GetToken(AppId, AppSecret);var id = context.Request["id"];var timeStamp = TenPayV3Util.GetTimestamp();var nonceStr = TenPayV3Util.GetNoncestr();var out_trade_no = DateTime.Now.ToString("HHmmss") + TenPayV3Util.BuildRandomStr(28);; //商户系统内部的订单号,32个字符内,可包含字母,其他说明见商户订单号var spbill_create_ip = context.Request.UserHostAddress; //APP和网页支付提交用户端IP,Native支付填调用微信支付API的机器IPvar trade_type = "JSAPI"; //JSAPI,NATIVE,APP,WAPvar resultAccess =context.Session["OAuthAccessTokenYueYang"]  as OAuthAccessTokenResult;var notifyUrl = "http://wap.yueyangdujia.com/ActivtyCallBack.ashx";var cardiD = context.Request["cardiD"];var code = context.Request["Cardcode"];//接收微信支付异步通知回调地址var backUrl = "/ActivtyPaySuccess.aspx";//创建支付应答对象//卡卷
if (CardApi.CardGet(token.access_token, code).errmsg == "ok"){cardPrice = CardApi.CardDetailGet(token.access_token, cardiD).card.cash.reduce_cost/100;}
//创建订单(根据需求自行创建订单)#region 生成订单#endregion//初始化支付
packageReqHandler.Init();//设置package订单参数packageReqHandler.SetParameter("appid", AppId);packageReqHandler.SetParameter("mch_id", MchId);//微信支付分配的商户号packageReqHandler.SetParameter("nonce_str", nonceStr);packageReqHandler.SetParameter("body", body);//商品或支付单简要描述packageReqHandler.SetParameter("out_trade_no", out_trade_no); //商户系统内部的订单号,32个字符内,可包含字母,其他说明见商户订单号packageReqHandler.SetParameter("total_fee",(money*100).ToString());//价格以分为计数单位packageReqHandler.SetParameter("spbill_create_ip", spbill_create_ip);//APP和网页支付提交用户端IP,Native支付填调用微信支付API的机器IPpackageReqHandler.SetParameter("notify_url", notifyUrl);//回调URLpackageReqHandler.SetParameter("trade_type", trade_type);//JSAPI,NATIVE,APP,WAPpackageReqHandler.SetParameter("openid", resultAccess.openid);packageReqHandler.SetParameter("attach",objOrder.Value.OrderCode+"&"+code);//自定义参数我这里是订单号+卡卷CODEvar sign = packageReqHandler.CreateMd5Sign("key", Key);packageReqHandler.SetParameter("sign", sign);var data = packageReqHandler.ParseXML();var result = TenPayV3.Unifiedorder(data);var res = System.Xml.Linq.XDocument.Parse(result);var prepayId = res.Element("xml").Element("prepay_id").Value;timeStamp = TenPayV3Util.GetTimestamp();nonceStr = TenPayV3Util.GetNoncestr();RequestHandler paysignReqHandler = new RequestHandler(null);paysignReqHandler.Init();//设置支付参数paysignReqHandler.SetParameter("appId", AppId);paysignReqHandler.SetParameter("timeStamp", timeStamp);paysignReqHandler.SetParameter("nonceStr", nonceStr);paysignReqHandler.SetParameter("package", string.Format("prepay_id={0}", prepayId));paysignReqHandler.SetParameter("signType", "MD5");var paysign = paysignReqHandler.CreateMd5Sign("key", Key);paysignReqHandler.SetParameter("paysign", paysign);paysignReqHandler.SetParameter("backUrl", backUrl);var js = new JavaScriptSerializer();context.Response.Write(js.Serialize(paysignReqHandler.GetAllParameters()));

backUrl为用户支付完成后,点击微信提供页面右上方完成后的跳转地址。并不是微信支付成功后的回调地址。

第五步:接受微信的回调,来更改内部订单状态。

        ResponseHandler resHandler = new ResponseHandler(null);string return_code = resHandler.GetParameter("return_code");string return_msg = resHandler.GetParameter("return_msg");var data = resHandler.GetParameter("attach");var dataArr=data.Split('&');var code = dataArr[1];var accessToken=CommonApi.GetToken(AppId, AppSecret).access_token;var a = CardApi.CardConsume(accessToken, code);//消耗卡卷
           Base.Core.Container.LogService.Error(a.errmsg);Base.Core.Container.LogService.Error("消耗卡卷");APIClient.OrderService.UpdateOrderStatus(dataArr[0], 2);string xml = string.Format(@"<xml><return_code><![CDATA[{0}]]></return_code><return_msg><![CDATA[{1}]]></return_msg>
</xml>", return_code, return_msg);context.Response.ContentType = "text/xml";context.Response.Write(xml);

最后:使用了博客园上一个哥们开发的SDK。

网站地址: http://weixin.senparc.com/

博客园地址:http://www.cnblogs.com/szw/archive/2013/01/13/senparc-weixin-mp-sdk.html

GitHub地址:https://github.com/JeffreySu/WeiXinMPSDK

转载于:https://www.cnblogs.com/harpz/p/4904177.html

微信开发(一):用JSAPI做微信支付+微信卡包(代金券)相关推荐

  1. 【微信开发第四章】SpringBoot实现微信H5支付

    前言 在进行微信公众号业务开发的时候,微信支付可以说是非常重要的一环.该篇文章每一步都有记录,力争理解的同时各位小伙伴也能够实现功能 文章目录 前言 1.公众号配置 2.微信支付实现代码 总结 1.公 ...

  2. 微信支付免充值代金券接口升级免费开通步骤

    无论是微信支付服务商还是普通商户,在创建代金券或立减折扣时,都希望能够实现免充值,在交易发生时直接抵扣,毕竟充值过程太啰嗦. 但是在微信支付商户平台上开通免充值相关产品(包括微信支付免充值代金券和微信 ...

  3. [ecshop 支付接口 开发调试] ecshop 需要做一些支付接口,和接口升级,经常需要支付返回

    [ecshop 支付接口 开发调试] ecshop 需要做一些支付接口,和接口升级,经常需要支付返回 1.经验1 直接建立一个支付页面 /** * ecshop 支付接口开发 测试 * ======= ...

  4. 微信小程序活动怎么做_分享微信小程序开发哪些营销活动

    ​我们在做小程序活动的时候,大部分我们都活策划以时间为理由做活动,用户比较容易获得认同.在传统商业活动中用户已经养成了习惯,以为这样的时间就应该有活动,所以,即便活动设计得不是很精彩,用户也会愿意来参 ...

  5. java web 分享功能实现_微信开发(一)基于Wx-java的微信分享功能

    最近在做微信服务号开发,简单总结一下,便于自己学习积累和分享给大家: 环境介绍: Spring+ Spring MVC +Mybatis 开发语言: JAVA 微信公众平台的开发中,微信只公布了一个基 ...

  6. java初始化微信分享_微信开发(一)基于Wx-java的微信分享功能

    最近在做微信服务号开发,简单总结一下,便于自己学习积累和分享给大家: 环境介绍: Spring+ Spring MVC +Mybatis 开发语言: JAVA 微信公众平台的开发中,微信只公布了一个基 ...

  7. 企业微信开发,开发者可以自己注册企业微信

    近期有个企业微信对接的需求,限制于正式上线无法使用客户正式企业微信联调测试,尝试自己注册企业微信,居然不需要认证就可以注册成功,并且注册成功之后,可以自行添加"自建应用",包括小程 ...

  8. 微信开发与应用实验一、创建微信公众号

    <软件工程>实训指导书 --创建微信公众号 制作人:陈晓华   qq:78976932   微信号:chen-jeo 开源项目:https://github.com/chenxhjeo,个 ...

  9. 微信公众号答题怎么做_分享微信公众号在线答题系统使用方法

    微信公众号在线答题系统注意事项,微信公众号在线答题系统虽然制作简单,但是有几个地方特别要注意一下,不然会出错的.其一:题库题目的数量,一定要确保题库数 > (每天答题数*活动天数) .其二,微信 ...

最新文章

  1. Zbrush制作手榴弹案例讲解学习教程
  2. C#实现一个用于开机启动其他程序的Windows服务
  3. 咖啡,一种心情的境界
  4. BootStrap学习笔记,优缺点总结
  5. ToString() 会发生装箱吗?
  6. SpringBoot中整合Mail实现发送带附件的邮件
  7. java执行linux命令
  8. 为此计算机上的所有用户安装此加载项,activex 安装给所有计算机用户
  9. Python实现带有阻塞和超时放弃功能的队列结构
  10. python之str与bytes互转
  11. 数组的循环及跌送方式
  12. 建筑智能化资质升级需要的企业工程业绩
  13. Evo使用过程问题汇总
  14. 网络安全技术第四章——身份认证技术(身份认证及方式、身份认证三要素、身份认证协议、KERBEROS协议、SSL协议)
  15. 智慧医院新系统架构设计与建设
  16. 180余件河北武强年画珍品亮相新疆昌吉回族自治州博物馆
  17. 教务系统自动评教_新版正方教务管理系统自动评教脚本
  18. 最新2022年高职大数据国赛任务书详解与模拟练习
  19. android 仿微信demo————注册功能实现(服务端)
  20. Power BI——建模

热门文章

  1. 全卷积神经网路【U-net项目实战】ISBI 挑战数据集图像分割-keras实现
  2. modelandview跳转页面404_Thinkphp制作404跳转页
  3. 网站想要快速收录到底难不难?4个问题快检查
  4. 如何为网站增加索引,促进网站SEO优化?
  5. windows c语言判断是不是nan,C++ 判断浮点数是否为Nan值
  6. mysql 5.6.29编译安装_MySQL-5.6.29源码编译安装记录
  7. commonjs是什么_第一步:面试官让我解释什么是Common.js和ES6模块化
  8. java培训机构_java编程软件培训机构
  9. php onmouse,html在鼠标按钮在元素上按下时触发的事件属性onmousedown
  10. css文本换行_CSS样式更改——文本Content