Go回调签名校验

client 是shell脚本

#!/bin/bash

url="http://localhost:8088/api"
secret_key="7!18!&mahrLxWADnJZDNMtN0"
data="your_data"

signature=$(echo -n "$data" | openssl dgst -sha256 -hmac "$secret_key" -binary | base64)

response=$(curl -X POST -H "Signature: $signature" -d "$data" "$url")
echo "Response: $response"

Go服务端

package main

import (
	"crypto/hmac"
	"crypto/sha256"
	"encoding/base64"
	"fmt"
	"io/ioutil"
	"log"
	"net/http"
)

const secretKey = "7!18!&mahrLxWADnJZDNMtN0"

func generateSignature(data, secretKey string) string {
	hmacSha256 := hmac.New(sha256.New, []byte(secretKey))
	hmacSha256.Write([]byte(data))
	expectedSig := base64.StdEncoding.EncodeToString(hmacSha256.Sum(nil))
	return expectedSig
}

func verifySignature(signature, data, secretKey string) bool {
	expectedSig := generateSignature(data, secretKey)
	return signature == expectedSig
}

func apiHandler(w http.ResponseWriter, r *http.Request) {
	signature := r.Header.Get("Signature")

	body, err := ioutil.ReadAll(r.Body)
	fmt.Println("body", body)
	fmt.Println("body str", string(body))
	if err != nil {
		http.Error(w, "Failed to read request body", http.StatusInternalServerError)
		return
	}

	data := string(body)
	if verifySignature(signature, data, secretKey) {
		fmt.Fprintf(w, "Signature verification passed")
	} else {
		fmt.Fprintf(w, "Signature verification failed")
	}
}

func main() {
	http.HandleFunc("/api", apiHandler)

	log.Fatal(http.ListenAndServe(":8088", nil))
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值