个人小程序实现微信支付

其实个人小程序是没办法直接调用微信支付的,但是可以间接的去调用,就是通过第三方的服务.

如:https://www.payjx.cn/
在这里插入图片描述

通过调用它得接口,返回一个带支付二维码得结果,这个二维码被微信扫码支付后,通过开发者留得通知地址回调给开发者.
在这里插入图片描述

就需要用户先进入开发者的网站,网站中展示二维码进行扫描付款.

那又会有一个问题,怎么知道是谁支付了?

我的解决办法是先扫码登录

  1. 后端通过一些算法生成一个字符串,保存在redis中,并且设置过期时间,在使用它生成二维码,最后和cookie怼到网页.

  2. 网页通过ajax带上cookie时不时得请求后端判断是否登录了没有.

  3. 小程序中扫描后传递二维码信息、临时登录凭证code和基本信息,这里的code是必须传给后端的,后端要换取openid,来区别用户,但是基本信息看自己,微信提供了根据openid获取用户信息的接口,但是这貌似不支持个人,所以,后端用到用户信息时,还得传,(妈蛋的麻烦,小程序还必须通过点击button后才可以)

  4. 后端获取openid等后,保存到数据库.并设置登录状态.

  5. 此时网页就知道是谁登录的了.在通过调用payjx的支付接口,为这个用户生成一个支付二维码.在attach中附加上用户信息,回调时候取出.

通常都有过期处理,所以,在二维码过期后,别忘了删除二维码哦.

其实还有种办法.小程序通过传递临时登录凭证code后,后端获取到openid,生成支付二维码返回给小程序,小程序保存他到相册,提示用户你去扫一扫相册中的二维码完成支付.但是我没去尝试.

### 如何在云开发的小程序实现微信支付 #### 开通条件与准备事项 为了能够在基于云开发的小程序中集成微信支付功能,需满足特定的前提条件。值得注意的是,微信支付并不支持个人开发者账号下的小程序;仅限于已绑定合法企业身份认证的企业主体所创建的小程序才能申请并使用此服务[^2]。 #### 技术选型与环境搭建 对于希望利用云端能力简化支付流程处理的应用来说,采用`uniapp`框架配合`uniCloud`作为后端服务平台是一个不错的选择。通过这种方式不仅可以快速构建跨平台移动应用,还能借助官方提供的`unipay`插件轻松完成支付逻辑的编写与部署工作[^1]。 #### 支付接口调用过程概述 当用户确认订单信息后触发前端页面发起预支付请求至服务器端API接口,在这里会组装必要的参数并通过HTTPS协议发送给腾讯侧网关进行验证以及获取交易流水号等必要数据返回给客户端用于后续操作展示。整个过程中涉及到敏感信息安全传输问题,则严格按照官方文档指引设置签名算法确保通信链路安全可靠。 ```javascript // 示例:初始化统一下单对象配置项 const payParams = { "body": "商品描述", "out_trade_no": new Date().getTime(), // 商户订单号 "total_fee": 1, // 订单金额 单位分 "spbill_create_ip": 'CLIENT_IP', // 终端IP "notify_url": 'https://yourdomain.com/pay/notify', "trade_type": "JSAPI", // 交易类型 "openid": 'USER_OPENID' // 用户标识 }; ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值