支付宝沙箱对接(GO语言)

支付宝沙箱对接

  • 1.1 官网
  • 1.2 秘钥生成(系统默认)
  • 1.3 秘钥生成(软件生成)
  • 1.4 golan 安装 SDK
  • 1.5 GoLand 代码
    • 1.6 前端代码

1.1 官网


沙箱官网:

https://open.alipay.com/develop/sandbox/app

秘钥用具下载:

https://opendocs.alipay.com/common/02kipk?pathHash=0d20b438

image-20231027214014588

1.2 秘钥生成(系统默认)

image-20231027214829962

1.3 秘钥生成(软件生成)


  • 点击生成密钥

image-20231027214209352

  • 生成成功

image-20231027214306694

  • 自定义密钥

image-20231027214456066****

  • 复制粘贴之前生成的公钥并点击保存

image-20231027214551413

  • 继续点击确认

image-20231027214642751

1.4 golan 安装 SDK


go get -u github.com/smartwalle/alipay/v3

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

1.5 GoLand 代码


  • app
    • utils
      • abfPay.go
package utilsimport ("fmt""github.com/smartwalle/alipay/v3""net/url"
)func ZfbPay(orderID string, totalPrice string) string {appID := "9021000131612134" // 你的appIDprivateKey := "" // 你的私钥aliPublicKey := "" // 支付宝的公钥var client, err = alipay.New(appID, privateKey, false)if err != nil {panic(err)}err = client.LoadAliPayPublicKey(aliPublicKey)if err != nil {panic(err)}//var p = alipay.TradeWapPay{}var p = alipay.TradePagePay{}p.NotifyURL = "http://192.168.137.188:5173/#/pages/pay-success/pay-success" //支付宝回调p.ReturnURL = "http://192.168.137.188:5173/#/pages/pay-success/pay-success" //支付后调转页面p.Subject = "云尚校园-订单支付"                                                     //标题p.OutTradeNo = orderID                                                      //传递一个唯一单号p.TotalAmount = totalPrice                                                  //金额//p.ProductCode = "QUICK_WAP_WAY"p.ProductCode = "FAST_INSTANT_TRADE_PAY" //网页支付var url2 *url.URLurl2, err = client.TradePagePay(p)if err != nil {fmt.Println(err)}var payURL = url2.String()println(payURL)return payURL
}
  • app
    • dto
      • Pay.go
package dtotype ShopPay struct {ByCode          string `json:"byCode"`ShopID          string `json:"id"`OrderTips       string `json:"tips"`OrderTotalPrice string `json:"totalPrice"`OrderStatus     string `json:"status"`OrderID         string `json:"order_id"`
}
  • app
    • model
      • Pay.go
package modelsimport "gorm.io/gorm"//
//  ShopPay
//  @Description: 生成订单号
//type ShopPay struct {gorm.ModelByCode          string `gorm:"type:varchar(100)"`OrderId         string `gorm:"type:varchar(100); unique;not null"` // 订单IDOrderStatus     string `gorm:"type:varchar(100); not null"`        // 订单状态OrderTips       string `gorm:"type:varchar(200); not null"`        // 订单备注OrderTotalPrice string `gorm:"type:varchar(100); not null"`ShopID          string `gorm:"type:varchar(100); not null"`
}
  • app
    • common
      • databaseMySQL.go
package commonimport ("github.com/spf13/viper""gorm.io/driver/mysql""gorm.io/gorm"
)var DB *gorm.DBfunc InitDB() *gorm.DB {host := viper.GetString("datasource.host")port := viper.GetString("datasource.port")database := viper.GetString("datasource.database")username := viper.GetString("datasource.username")password := viper.GetString("datasource.password")charset := viper.GetString("datasource.charset")db, err := gorm.Open(mysql.Open(username+`:`+password+`@tcp(`+host+`:`+port+`)/`+database+`?charset=`+charset+`&parseTime=true&loc=Local`),&gorm.Config{})if err != nil {panic("failed to connect database, err: " + err.Error())}db.AutoMigrate(&model.ShopPay{})DB = dbreturn db
}func GetDB() *gorm.DB {return DB
}
  • app
    • config
      • application.yml
