https://mp.weixin.qq.com/
商户平台: 商户平台
https://pay.weixin.qq.com/index.php/core/home/login
开发手册 api 是:
https://pay.weixin.qq.com/wiki/doc/api/index.html
https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=9_1
生成XML的测试接口: 测试接口
https://pay.weixin.qq.com/wiki/tools/signverify/
32位随机码生成器
1 配置参数, 一个都不能少(这些都是必填的,还有其他选填的参数,也可以随心情填写)
appid 此小程序的唯一标识 例如:wxed9dxxx6d6cxxx9e
body 可以写商品描述 例如:我是商品描述,用户买了两个馒头
mch_id 商户id 需在 商户平台 查看(申请商户平台成功就会得到) 如: 149411***2
nonce_str 随机字符串(别带小数点(没考证 感觉)) 例如:76521019851170500000
notify_url 成功后的通知地址 例如:https://baidu.top/callbackofpay
openid 用户的唯一标识 在用户使用小程序的时候通过其 code 换取 openid
例如: obxgc5CgBbgKDrvcxxxxxJ-xxxxx
out_trade_no 商户订单号 例如:20180805740161 需要无重复
spbill_create_ip 终端ip(服务器的ip)貌似 127.0.0.1 就行
total_fee 此单的交易额度(钱 money) 例如:888 单位是 分钱。及8.88元钱 ( 注意是数值型,非字符型,除此之外其他的都是字符型 )
trade_type 小程序用 'JSAPI' 其他看api
2 将以上参数(必要参数一个不能少)按照 key 字典排序,进行拼接。
例如: appid=wxedxxx2xxx6c03e9e&body=我是商品描述,用户买了两个馒头.&mch_id=149411***2&nonce_str=76521019851170500000 ......
3 在结尾加上 商户的秘钥 mch_key (需在商户平台配置 在:账户中心-->账户设置-->API安全-->API秘钥 ,可以用 32位随机码生成器 生成)
+ "&key=" + mch_key
5 对拼接成的字符串,进行md5加密-->转大写 -->生成 签名 sign
例如: 425F6561A654B366B5519F000CF2AE61
6 将以上参数拼成 xml
let _xmlUnifiedorder = `
${myObj.appid}
${myObj.body}
${myObj.mch_id}
${myObj.nonce_str}
${myObj.notify_url}
${myObj.openid}
${myObj.out_trade_no}
${myObj.spbill_create_ip}
${myObj.total_fee}
${myObj.trade_type}
${sign}
`
7 携带参数 post 访问 https://api.mch.weixin.qq.com/pay/unifiedorder 接口
如果正确 会成功得到 xml格式的 prepay_id ,如果签名错误进行下面的错误查找。
~~:进行错误查找 可以拿出参数在 测试接口 进行测试 ,无异常可以正常生成 xml之后,如果还报错。
试着 更改 商户平台的秘钥 (详细请看第 3 步)。貌似很多人都踩这个雷了 ...
<code>
// 字典排序 key1=xxx&key2=zzz 拼接成字符串
function joinToStr(_obj) {
let keyArr = []
for (let key in _obj) {
keyArr.push(key)
}
keyArr = keyArr.sort()
console.log("keyArrSort--->", keyArr)
// paySign = MD5(appId=wxd678efh567hg6787&nonceStr=5K8264ILTKCH16CQ2502SI8ZNMTM67VS&package=prepay_id=wx2017033010242291fcfe0db70013231072&signType=MD5&timeStamp=1490840662&key=qazwsxedcrfvtgbyhnujmikolp111111) = 22D9B4E54AB1950F51E0649E8810ACD6
// _str 是 paySign 中MD5 包裹的字符串部分
let _str = ""
let len = keyArr.length
for (let i = 0i <leni++) {
if (i == len - 1) {
_str += (keyArr[i] + "=" + _obj[keyArr[i]])
} else {
_str += (keyArr[i] + "=" + _obj[keyArr[i]] + "&")
}
}
return _str
}
</code>
微信小程序测试号和 AppID 是微信小程序开发中的两个概念,它们的区别如下:1. 测试号:测试号是微信小程序开发测试使用的账号,不需要付费,可以测试开发和功能调试。测试号不可接受支付、微信登录、微信分享等功能,并且有一定的使用次数限制。
2. AppID:AppID则是微信小程序正式上线需要的身份标识,一般需要向微信支付一定的认证费用。用于获取微信小程序接口,调用微信小程序相关接口功能,例如微信登录、支付、分享等。只有正式的 AppID 才能在微信小程序正式发布上线。
因此,在进行微信小程序开发时,测试号和 AppID 的使用场景是不同的。测试号主要用于开发和本地调试,而 AppID 则是正式上线以后使用的标识,用于用户正常使用。使用测试号的开发者也需要对 AppID 进行申请和认证才能正式发布小程序。
很多朋友都对小程序开发制作感兴趣,也想拥有自己的小程序店铺,下面小木就来分享一下小程序的制作流程,供大家参考:第一步:确定微信小程序制作方案
对于商家来说,在制作小程序之前,是需要确定微信购物小程序制作内容方案,包括行业、目标用户及市场、用户体验、小程序功能及设计等需求。
第二步:注册微信小程序相关账号
在微信公众平台上申请注册微信小程序、申请开通微信支付商户号。
第三步:选择小程序制作公司
很多的企业是不具备自己开发能力的,所以市场中大部分的商家都会选择小程序制作公司或外包团队,帮忙制作微信小程序。
第四步:确定小程序功能
当您确定好小程序制作公司之后,紧接着与该公司对接需求,来确定小程序的功能,如购物车功能,订单功能,商品管理功能等一些基础功能以及小程序自带的一些特色营销功能,如拼团,秒杀,砍价等。
第五步:开始制作小程序
当将商家最终确定的小程序功能之后,开发公司就可以着手制作小程序了。
第六步:小程序测试
对已经制作完成的小程序进行不同环境下的测试,如各功能测试、能否正常交易测试等,测试完成之后,将体验码给商家,让商家体验一下小程序,看看是否符合商家要求,没有问题,就可以提交给微信官方审核。
第七步:发布上线
等到微信官方审核通过之后,再点击正式发布,小程序发布后,过一会搜索您的微信小程序名称,就可以看到您的小程序了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)