先定义订单和支付结构,用map模拟存储,实现创建订单、支付及回调通知功能,通过http接口暴露服务,支持基本流程并预留扩展性。

用golang构建一个简单的支付模拟系统,重点是清晰的结构、可扩展性和基本的安全性考虑。虽然不对接真实支付网关,但可以模拟核心流程:创建订单、发起支付、处理回调、查询状态等。下面是一个轻量级实现思路。
定义核心数据结构
先设计关键模型,比如订单和支付记录:
type Order Struct {
ID String `json:”id”`
Amount float64 `json:”amount”`
Status string `json:”status”` // pending, paid, failed
CreatedAt int64 `json:”created_at”`
}
type Payment struct {
OrderID string `json:”order_id”`
PaidAt int64 `json:”paid_at”`
PaymentID string `json:”payment_id”`
}
这些结构可用于内存存储或简单持久化。
实现基础服务逻辑
使用 map 模拟数据库,提供创建订单和更新状态的功能:
立即学习“go语言免费学习笔记(深入)”;
var (
orders = make(map[string]*Order)
payments = make(map[string]*Payment)
)
func CreateOrder(amount float64) *Order {
orderID := fmt.Sprintf(“ord_%d”, time.Now().unix())
order := &Order{
ID: orderID,
Amount: amount,
Status: “pending”,
CreatedAt: time.Now().Unix(),
}
orders[orderID] = order
return order
}
添加支付处理函数,模拟用户完成付款:
func PayOrder(orderID string) (*Payment, Error) {
order, exists := orders[orderID]
if !exists {
return nil, errors.New(“订单不存在”)
}
if order.Status == “paid” {
return nil, errors.New(“订单已支付”)
}
order.Status = “paid”
payment := &Payment{
OrderID: orderID,
PaymentID: fmt.Sprintf(“pay_%d”, time.Now().Unix()),
PaidAt: time.Now().Unix(),
}
payments[payment.PaymentID] = payment
return payment, nil
}
暴露HTTP接口
用 net/http 启动一个服务,支持创建订单和支付操作:
func main() {
http.HandleFunc(“/create”, func(w http.ResponseWriter, r *http.Request) {
amount, _ := strconv.ParseFloat(r.FormValue(“amount”), 64)
order := CreateOrder(amount)
json.NewEncoder(w).Encode(order)
})
http.HandleFunc(“/pay”, func(w http.ResponseWriter, r *http.Request) {
orderID := r.FormValue(“order_id”)
payment, err := PayOrder(orderID)
if err != nil {
http.Error(w, err.Error(), http.StatusbadRequest)
return
}
json.NewEncoder(w).Encode(payment)
})
log.Println(“服务启动在 :8080”)
http.ListenAndServe(“:8080”, nil)
}
这样就可以通过 /create?amount=100 创建订单,再调用 /pay?order_id=ord_xxx 模拟支付。
加入回调通知机制(可选)
模拟异步回调,比如支付完成后通知商户系统:
在 PayOrder 结尾添加:
go func() {
time.Sleep(500 * time.Millisecond) // 模拟网络延迟
resp, _ := http.PostForm(“https://your-merchant.com/callback”,
url.Values{“order_id”: {orderID}, “status”: {“success”}})
if resp != nil {
resp.Body.Close()
}
}()
注意:真实场景需签名验证、重试机制和幂等处理。
基本上就这些。这个系统适合学习或测试使用,代码简洁,逻辑直观。如果需要更复杂功能,比如退款、对账、多支付渠道,可以在基础上分层扩展。不复杂但容易忽略的是状态一致性与并发安全,生产环境建议加锁或使用 sync.Map。