server:port: 9999datasource:diverName: mysqlhost: 127.0.0.1port: 3306database: go-appusername: rootpassword: 123456charset: utf8
  • app
    • controller
      • PayController.go
package controllerimport "github.com/gin-gonic/gin"type PayController interface {AddShopPay(ctx *gin.Context)OrderPay(ctx *gin.Context)
}
  • app
    • controller
      • pay
        • pay.go
package payimport ("github.com/gin-gonic/gin""go-app/common""go-app/controller""go-app/dto"model "go-app/models""go-app/response""go-app/utils""gorm.io/gorm""strconv"
)type PayFun interface {controller.PayController
}type payDB struct {DB *gorm.DB
}func PayFunction() PayFun {db := common.GetDB()db.AutoMigrate(model.User{})return payDB{DB: db}
}func (db payDB) AddShopPay(ctx *gin.Context) {getPayData := dto.ShopPay{}ctx.BindJSON(&getPayData)getPayData.OrderStatus = "2"getPayData.OrderID = strconv.FormatInt(utils.GetSnowflakeId(), 10)if getPayData.ByCode != "" {db.DB.Debug().Create(&getPayData)}response.Success(ctx, gin.H{"data": getPayData}, "success")
}
func (db payDB) OrderPay(ctx *gin.Context) {order := model.ShopPay{}id, _ := strconv.Atoi(ctx.Params.ByName("orderID"))db.DB.Debug().Where("order_id", id).First(&order)pay := utils.ZfbPay(order.OrderId, order.OrderTotalPrice)response.Success(ctx, gin.H{"data": pay}, "success")
}
  • app
    • router.go
package mainimport ("github.com/gin-gonic/gin"shopController "go-app/controller/shop"
)
func CollectRoute(r *gin.Engine) *gin.Engine {// 支付页面payGroup := r.Group("api/pay/")payFun := payController.PayFunction()payGroup.POST("/AddShopPay/", payFun.AddShopPay)payGroup.POST("/orderPay/:orderID", payFun.OrderPay)return r
}
  • app
    • main.go
package mainimport ("github.com/gin-contrib/cors""github.com/gin-gonic/gin""github.com/spf13/viper""go-app/common""os"
)func main() {InitConfig()common.InitDB()r := gin.Default()config := cors.DefaultConfig()config.AllowAllOrigins = true                            //允许所有域名config.AllowMethods = []string{"GET", "POST", "OPTIONS"} //允许请求的方法config.AllowHeaders = []string{"token", "tus-resumable", "upload-length", "upload-metadata", "cache-control", "x-requested-with", "*"}r.Use(cors.New(config))// 定义路由和处理函数r = CollectRoute(r)port := viper.GetString("server.port")if port != "" {panic(r.Run(":" + port))}r.Run()
}func InitConfig() {workDir, _ := os.Getwd()viper.SetConfigName("application")viper.SetConfigType("yml")viper.AddConfigPath(workDir + "/config")err := viper.ReadInConfig()if err != nil {panic(err)}
}

1.6 前端代码


