蝙蝠岛资源网 Design By www.hbtsch.com
本文实例为大家分享了微信小程序支付PHP具体代码,供大家参考,具体内容如下
服务器端获取 openid
Getopenid.php
<"";//填写小程序appid
$SECRET="";//填写小程序secret
$JSCODE="";
if(isset($_GET['js_code'])){
$JSCODE=$_GET['js_code'];
$url="https://api.weixin.qq.com/sns/jscode2session".$APPID
."&secret=".$SECRET."&js_code=".$JSCODE."&grant_type=authorization_code";
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl, CURLOPT_HEADER, 0);
$data = curl_exec($curl);
$array=json_decode($data,true);
curl_close($curl);
$openid=isset($array['openid'])"40029"){
$response["result"] = 0;
$response["msg"] = "invalid code";
$response["openid"] = $openid;
echo json_encode($response);
}else{
$response["result"] = 1;
$response["msg"] = "user exist";
$response["openid"] = $openid;
echo json_encode($response);
}
}
小程序存储openid
在app.js中
getUserInfo:function(cb){
var that = this
if(this.globalData.userInfo){
typeof cb == "function" && cb(this.globalData.userInfo)
}else{
wx.login({
success: function (res) {
if (res.code) {
var code = res.code;
wx.getUserInfo({
success: function (res2) {
console.log(res2);
that.globalData.userInfo = res2.userInfo;
typeof cb == "function" && cb(that.globalData.userInfo)
var encryptedData = encodeURIComponent(res2.encryptedData);//一定要把加密串转成URI编码
var iv = res2.iv;
//请求自己的服务器
//Login(code, encryptedData, iv);
wx.showToast({
title: '正在登录...',
icon: 'loading',
duration: 10000
});
//请求服务器
wx.request({
url: API_URL,//Getopenid.php
data: {
js_code: code,
},
method: 'GET',
header: {
'content-type': 'application/json'
}, // 设置请求的 header
success: function (res) {
// success
wx.hideToast();
console.log("JSON:" + res.data);
if (res.data.result=="1"){//获取openid成功
wx.setStorage({//存储openid
key: "openid",
data: res.data.openid
})
}else{
wx.showToast({
title: 'openid获取失败',
icon: 'none',
duration: 2000
})
}
console.log('服务器返回' + res.data.result);
console.log('服务器返回' + res.data.msg);
console.log('服务器返回' + res.data.openid);
},
fail: function () {
// fail
// wx.hideToast();
},
complete: function () {
// complete
}
})
}
})
} else {
console.log('获取用户登录态失败!' + res.errMsg)
}
}
})
}
}
在登陆界面获取openid
var app = getApp()
onLoad: function () {
console.log('onLoad')
var that = this
//调用应用实例的方法获取全局数据
app.getUserInfo(function(userInfo){//获取用户信息
//更新数据
that.setData({
userInfo:userInfo
})
})
}
通过以上步骤已经获取到openid
支付方法小程序
pay() {
var that = this;
if (this.data.totalPrice == 0) {
return;
}
wx.getStorage({//获取存储在本地的openid
key: 'openid',
success: function (res) {
console.log(res.data)
that.setData({
openid:res.data,
})
var carArray = that.data.carArray;
var str="";
for (var i = 0; i < carArray.length; i++) {
str=str+ carArray[i].num+"个" + carArray[i].name+" ";
}
wx.request({
url: 'Pay.php',//支付接口
data: {
openid: res.data,//openid
total_fee: that.data.totalPrice,//总金额
body: str,//商品描述
},
method:'GET',
success:function(res){
console.log(res.data['timeStamp'])
if(res.data){
wx.requestPayment({
'timeStamp': res.data['timeStamp'],
'nonceStr': res.data['nonceStr'],
'package': res.data['package'],
'signType': 'MD5',
'paySign': res.data['paySign'],
'success': function (res) {
wx.showToast({
title: '支付成功',
icon: 'succes',
duration: 1000,
mask: true
})
//支付成功后在数据库减去购买商品的数量
var carArray = that.data.carArray;
for (var i = 0; i < carArray.length; i++) {
that.setData({
jiesuan_num: carArray[i].num,
jiesuan_id: carArray[i].goods_id,
})
DeGood(that);
}
},
'fail': function (res) {
wx.showToast({
title: '支付失败',
icon: 'none',
duration: 1000,
mask: true
})
}
})
}
}
})
}
})
},
Pay.php
<"htmlcode"><"curl出错,错误码:$error"); } } //数组转换成xml private function arrayToXml($arr) { $xml = "<root>"; foreach ($arr as $key => $val) { if (is_array($val)) { $xml .= "<" . $key . ">" . arrayToXml($val) . "</" . $key . ">"; } else { $xml .= "<" . $key . ">" . $val . "</" . $key . ">"; } } $xml .= "</root>"; return $xml; } //xml转换成数组 private function xmlToArray($xml) { //禁止引用外部xml实体 libxml_disable_entity_loader(true); $xmlstring = simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA); $val = json_decode(json_encode($xmlstring), true); return $val; } //微信小程序接口 private function weixinapp() { //统一下单接口 $unifiedorder = $this->unifiedorder(); // print_r($unifiedorder); $parameters = array( 'appId' => $this->appid, //小程序ID 'timeStamp' => '' . time() . '', //时间戳 'nonceStr' => $this->createNoncestr(), //随机串 'package' => 'prepay_id=' . $unifiedorder['prepay_id'], //数据包 'signType' => 'MD5'//签名方式 ); //签名 $parameters['paySign'] = $this->getSign($parameters); return $parameters; } //作用:产生随机字符串,不长于32位 private function createNoncestr($length = 32) { $chars = "abcdefghijklmnopqrstuvwxyz0123456789"; $str = ""; for ($i = 0; $i < $length; $i++) { $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1); } return $str; } //作用:生成签名 private function getSign($Obj) { foreach ($Obj as $k => $v) { $Parameters[$k] = $v; } //签名步骤一:按字典序排序参数 ksort($Parameters); $String = $this->formatBizQueryParaMap($Parameters, false); //签名步骤二:在string后加入KEY $String = $String . "&key=" . $this->key; //签名步骤三:MD5加密 $String = md5($String); //签名步骤四:所有字符转为大写 $result_ = strtoupper($String); return $result_; } ///作用:格式化参数,签名过程需要使用 private function formatBizQueryParaMap($paraMap, $urlencode) { $buff = ""; ksort($paraMap); foreach ($paraMap as $k => $v) { if ($urlencode) { $v = urlencode($v); } $buff .= $k . "=" . $v . "&"; } $reqPar; if (strlen($buff) > 0) { $reqPar = substr($buff, 0, strlen($buff) - 1); } return $reqPar; } }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
蝙蝠岛资源网 Design By www.hbtsch.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
蝙蝠岛资源网 Design By www.hbtsch.com
暂无微信小程序支付PHP代码的评论...
更新日志
2025年10月24日
2025年10月24日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]