创建订单
请求地址:http://orderapi.liangtouyang.com/api/orders/pay
请求名 | 类型 | 参考值 | 备注 | |
appid | String | 100010000 | 后台应用中心获取 | |
type | int | 0 | 0:微信支付 1:支付宝支付 | |
out_trade_no | string | Y1234567989 | 用户订单号 | |
money | string | 1.00 | 付款金额,注意必须是标准的金额格式如1.00 1.01 | |
notify_url | string | 可填可不填 不填则用后台应用内设置的为准 | ||
device | int | 1 | 1:电脑 2:手机 填写的类型会利于接口的返回类型 | |
sign | string | 32位的MD5加密字符串 |
|
计算签名
use md5::{Md5, Digest};
use std::collections::BTreeMap;
fn generate_sign(parameters: &BTreeMap<&str, &str>, secret_key: &str) -> String {
// 移除 'sign' 参数
let mut params = parameters.clone();
params.remove("sign");
// 拼接字符串
let param_string: String = params.iter()
.map(|(k, v)| format!("{}={}", k, v))
.collect::<Vec<String>>()
.join("&");
// 在拼接的字符串后面加上密钥
let string_to_sign = format!("{}{}", param_string, secret_key);
// 计算MD5签名
let mut hasher = Md5::new();
hasher.update(string_to_sign.as_bytes());
let result = hasher.finalize();
hex::encode(result)
}
fn main() {
let mut params = BTreeMap::new();
params.insert("appid", "100010000");
params.insert("type", "0");
params.insert("out_trade_no", "Y1234567989");
params.insert("money", "1.00");
params.insert("notify_url", "");
params.insert("device", "1");
let secret_key = "your_secret_key_here";
let sign = generate_sign(¶ms, secret_key);
println!("{}", sign);
}
查询订单
请求地址:http://orderapi.liangtouyang.com/api/orders/query
请求名 | 类型 | 参考值 | 备注 | |
appid | string | 100010000 | 后台应用处获取 | |
out_trade_no | string | Y123456789 | 用户自己订单号 (二选一) | |
trade_no | string | R201400000000000000 | 平台订单号(二选一) |
查询订单 无需sign计算
验证回调签名
use md5::{Md5, Digest};
use std::collections::BTreeMap;
fn verify_callback_signature(data: &BTreeMap<&str, &str>, secret_key: &str) -> bool {
// 提取签名
let signature = match data.get("sign") {
Some(&sig) => sig,
None => return false,
};
let mut params = data.clone();
params.remove("sign");
// 拼接字符串
let param_string: String = params.iter()
.map(|(k, v)| format!("{}={}", k, v))
.collect::<Vec<String>>()
.join("&");
// 在拼接的字符串后面加上密钥
let string_to_sign = format!("{}{}", param_string, secret_key);
// 计算MD5签名
let mut hasher = Md5::new();
hasher.update(string_to_sign.as_bytes());
let result = hasher.finalize();
let computed_signature = hex::encode(result);
// 验证签名
signature.eq_ignore_ascii_case(&computed_signature)
}
fn main() {
let mut data = BTreeMap::new();
data.insert("appid", "100100001");
data.insert("time", "1713760397");
data.insert("amount", "1.100");
data.insert("status", "1");
data.insert("out_trade_no", "y1713760297");
data.insert("trade_no", "R240422123135450090");
data.insert("sign", "a7762b869a349409616ed4cbc5018dae");
let secret_key = "your_secret_key_here";
let is_valid = verify_callback_signature(&data, secret_key);
println!("{}", if is_valid { "签名验证通过" } else { "签名验证失败" });
}
进件地址:两头羊支付