您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

微信扫码支付的Asp.Net MVC开发

2026/1/10 7:38:37发布13次查看
这次给大家带来微信扫码支付的asp.net mvc开发,微信扫码支付asp.net mvc开发的注意事项有哪些,下面就是实战案例,一起来看一下。
这里的扫码支付指的是pc网站上面使用微信支付,也就是官方的模式二,网站是asp.net mvc,整理如下。(demo在最下方)
一、准备工作
使用的微信api中的统一下单方法,关键的参数是‘公众账号id(appid)’,‘商户号(mch_id)’和’商户支付密钥(key)‘,所以首先要有一个审核过的公众号,并开通支付功能,然后申请商户,通过审核后得到商户号,也就是商户平台的登录名。商户支付密钥是用来签名的,确保url不被篡改。进入商户平台后在api安全中设置,是一个32位的字符串。
有这三个参数后,还有一点要注意的是交易起始时间和交易结束时间的间隔应该在五分钟以上2小时以内。不然获取支付url的时候回报错。
二、生成支付二维码
有了上面的参数,接下来就是下载sdk: .net sdk及示例 。
可惜官方的这个示例一开始并不能运行正确。把相关dll引用mvc目录下。并创建一个wxpayapi文件夹把相关类复制过来。
然后将wxpayconfig中的相关参数设置成自己的参数,再修改getpayurl方法,
public string getpayurl(order order,string ip)         {            if (order == null)             {                throw new argumentnullexception(order);             }                        var product = order.orderitems.first();             wxpaydata data = new wxpaydata();             data.setvalue(appid, wxpayconfig.appid);             data.setvalue(mch_id, wxpayconfig.mchid);            // data.setvalue(device_info, iphone4s);             data.setvalue(nonce_str, wxpayapi.generatenoncestr());             data.setvalue(body, product.attributedescription);//商品描述             data.setvalue(detail, product.attributedescription);//商品描述             data.setvalue(attach, 北京分店);//附加数据             data.setvalue(out_trade_no, order.tradenumber);//随机字符串           // data.setvalue(total_fee, convert.toint32(order.ordertotal * 100));//总金额             data.setvalue(total_fee, 1);//总金额             data.setvalue(spbill_create_ip,ip);//总金额             data.setvalue(time_start, datetime.now.tostring(yyyymmddhhmmss));//交易起始时间             data.setvalue(time_expire, datetime.now.addminutes(30).tostring(yyyymmddhhmmss));//交易结束时间             data.setvalue(goods_tag, 智能婴儿床);//商品标记             data.setvalue(notify_url, http://www.xxxx.com/checkout/resultnotify);//通知地址             data.setvalue(trade_type, native);//交易类型             data.setvalue(product_id, product.productid);//商品id               data.setvalue(sign, data.makesign());//签名             logger.info(获得签名 + data.getvalue(sign));             wxpaydata result = wxpayapi.unifiedorder(data);//调用统一下单接口            logger.info(result.tojson());            string url = result.getvalue(code_url).tostring();//获得统一下单接口返回的二维码链接             logger.info(pay url: + url);            return url;         }
tradenumber是调用wxpayapi.generateouttradeno() 方法生成的,notify_url是用户支付之后微信通知的地址。金额的单位是分,只能传int型或string型,decimal需要转换一下。获取url成功后,在负责支付的控制器中创建一个payment方法。用于显示二维码:
actionresult payment((  argumentexception( order = _orderservice.getorderbyguid( user ==  url2 ==  +=
这里只是返回了一个url,在页面上:
<img src="@viewbag.qrcode" class="qrcode" />
后台用的qrcodeencoder生成二维码。
public fileresult makeqrcode(string data)         {            if (string.isnullorempty(data))                  throw new argumentexception(data);            //初始化二维码生成工具             qrcodeencoder qrcodeencoder = new qrcodeencoder();             qrcodeencoder.qrcodeencodemode = qrcodeencoder.encode_mode.byte;             qrcodeencoder.qrcodeerrorcorrect = qrcodeencoder.error_correction.m;             qrcodeencoder.qrcodeversion = 0;             qrcodeencoder.qrcodescale = 4;            //将字符串生成二维码图片             bitmap image = qrcodeencoder.encode(data, encoding.default);            //保存为png到内存流               memorystream ms = new memorystream();             image.save(ms, imageformat.jpeg);            return file(ms.toarray(), image/jpeg);         }
成功之后得到支付页面:
扫码后跳出支付页面:
三、回调
用户支付之后,微信会给之前预留的接口(接口不能带参数)发消息, 网站在收到消息后进行验证和确认,确定之后再给微信发一个消息。详细参数和文档请看官方api
这里还是把demo中的方法稍作改动放到了控制器里面:
public actionresult resultnotify()         {            //接收从微信后台post过来的数据             stream s = request.inputstream;            int count = 0;            byte[] buffer = new byte[1024];             stringbuilder builder = new stringbuilder();            while ((count = s.read(buffer, 0, 1024)) > 0)             {                 builder.append(encoding.utf8.getstring(buffer, 0, count));             }             s.flush();             s.close();             s.dispose();             logger.info(this.gettype()+ receive data from wechat :  + builder);            //转换数据格式并验证签名             wxpaydata data = new wxpaydata();            try             {                 data.fromxml(builder.tostring());             }            catch (wxpayexception ex)             {                //若签名错误,则立即返回结果给微信支付后台                 wxpaydata res = new wxpaydata();                 res.setvalue(return_code, fail);                 res.setvalue(return_msg, ex.message);                 log.error(this.gettype().tostring(), sign check error :  + res.toxml());                 response.write(res.toxml());                 response.end();             }             logger.info(this.gettype()+ check sign success);             processnotify(data);            return view();         }        public void processnotify(wxpaydata data)         {             wxpaydata notifydata = data;            //检查支付结果中transaction_id是否存在             if (!notifydata.isset(transaction_id))             {                //若transaction_id不存在,则立即返回结果给微信支付后台                 wxpaydata res = new wxpaydata();                 res.setvalue(return_code, fail);                 res.setvalue(return_msg, 支付结果中微信订单号不存在);                 logger.error(this.gettype()+the pay result is error :  + res.toxml());                 response.write(res.toxml());                 response.end();             }            string transaction_id = notifydata.getvalue(transaction_id).tostring();            //查询订单,判断订单真实性             if (!queryorder(transaction_id))             {                //若订单查询失败,则立即返回结果给微信支付后台                 wxpaydata res = new wxpaydata();                 res.setvalue(return_code, fail);                 res.setvalue(return_msg, 订单查询失败);                 logger.error(this.gettype()+order query failure :  + res.toxml());                 response.write(res.toxml());                 response.end();             }            //查询订单成功             else             {                 wxpaydata res = new wxpaydata();                 res.setvalue(return_code, success);                 res.setvalue(return_msg, ok);                 logger.info(this.gettype()+order query success :  + res.toxml());                setpaymentresult(data.getvalue(out_trade_no).tostring(), paymentstatus.paid);                 response.write(res.toxml());                 response.end();             }         }
收到确认后,我们要更新订单的状态:
public void setpaymentresult(string tradeno, paymentstatus status)         {             logger.info(订单号:+tradeno);            var order = _orderservice.getorderbytradenumber(tradeno);            if (order != null)             {                 order.paymentstatus = status;                if (status == paymentstatus.paid)                 {                     order.paiddate = datetime.now;                 }                 _orderservice.updateorder(order);                 logger.info(订单:+tradeno+成功更新状态为+status);             }         }
然后在页面上检测订单的状态,确定成功后,跳转页面。
在商户平台的后台,我们可以查询到:
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
微信支付的退款功能开发
h5的视频播放库video.js详解
微信硬件h5开发之控制灯光
js里特别好用的轻量级日期插件
以上就是微信扫码支付的asp.net mvc开发的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product