php thinkphp 抖音支付,订单同步接口分享
1. 抖音支付
需要获取抖音小程序的AppID,AppSecret,需要配置回调地址,Token获取SALT
官方地址:支付,订单同步

以下干货仅针对于有一定开发基础的精英,0基础的止步。
public function DouyinPay($openId='',$id='',$body = '抖音担保支付'){$order=db('order')->where(['id'=>$id,'status'=>1])->find();//获取订单信息$outOrderNo = $order['orderno'];//开发者侧的订单号$totalAmount = $order['price'];//支付价格; 接口中参数支付金额单位为[分]$subject = "订单号:".$order['orderno']; //商品描述也就是标题$body = $body;$validTimestamp = 60 * 60;//订单过期时间(秒);$notifyUrl = "https://***/notify"; //这里可以忽略,走字节跳动小程序 -支付 -担保配置-设置回调地址//创建订单$response = $this->createOrder($outOrderNo, $totalAmount, $subject, $body, $validTimestamp, $notifyUrl);$this->success('成功',$response);}/*** 创建订单*/public function CreateOrder($outOrderNo, $totalAmount, $subject, $body, $validTimestamp, $notifyUrl){$params = ['app_id' => '******',//小程序appid'out_order_no' => $outOrderNo,'total_amount' => $totalAmount * 100,'subject' => $subject,'body' => $body,'valid_time' => $validTimestamp,'notify_url' => $notifyUrl,];$params = array_filter($params);$params['sign'] = $this->sign($params);$res = $this->posts('https://developer.toutiao.com/api/apps/ecpay/v1/create_order',$params);return $res;}/*** 获取签名*/public function sign($map) {$rList = [];foreach($map as $k =>$v) {if ($k == "other_settle_params" || $k == "app_id" || $k == "sign" || $k == "thirdparty_id")continue;$value = trim(strval($v));if (is_array($v)) {$value = $this->arrayToStr($v);}$len = strlen($value);if ($len > 1 && substr($value, 0,1)=="\"" && substr($value, $len-1)=="\"")$value = substr($value,1, $len-1);$value = trim($value);if ($value == "" || $value == "null")continue;$rList[] = $value;}$rList[] = "*****";//这里是SALTsort($rList, SORT_STRING);return md5(implode('&', $rList));}// **************** 以下方法 是字节小程序支付 签名处理方式public function callbackSign($data) {//***这里的是配置salt的时候填写的Token令牌$array = array('***',(string)$data['timestamp'],(string)$data['nonce'], (string)htmlspecialchars_decode($data['msg']));sort($array,SORT_STRING);$join_str = implode('',$array);return sha1($join_str);}public function arrayToStr($map) {$isMap = $this->isArrMap($map);$result = "";if ($isMap){$result = "map[";}$keyArr = array_keys($map);if ($isMap) {sort($keyArr);}$paramsArr = array();foreach($keyArr as $k) {$v = $map[$k];if ($isMap) {if (is_array($v)) {$paramsArr[] = sprintf("%s:%s", $k, arrayToStr($v));} else {$paramsArr[] = sprintf("%s:%s", $k, trim(strval($v)));}} else {if (is_array($v)) {$paramsArr[] = arrayToStr($v);} else {$paramsArr[] = trim(strval($v));}}}$result = sprintf("%s%s", $result, join(" ", $paramsArr));if (!$isMap) {$result = sprintf("[%s]", $result);} else {$result = sprintf("%s]", $result);}return $result;}public function isArrMap($map) {foreach($map as $k =>$v) {if (is_string($k)){return true;}}return false;}
// **************** 以下方法 是回调public function notify(){$notify = \request()->param();// 验签if ($notify['msg_signature'] !== $this->callbackSign($notify)) {return false;} else {//获取订单信息$order=(string)htmlspecialchars_decode($notify['msg']);$order = json_decode($order, true);//处理订单,获取订单号$sn = $order['cp_orderno'];$do2='订单的处理';if($do2){$data = ['err_no' => '0', 'err_tips' => 'success'];return json($data);}else{db()->rollback();return false;}// Log::info('抖音担保支付效验成功');}}public function posts(string $url, array $params = [], array $headers = []){$headers[] = 'Content-type: application/json';$ch = curl_init();curl_setopt($ch, CURLOPT_URL, $url);curl_setopt($ch, CURLOPT_POST, true);curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($params));curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);$output = curl_exec($ch);curl_close($ch);return json_decode($output, true);}
不要单纯以为只要支付完成就OK了,下面还需要订单同步到抖音,下场如下

2.订单同步
这里不需要申请额外的参数,大致分为三步(1.获取token,2.组装商品,3.组装订单)
代码如下:
/*** 订单推送到抖音* @param $data array 订单数据* @note order_status 与 status须保持一致,但类型不同* @return array*/public function pushOrder($id=''){$data=[];//获取订单信息$api = "https://developer.toutiao.com/api/apps/order/v2/push";$openid ='';//获取下单用户openid//组装商品$item_list = [['item_code' => '购买会员卡','img'=>'https://***/logo.jpg','title'=>'会员服务','amount'=>1,'price'=>(int)($data['price']*100)]];//参数对应请查看官方文档,注意字段类型// 组装订单$detail = ['order_id'=>$data['orderno'],'create_time'=>strtotime($data['add_time'])*1000,'status'=>"已支付",'amount'=>1,'total_price'=>(int)($data['price']*100),'detail_url'=>"pages/me/vip/vip",'item_list'=>$item_list];dump($detail);$param = ['access_token'=>$this->getAccessTokens(),'app_name'=>"douyin",'open_id'=>$openid,'update_time'=>$this->getMillisecond(),'order_detail'=>json_encode($detail),'order_type'=>0,'order_status'=>1,'payment_order_no'=>$data['orderno']];$result =$this->posts($api,$param);//请求}/*** 获取AccessToken*/public function getAccessTokens(){$api = "https://developer.toutiao.com/api/apps/v2/token";$param = ['appid'=>'***','secret'=>'***','grant_type'=>"client_credential"];$access_token = Cache::get('dy_accessToken');if(empty($access_token)){$data = $this->posts($api,$param);// dump($result);die;// $data = json_decode($result,true);if($data['err_no'] == 0){$access_token = $data['data']['access_token'];Cache::set('dy_accessToken',$access_token,$data['data']['expires_in']);}}return $access_token;}public function getMillisecond() {list($t1, $t2) = explode(' ', microtime());return (float)sprintf('%.0f',(floatval($t1)+floatval($t2))*1000);}
相关文章:
php thinkphp 抖音支付,订单同步接口分享
1. 抖音支付 需要获取抖音小程序的AppID,AppSecret,需要配置回调地址,Token获取SALT 官方地址:支付,订单同步 以下干货仅针对于有一定开发基础的精英,0基础的止步。 public function DouyinPay($openId,$id,$body 抖音担保支付…...
excel功能区(ribbonx)编程笔记--2 button控件与checkbox控件
我们上一章简单先了解了ribbonx的基本内容,以及使用举例实现自己修改ribbox的内容,本章紧接上一章,先讲解一下ribbonx的button控件。 在功能区的按钮中,可以使用内置图像或提供自已的图像,可以指定大按钮或者更小的形式,添加少量的代码甚至可以同时提供标签。此外,可以利…...
JavaScript 知识点
立即执行函数 代码(function () {// ... })();创建函数的同时立即执行,没有绑定任何事件,也无需等待任何异步操作function () {} 是一个匿名函数,包围它的一对括号将其转换为一个表达式,紧跟其后的一对括号调用了这个函数。立即执…...
深入理解 JVM 之——动手编译 JDK
更好的阅读体验 \huge{\color{red}{更好的阅读体验}} 更好的阅读体验 本篇为深入理解 Java 虚拟机第一章的实战内容,推荐在学习前先掌握基础的 Linux 操作、编译原理基础以及扎实的 C/C 功底。 该系列的 GitHub 仓库:https://github.com/Doge2077/lear…...
[移动通讯]【Carrier Aggregation in LTE】【 Theory + Log analysis-1】
CA: Carrrier Aggregation PCC: Primary Component Carrier SCC: SCC Secondary Component Carrier 目录: 背景介绍 PCC & SCC 聚合方式 Precondition for CA 一 背景介绍 在没有CA 技术前,手机和基站以单子载波的方式,收发…...
Sui诚邀您参加KBW「首尔Web3之夜」
韩国区块链周(KBW)是由FACTBLOCK创办,Hashed联合主办的年度盛会。今年的KBW将于9月4–10日在韩国首尔举办。作为亚洲最具影响力的Web3行业盛会之一,KBW将汇聚业界优秀的参与者和先驱者,共同探讨区块链行业的未来。 Su…...
19.CSS雨云动画特效
效果 源码 <!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><title>Cloud & Rain Animation</title><link rel="stylesheet" href="style.css"> </head> <bo…...
第61步 深度学习图像识别:多分类建模(TensorFlow)
基于WIN10的64位系统演示 一、写在前面 截至上期,我们一直都在做二分类的任务,无论是之前的机器学习任务,还是最近更新的图像分类任务。然而,在实际工作中,我们大概率需要进行多分类任务。例如肺部胸片可不仅仅能诊断…...
Spark 7:Spark SQL 函数定义
SparkSQL 定义UDF函数 方式1语法: udf对象 sparksession.udf.register(参数1,参数2,参数3) 参数1:UDF名称,可用于SQL风格 参数2:被注册成UDF的方法名 参数3:声明UDF的返回值类型 ud…...
ThinkPHP 文件上传 fileSystem 扩展的使用
ThinkPHP 文件上传 ThinkPHP 文件上传 扩展 filesystem一、安装 FileSystem 扩展二、认识 filesystem 配置文件 config/filesystem.php三、上传验证(涉及到验证器的知识点)四、文件上传demo ThinkPHP 文件上传 扩展 filesystem ThinkPHP 为我们 提供了 …...
液体神经网络LLN:通过动态信息流彻底改变人工智能
巴乌米克泰吉 一、说明 在在人工智能领域,神经网络已被证明是解决复杂问题的非常强大的工具。多年来,研究人员不断寻求创新方法来提高其性能并扩展其能力。其中一种方法是液体神经网络(LNN)的概念,这是一个利用动态计算…...
2023年的今天,PMP项目管理认证还值得考吗?
首先我肯定它值得考,PMP认证的教材和考纲都会随着项目管理工具和市场趋势而更新,不用担心会过时。 PMP项目管理认证是什么? 英文全称是Project Management Professional,中文全称叫做项目管理专业人士资格认证。它是由美国项目管…...
【JavaSE专栏91】Java如何主动发起Http、Https请求?
作者主页:Designer 小郑 作者简介:3年JAVA全栈开发经验,专注JAVA技术、系统定制、远程指导,致力于企业数字化转型,CSDN学院、蓝桥云课认证讲师。 主打方向:Vue、SpringBoot、微信小程序 本文讲解了如何使用…...
给oracle逻辑导出clob大字段、大数据量表提提速
文章目录 前言一、大表数据附:查询大表 二、解题思路1.导出排除大表的数据2.rowid切片导出大表数据Linux代码如下(示例):Windows代码如下(示例):手工执行代码如下(示例)&…...
研发规范第九讲:通用类命名规范(重点)
研发规范第九讲:通用类命名规范(重点) 无规范不成方圆。我自己非常注重搭建项目结构的起步过程,应用命名规范、模块的划分、目录(包)的命名,我觉得非常重要,如果做的足够好ÿ…...
python+django+协同过滤算法-基于爬虫的个性化书籍推荐系统(包含报告+源码+开题)
为了提高个性化书籍推荐信息管理的效率;充分利用现有资源;减少不必要的人力、物力和财政支出来实现管理人员更充分掌握个性化书籍推荐信息的管理;开发设计专用系统--基于爬虫的个性化书籍推荐系统来进行管理个性化书籍推荐信息,以…...
系统架构:软件工程
文章目录 资源知识点自顶向下与自底向上形式化方法结构化方法敏捷方法净室软件工程面向服务的方法面向对象的方法快速应用开发螺旋模型软件过程和活动开放式源码开发方法功用驱动开发方法统一过程模型RUP基于构件的软件开发UML 资源 信息系统开发方法 知识点 自顶向下与自底…...
泰迪大数据实训平台产品介绍
大数据产品包括:大数据实训管理平台、大数据开发实训平台、大数据编程实训平台等 大数据实训管理平台 泰迪大数据实训平台从课程管理、资源管理、实训管理等方面出发,主要解决现有实验室无法满足教学需求、传统教学流程和工具低效耗时和内部教学…...
Linux- 文件夹相关的常用指令
1. 统计文件夹下的文件数量 在 Linux 下,有几种方法可以统计文件夹下的文件数量: 使用 ls 和 wc 命令: 这种方式可以统计目录下的直接子文件(不包括子目录里的文件)。 ls -l <目录路径> | wc -l注意:…...
在 macOS 中安装 TensorFlow 1g
tensorflow 需要多大空间 pip install tensorflow pip install tensorflow Looking in indexes: https://pypi.douban.com/simple/ Collecting tensorflowDownloading https://pypi.doubanio.com/packages/1a/c1/9c14df0625836af8ba6628585c6d3c3bf8f1e1101cafa2435eb28a7764…...
华硕笔记本性能管家G-Helper:告别臃肿控制中心,重获系统掌控权
华硕笔记本性能管家G-Helper:告别臃肿控制中心,重获系统掌控权 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops with nearly the same functionality. Works with ROG Zephyrus, Flow, TUF, Strix, Scar, ProArt, Vi…...
新手如何通过Taotoken控制台申请API Key并查看初始用量
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 新手如何通过Taotoken控制台申请API Key并查看初始用量 对于初次接触大模型API的开发者而言,第一步往往是如何获取一个…...
Cursor设备标识重置技术:3分钟解决试用限制的完整方案
Cursor设备标识重置技术:3分钟解决试用限制的完整方案 【免费下载链接】go-cursor-help 解决Cursor在免费订阅期间出现以下提示的问题: Your request has been blocked as our system has detected suspicious activity / Youve reached your trial request limit. …...
告别丑表格!用xlsx-style给Vue+Element UI导出的Excel加个美颜(附完整代码)
专业级Excel导出美化实战:VueElement UI与xlsx-style深度整合指南 在企业级后台管理系统开发中,数据报表的导出功能几乎是标配需求。但开发者常遇到这样的尴尬:精心设计的页面表格导出为Excel后,所有样式荡然无存,变成…...
从零开始:YY3568开发板刷写原生Linux系统全流程指南
1. 项目概述与核心价值 最近拿到了一块YY3568开发板,这是一款基于瑞芯微RK3568芯片的嵌入式开发平台,性能相当不错。很多朋友拿到开发板后,第一反应就是跟着官方文档跑个Demo,或者直接用板子预装的Android系统。但如果你和我一样&…...
从莱顿瓶到手机:一个300年前的“水罐”如何塑造了今天的电子世界?
从莱顿瓶到手机:一个300年前的“水罐”如何塑造了今天的电子世界? 1746年,法国物理学家诺莱特在巴黎科学院进行了一场令人瞠目的公开实验:700名僧侣手拉手排成1.5公里长的人链,当首尾两端连接莱顿瓶时,所有…...
过拟合和欠拟合
模型容量可以视作模型的复杂度。如果数据比较简单,却选择了模型容量高的(复杂模型),可能会出现过拟合(underfitting)如果数据比较复杂,却选择类简单模型,可能会出现欠拟合࿰…...
从零到一:华大HC32L110C6PA GPIO操作避坑指南(附完整代码)
从零到一:华大HC32L110C6PA GPIO操作避坑指南(附完整代码) 第一次接触华大HC32L110C6PA这款MCU时,我被它小巧的体积和丰富的功能所吸引。但当我真正开始GPIO配置时,却发现官方文档中的某些细节并不像想象中那么直观。…...
告别开机黑屏:搞懂UEFI、CSM和Secure Boot的‘三角关系’,装机不求人
现代计算机启动架构解密:UEFI、CSM与Secure Boot的协同与冲突 开机黑屏是许多DIY装机用户和技术爱好者常遇到的棘手问题。当新硬件遇上旧设备,或是现代系统需要兼容传统软件时,计算机的启动过程往往成为第一道技术壁垒。要真正理解这些兼容性…...
终极指南:5步掌握UnityPackage Extractor高效提取Unity资源包
终极指南:5步掌握UnityPackage Extractor高效提取Unity资源包 【免费下载链接】unitypackage_extractor Extract a .unitypackage, with or without Python 项目地址: https://gitcode.com/gh_mirrors/un/unitypackage_extractor UnityPackage Extractor是一…...
