微信小程序支付(java后端)

本文介绍了微信小程序支付的实现过程,首先在小程序端下单并获取Openid,然后调用微信支付统一下单API获取prepay_id。接着,对支付数据进行签名处理,涉及后台业务逻辑、工具类和参数封装。提供了部分源码和思路分析。
摘要由CSDN通过智能技术生成

第一步 

进入小程序,下单,请求下单支付,调用小程序登录API来获取Openid(https://mp.weixin.qq.com/debug/w ... .html#wxloginobject),生成商户订单,这些都是在小程序端完成的业务。 

小程序端代码 

 

// pages/pay/pay.js 
var app = getApp(); 
Page({ 
    data: {}, 
    onLoad: function (options) { 
        // 页面初始化 options为页面跳转所带来的参数 
    }, 
    /* 微信支付 */ 
    wxpay: function () { 
        var that = this 
        //登陆获取code 
        wx.login({ 
            success: function (res) { 
                console.log(res.code) 
                //获取openid 
                that.getOpenId(res.code) 
            } 
        }); 
    }, 
    getOpenId: function (code) { 
        var that = this; 
        wx.request({ 
            url: "https://api.weixin.qq.com/sns/jscode2session?appid=wxa142513e524e496c&secret=5d6a7d86048884e7c60f84f7aa85253c&js_code=" + code + "&grant_type=authorization_code", 
            data: {}, 
            method: 'GET', 
            success: function (res) { 
                console.log('返回openId') 
                console.log(res.data) 
                that.generateOrder(res.data.openid) 
            }, 
            fail: function () { 
                // fail 
            }, 
            complete: function () { 
                // complete 
            } 
        }) 
    }, 
    /**生成商户订单 */ 
    generateOrder: function (openid) { 
        var that = this 
        //统一支付 
        wx.request({ 
            url: 'http://localhost:8070/RMS/pay_pay.action', 
            method: 'GET', 
            data: { 
                total_fee: '5', 
                body: '支付测试', 
                attach:'真假酒水' 
            }, 
            success: function (res) { 
                console.log(res) 
                var pay = res.data 
                //发起支付 
                var timeStamp = pay[0].timeStamp; 
                console.log("timeStamp:"+timeStamp) 
                var packages = pay[0].package; 
                console.log("package:"+packages) 
                var paySign = pay[0].paySign; 
                console.log("paySign:"+paySign) 
                var nonceStr = pay[0].nonceStr; 
                 console.log("nonceStr:"+nonceStr) 
                var param = { "timeStamp": timeStamp, "package": packages, "paySign": paySign, "signType": "MD5", "nonceStr": nonceStr }; 
                that.pay(param) 
            }, 
        }) 
    }, 
    /* 支付   */ 
    pay: function (param) { 
        console.log("支付") 
        console.log(param) 
        wx.requestPayment({ 
            timeStamp: param.timeStamp, 
            nonceStr: param.nonceStr, 
            package: param.package, 
            signType: param.signType, 
            paySign: param.paySign, 
            success: function (res) { 
                // success 
                console.log("支付") 
                console.log(res) 
                wx.navigateBack({ 
                    delta: 1, // 回退前 delta(默认为1) 页面 
                    success: function (res) { 
                        wx.showToast({ 
                            title: '支付成功', 
                            icon: 'success', 
                            duration: 2000 
                        }) 
                    }, 
                    fail: function () { 
                        // fail 
                    }, 
                    complete: function () { 
                        // complete 
                    } 
                }) 
            }, 
            fail: function (res) { 
                // fail 
                console.log("支付失败") 
                console.log(res) 
            }, 
            complete: function () { 
                // complete 
                console.log("pay complete") 
            } 
        }) 
    } 
}) 

第二步 
调用支付统一下单API来获取prepay_id,并将小程序调起支付数据需要签名的字段appId,timeStamp,nonceStr,package再次签名(https://pay.weixin.qq.com/wiki/d ... ter=7_7&index=3) 

后台代码 

 

package cn.it.shop.action; 
import java.io.ByteArrayInputStream; 
import java.io.InputStream; 
import java.io.UnsupportedEncodingException; 
import java.text.SimpleDateFormat; 
import java.util.Date; 
import java.util.HashMap; 
import java.util.List; 
import java.util.Map; 
import org.dom4j.Document; 
import org.dom4j.DocumentException; 
import org.dom4j.Element; 
import org.dom4j.io.SAXReader; 
impo
评论 31
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

未名胡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值