<template><view><!-- 自定义导航栏 --><view class="box-bg" style="font-size: 36rpx;"><!-- <uni-nav-bar shadow left-icon="left" right-icon="cart" title="购物车" /> --><uni-nav-bar shadow fixed="true" left-icon="left" right-text="关闭" title="支付订单" statusBar="true"@clickLeft="backCommitShop" @clickRight="colsePay" /></view><!-- 支付选择模块 --><view class="pay-main"><radio-group name=""><label><view class="pay-item"><view v-for="(item,index) in payItemIamges.data" :key="index"><view class="pay-connect"><img class="pay-item-image" :src="item.imageUrl" alt=""><view class="pay-item-text"><view class="pay-item-text-top">{{item.nameFather}}</view><view class="pay-item-text-foot">{{item.name}}</view></view><label class="pay-radio"><radio :checked="isChecked" color="#F33" /><text></text></label></view></view></view></label></radio-group></view><!-- 底部去支付模块 --><view class="foot-pay"><view class="total-pay"><view class="total">合计:</view><view class="total">¥{{payMoney}}</view></view><view class="go-pay" @tap="goPay">去支付</view></view></view>
</template><script setup>import {onLoad,} from '@dcloudio/uni-app';import {reactive,ref} from "vue"import {orderPay} from "@/api/shop/pay.js"onLoad((e) => {// 获取价格payMoney.value = e.price;// 获取订单号orderID.value = e.orderID;})// 选择支付方式const isChecked = ref(false);const payItemIamges = reactive({data: [{nameFather: "微信支付",name: "推荐微信用户使用",imageUrl: "http://s1jh1gxy3.hn-bkt.clouddn.com/shopCartCommit/wPay.png"},{nameFather: "支付宝支付",name: "推荐支付宝用户使用",imageUrl: "http://s1jh1gxy3.hn-bkt.clouddn.com/shopCartCommit/zPay.png"}]})// 获取金额const payMoney = ref(0);// 订单ID const orderID = ref(0);// 去支付const goPay = () => {uni.navigateTo({url:"@/pages/pay-success/pay-success"})orderPay(orderID.value).then(res=>{//#ifdef APP-PLUS  plus.runtime.openURL(res.data.data, function(res){console.log(res);})//#endif // #ifdef H5window.open(res.data.data)// #endif})}const backCommitShop = () => {uni.navigateBack({delta: 1})}const colsePay = () => {uni.navigateTo({url: "../shop-commit/shop-commit"})}
</script><style lang="less" scoped>// 底部样式.foot-pay {border-top: 2rpx solid #fcc;line-height: 100rpx;height: 100rpx;width: 100%;position: fixed;bottom: 0;left: 0;display: flex;justify-content: space-between;align-items: center;.total-pay {display: flex;flex: 1;background-color: black;color: white;padding-left: 120rpx;.total {padding: 0rpx 7rpx;}}.go-pay {padding: 0rpx 100rpx;color: white;background-color: #49BDFB;}}// 支付样式.pay-main {margin-top: 15rpx;.pay-item {.pay-connect {display: flex;justify-content: space-between;padding: 20rpx 30rpx;border-bottom: 8rpx solid #F5F5F5;.pay-item-image {width: 100rpx;height: 100rpx;}.pay-item-text {flex: 1;padding-left: 80rpx;.pay-item-text-top {font-weight: bold;}.pay-item-text-foot {color: #636263;}}.pay-radio {padding-top: 20rpx;}}}}.box-bg {background-color: #F5F5F5;padding: 0 5px 0;}::v-deep uni-text.uni-nav-bar-text.uni-ellipsis-1 {font-size: 34rpx;font-weight: bolder;}::v-deep uni-text.uni-nav-bar-right-text {font-size: 32rpx;font-weight: bolder;}pay-item-text {flex: 1;padding-left: 80rpx;.pay-item-text-top {font-weight: bold;}.pay-item-text-foot {color: #636263;}}.pay-radio {padding-top: 20rpx;}}}}.box-bg {background-color: #F5F5F5;padding: 0 5px 0;}::v-deep uni-text.uni-nav-bar-text.uni-ellipsis-1 {font-size: 34rpx;font-weight: bolder;}::v-deep uni-text.uni-nav-bar-right-text {font-size: 32rpx;font-weight: bolder;}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/41719.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

序列化、反序列化

java 提供了一种对象序列化的机制&#xff0c;该机制中&#xff0c;一个对象可以被表示为一个字节序列&#xff0c;该字节序列包括该对象的数据、有关对象的类型的信息和存储在对象中数据的类型。 将序列化对象写入文件之后&#xff0c;可以从文件中读取出来&#xff0c;并且对…

Java并发编程-ThreadLocal深入解读及案例实战

文章目录 概述原理使用场景示例最佳实践内存泄漏风险阿里开源组件TransmittableThreadLocal原理和机制使用场景如何使用注意事项ThreadLocal在分布式存储系统edits_log案例中的实践1. 为什么使用`ThreadLocal`?2. 实践案例2.1 缓存日志操作2.2 线程局部的编辑日志状态3. 注意事…

在 Spring 中编写单元测试

单元测试是软件开发过程中不可或缺的一部分&#xff0c;它能有效地提高代码质量&#xff0c;确保代码功能的正确性。在 Spring 应用中&#xff0c;JUnit 和 Mockito 是常用的单元测试工具&#xff0c;而 Spring Test 提供了丰富的测试支持。本文将介绍如何在 Spring 中使用 JUn…

并行处理百万个文件的解析和追加

处理和解析大量文件&#xff0c;尤其是百万级别的文件&#xff0c;是一个复杂且资源密集的任务。为实现高效并行处理&#xff0c;可以使用Python中的多种并行和并发编程工具&#xff0c;比如multiprocessing、concurrent.futures模块以及分布式计算框架如Dask和Apache Spark。这…

物联网时代5G通信技术分析研究一、引言

一、引言 近几年&#xff0c;移动网络技术跟随互联网的不断发展而改革和进步&#xff0c;给平民大众的生活也带来新的尝试与影响。从2G网络的出现&#xff0c;到逐步被社会民众所了解的3G&#xff0c;再到被熟知的且正在服务于大家的4G网络&#xff0c;移动网络技术的发展速度令…

jQuery Mobile 安装指南

jQuery Mobile 安装指南 jQuery Mobile 是一个基于 jQuery 的移动设备友好的网页开发框架,它允许开发者创建响应式网页和应用程序。本指南将详细介绍如何安装 jQuery Mobile,并确保您的开发环境准备好进行移动网页开发。 1. 环境准备 在开始安装 jQuery Mobile 之前,请确…

Mysql系列-Binlog主从同步

原文链接&#xff1a;https://zhuanlan.zhihu.com/p/669450627 一、主从同步概述 mysql主从同步&#xff0c;即MySQL Replication,可以实现将数据从一台数据库服务器同步到多台数据库服务器。MySQL数据库自带主 从同步功能&#xff0c;经过配置&#xff0c;可以实现基于库、表…

B端设计:任何不顾及用户体验的设计,都是在装样子,花架子

B端设计是指面向企业客户的设计&#xff0c;通常涉及产品、服务或系统的界面和功能设计。与C端设计不同&#xff0c;B端设计更注重实用性和专业性&#xff0c;因为它直接影响企业的效率和利益。 在B端设计中&#xff0c;用户体验同样至关重要。不顾及用户体验的设计只是空洞的表…

数据库之索引(二)

目录 一、如何判断数据库的索引是否生效 二、如何评估索引创建的是否合理 三、索引是否越多越好 四、如何处理数据库索引失效 五、是否所有的字段都适合创建索引 一、如何判断数据库的索引是否生效 可以使用EXPLAIN语句查看索引是否正在使用。 例如&#xff0c;假设已经创…

70.Bug:使用list.sort(Comparator.Comping(User::getCreateTime).reverse())空指针异常

1.出错原因&#xff1a;在xml中没有做字段映射 报错语句复现&#xff1a; List<User> listnew ArrayList<>()&#xff1b; xml中进行查询数据&#xff0c;数据存放在list中........... //排序 list.sort(Comparator.Comping(User::getCreateTime).reverse())&…

经典的layui框架,还有人用吗?令人惋惜。

自从layui官网宣布关闭之后&#xff0c;layui框架的用户飞速下滑&#xff0c;以至于到现在贝格前端工场承接的项目中&#xff0c;鲜有要求使用layui框架的&#xff0c;那么个框架还有人用吗&#xff1f; 一、layui没落是不是jquery惹的祸 layui的没落与jQuery无关。layui框架…

Hi3861 OpenHarmony嵌入式应用入门--UDP Server

本篇使用的是lwip编写udp服务端。需要提前准备好一个PARAM_HOTSPOT_SSID宏定义的热点&#xff0c;并且密码为PARAM_HOTSPOT_PSK。 修改网络参数 在Hi3861开发板上运行上述四个测试程序之前&#xff0c;需要根据你的无线路由、Linux系统IP修改 net_params.h文件的相关代码&…

深入理解 Docker 容器技术

一、引言 在当今的云计算和软件开发领域&#xff0c;Docker 容器技术已经成为了一项不可或缺的工具。它极大地改变了应用程序的部署和运行方式&#xff0c;为开发者和运维人员带来了诸多便利。 二、Docker 容器是什么&#xff1f; Docker 容器是一种轻量级、可移植、自包含的…

起底:Three.js和Cesium.js,二者异同点,好比全科和专科.

Three.js和Cesium.js是两个常用的webGL引擎&#xff0c;很多小伙伴容易把它们搞混淆了&#xff0c;今天威斯数据来详细介绍一下&#xff0c;他们的起源、不同点和共同点&#xff0c;阅读后你就发现二者就像全科医院和专科医院的关系&#xff0c;很好识别。 一、二者的起源 Th…

性能测试相关理解---性能测试流程(二)

六、性能测试流程&#xff08;如何做性能测试&#xff1f;) 根据学习全栈测试博主的课程做的笔记 1、前期准备– 项目初期就开始&#xff0c;业务需求评审时尽量参与,对业务更深刻的认识&#xff08;确定哪些是核心业务、哪些可能存在并发请求、确定什么地方会出现瓶颈,方便后…

WebOffice在线编微软Offfice,并以二进制流的形式打开Word文档

在日常办公场景中&#xff0c;我们经常会遇到这种场景&#xff1a;我们的合同管理系统的各种Word,excel,ppt数据都是以二进制数组的形式存储在数据库中&#xff0c;如何从数据库中读取二进制数据&#xff0c;以二进制数据作为参数&#xff0c;然后加载到浏览器的Office窗口&…

【无标题】地平线2西之绝境/Horizon Forbidden West™ Complete Edition(更新:V1.3.57)

游戏介绍 与埃洛伊同行&#xff0c;在危险壮美的边疆之地揭开种种未知的神秘威胁。此完整版可完整享受广受好评的《地平线 西之绝境™》内容和额外内容&#xff0c;包括在主线游戏后展开的后续故事“炙炎海岸”。 重返《地平线》中遥远未来的后末日世界&#xff0c;探索远方的土…

Twitter群发消息API接口的功能?如何配置?

Twitter群发消息API接口怎么申请&#xff1f;如何使用API接口&#xff1f; 为了方便企业和开发者有效地与用户互动&#xff0c;Twitter提供了各种API接口&#xff0c;其中Twitter群发消息API接口尤为重要。AokSend将详细介绍Twitter群发消息API接口的功能及其应用场景。 Twit…

html+css+js贪吃蛇游戏

贪吃蛇游戏&#x1f579;四个按钮控制方向&#x1f3ae; 源代码在图片后面 点赞❤️关注&#x1f64f;收藏⭐️ 互粉必回&#x1f64f;&#x1f64f;&#x1f60d;&#x1f60d;&#x1f60d; 源代码&#x1f4df; <!DOCTYPE html> <html lang"en"&…

15jQuery引入

【一】什么是jQuery jQuery是一个轻量级的、兼容多浏览器的JavaScript库。jQuery内部封装了原生的js代码&#xff0c;提高编写效率 【二】jQuery引入配置 1.● 代码复制下来放到自己建的txt中&#xff0c;然后把他移入pycharm项目中重构成js文件(注意&#xff1a;只能在当前…