PHP实现财务审核通过后返现金额到客户的功能

应用场景:

有这么一个返现的系统,当前端客户发起提现的时候,后端就要通过审核这笔返现订单,才可以返现到客户的账号里。

来看看下面的截图

这里的业务场景就是经过两轮审核:销售审核,财务审核都通过后,后端就会付款一笔钱到客户,当然,这里财务审核会有很多种情况,不通过与通过,通过后直接付款又有很多种情况,详细可以查看微信付款到零钱的文档。下面就来看看具体你的代码实现

微信支付配置

1,数据表大概如下

CREATE TABLE `zmq_weixin_config` (
 `id` int(1) unsigned NOT NULL AUTO_INCREMENT COMMENT '微信公众平台编号,自增id',
 `weixin_name` varchar(10) NOT NULL COMMENT '微信公众平台名称',
 `token` varchar(100) NOT NULL,
 `appid` char(18) NOT NULL,
 `appsecret` char(32) NOT NULL,
 `access_token` varchar(300) NOT NULL,
 `api_ticket` varchar(300) DEFAULT NULL COMMENT '微信卡包api_ticket',
 `api_ticket_expired_at` datetime DEFAULT NULL COMMENT '微信卡包api_ticket过期时间',
 `mchid` varchar(20) DEFAULT NULL COMMENT '商户号',
 `mchkey` varchar(50) DEFAULT NULL COMMENT '支付密钥',
 `expired_at` timestamp NULL DEFAULT NULL COMMENT 'access_token过期时间,会自动更新',
 `updated_at` timestamp NULL DEFAULT NULL COMMENT '记录更新时间',
 `created_at` timestamp NULL DEFAULT NULL COMMENT '创建时间',
 `sort_order` smallint(5) NOT NULL DEFAULT '0' COMMENT '排序',
 `points_url` varchar(100) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=11 DEFAULT CHARSET=utf8 CHECKSUM=1 DELAY_KEY_WRITE=1 ROW_FORMAT=DYNAMIC COMMENT='微信配置表';

2 .config的配置方法

/**
 * 获取微信支付配置
 * 这里我是把配置信息存储在数据表里,方便调用
 * $param是从controller里传值过来:weixin_config_id,notify_url
 * @return array
 */
public function getWechatConfig($param)
{
  $weixin = WeixinConfigBaseModel::find($param['weixin_config_id']);
  if (empty($weixin)) {
    throw new Exception('微信配置ID错误');
  }

  return [
    'wechat' =>[
      $app_id => $weixin->appid,
      'mch_id' => $weixin->mchid,
      'notify_url' => empty($param['notify_url']) ? '' : $param['notify_url'], //回调url
      'key' => $weixin->mchkey,
      'cert_client' => resource_path().'/wechat/'.$weixin->id.'/apiclient_cert.pem', //证书与key
      'cert_key' => resource_path().'/wechat/'.$weixin->id.'/apiclient_key.pem',
    ]
  ];
}

企业付款到个人零钱核心代码

/**
 * 获取微信支付配置
 * 这里我是把配置信息存储在数据表里,方便调用
 * $param是从controller里传值过来:weixin_config_id,notify_url
 * @return array
 */
public function getWechatConfig($param)
{
  $weixin = WeixinConfigBaseModel::find($param['weixin_config_id']);
  if (empty($weixin)) {
    throw new Exception('微信配置ID错误');
  }

  return [
    'wechat' =>[
      $app_id => $weixin->appid,
      'mch_id' => $weixin->mchid,
      'notify_url' => empty($param['notify_url']) ? '' : $param['notify_url'], //回调url
      'key' => $weixin->mchkey,
      'cert_client' => resource_path().'/wechat/'.$weixin->id.'/apiclient_cert.pem', //证书与key
      'cert_key' => resource_path().'/wechat/'.$weixin->id.'/apiclient_key.pem',
    ]
  ];
}

财务审核,也就是微信返现到零钱,这个时候会返回成功结果,或者是各种不成功的结果

这里我用一个方法封装

//财务审核
if($param['status'] == 2){

  //判断返现金额与修改后的金额
  if($before_rebate_amount != $param['rebate_amount']){
    //返现金额不相等,则出款金额改变
    $out_amount = $param['rebate_amount'] - $before_rebate_amount ;
    $this->outMount($business->business_id,$out_amount);
  }

  if($param['rebate_status'] == 9){
    //财务拒绝通过
    $business->audit_status = $param['rebate_status'];
    $business->rebate_amount = $param['rebate_amount'];
    $business->status = 6;
    $business->save();

    //生成日志
    $this->insertWithdrawLog($param['withdraw_id'], $business->status, $business->audit_status, $param['rebate_remark'], $param['admin_id']);

  }else{
    //提现的各种返回结果
    $this->payReturnResult($business,$param);
  }
}
/**
 * Function:微信提现返回的各种结果
 * Author:cyw0413
 * @param $res
 * @param $business
 * @param $param
 */
public function payReturnResult($business,$param)
{
  $input = [
    'weixin_config_id' => 20 ,
    'openid'      => $business->business->open_id,
    'amount'      => $param['rebate_amount'] * 100,
    'trade_no'     => $business->order_sn, //商户订单号
    'desc'       => "微信提现"
  ];

  $pay = new PayLogBaseService();
  $res = $pay->weixinPay($input);

  if($res['result_code']=="SUCCESS"){
    //提现成功
    $business->audit_status = 4;
    $business->status = 4;
    $business->rebate_amount = $param['rebate_amount'];
    $param['rebate_remark'] = "已付款(".$param['rebate_amount'].")";

  }elseif ($res['err_code'] == "MONEY_LIMIT"){
    $business->audit_status = 3;
    $business->status = 3;
    $param['rebate_remark'] = "提现失败,已达到付款给此用户额度上限";
    //throw new \Exception($param['rebate_remark']);

  }elseif ($res['err_code'] == "AMOUNT_LIMIT"){
    $business->audit_status = 3;
    $business->status = 3;
    $param['rebate_remark'] = "提现失败,低于最低付款金额或者高于最高付款金额";
    //throw new \Exception($param['rebate_remark']);
egdf
  }elseif ($res['err_code'] == "NOTENOUGH"){
    $business->audit_status = 3;
    $business->status = 3;
    $param['rebate_remark'] = "提现失败,付款帐号余额不足或资金未到账";
    //throw new \Exception($param['rebate_remark']);

  }elseif ($res['err_code'] == "SIGN_ERROR"){
    $business->audit_status = 3;
    $business->status = 3;
    $param['rebate_remark'] = "提现失败,签名错误";

  }elseif ($res['err_code'] == "PARAM_ERROR"){
    $business->audit_status = 3;
    $business->status = 3;
    $param['rebate_remark'] = "提现失败,参数错误";

  }elseif ($res['err_code'] == "OPENID_ERROR"){
    $business->audit_status = 3;
    $business->status = 3;
    $param['rebate_remark'] = "提现失败,Openid错误";

  }elseif ($res['err_code'] == "FATAL_ERROR"){
    $business->audit_status = 3;
    $business->status = 3;
    $param['rebate_remark'] = "提现失败,两次请求参数不一致";

  }elseif ($res['err_code'] == "CA_ERROR"){
    $business->audit_status = 3;
    $business->status = 3;
    $param['rebate_remark'] = "提现失败,商户API证书校验出错";

  }elseif ($res['err_code'] == "V2_ACCOUNT_SIMPLE_BAN"){
    $business->audit_status = 3;
    $business->status = 3;
    $param['rebate_remark'] = "提现失败,无法给非实名用户付款";

  }else{
    $business->audit_status = 3;
    $business->status = 3;
    $param['rebate_remark'] = "提现失败,服务器繁忙,请稍后再试";
    //throw new \Exception($param['rebate_remark']);
  }

  $business->save();

}

当微信平台余额不足或者出现各种错误而提现失败的时候,这里还有支持重新付款的功能:其实就是点击按钮后重新调用付款到零钱的功能,知道成功付款

/**
 * Function:重新付款
 * Author:cyw0413
 * @param $param
 * @throws \Exception
 */
public function repay($param)
{
  if(empty($param)){
    throw new \Exception("参数错误");
  }
  $business = GroupBusinessWithdrawBaseModel::find($param['withdraw_id']);
  if(empty($business)){
    throw new \Exception("不存在!");
  }
  if($business->audit_status != 3){
    throw new \Exception("状态有错误");
  }
  //提现的各种返回结果
  $this->payReturnResult($business,$param);
}

总结

以上所述是小编给大家介绍的PHP实现财务审核通过后返现金额到客户的功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

(0)

相关推荐

  • 如何用PHP做到页面注册审核

    用户注册后就有该条用户记录,你对用户表设一个"审核状态"字段,默认值设为"未审核",然后你写几句审核代码做成一个功能,按照你们的意愿若审核通过你把审核状态改为"已审核"就行了.用户想进行各种操作时,你先判断一下审核状态字段,若未审核则阻止并给出一些提示信息,否则放行. 注册页面 <body > <h1>注册页面</h1> <form action="zhucechuli.php" me

  • php注册审核重点解析(数据访问)

    关于审核,如发表文章的审核.员工请假的审核.药品申请的审核等等,代码大同小异. 一.注册功能(zhece.php   chuli.php) 1.zhece.php <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> </head> <form method="post" action=&quo

  • PHP利用百度ai实现文本和图片审核

    之前做平台内容发布审核都是自己构建一套违禁词库,在代码中利用词库判断用户发布的内容,现在可以使用百度ai api完成这个功能.接下来就简单说下怎么做吧: 首先打开百度ai 开发平台 注册一个账号: 注册账号,进入控制台 创建自己的应用,获取apikey 和秘钥 进入文档页 文本审核: 图像审核: 文档很详细,实现用户发布内容审核 图片审核还是很方便简单的.我没有使用官方的sdk,简单的整合了一下作为练手,以下是我简单的代码demo: class Sentive { protected $acce

  • PHPCMS遭遇会员投稿审核无效的解决方法 原创

    今天接到主编那边的反馈,说本站的会员投稿平台,后台无法审核文章了,赶紧看看吧 本来想偷个懒,去度娘那里搜搜,看有相同情况的解决方案没,结果大失所望,虽然也有几个类似的情况,要么没解决,要么就是原因跟本站不同. 得了,毛主席他老人家教导我们,自己动手,丰衣足食! 先找到审核的相关程序页 /phpcms/modules/content/content.php中的pass()方法,检查了下,并无被修改的现象 去审核页面按F12调试,控制台也无报错情况 真是奇了怪了, 查看下源码,发现了这段 <scri

  • PHP实现财务审核通过后返现金额到客户的功能

    应用场景: 有这么一个返现的系统,当前端客户发起提现的时候,后端就要通过审核这笔返现订单,才可以返现到客户的账号里. 来看看下面的截图 这里的业务场景就是经过两轮审核:销售审核,财务审核都通过后,后端就会付款一笔钱到客户,当然,这里财务审核会有很多种情况,不通过与通过,通过后直接付款又有很多种情况,详细可以查看微信付款到零钱的文档.下面就来看看具体你的代码实现 微信支付配置 1,数据表大概如下 CREATE TABLE `zmq_weixin_config` ( `id` int(1) unsi

  • php+ajax发起流程和审核流程(以请假为例)

    上一篇随笔中已经提到如何新建流程,那么现在我们就来看一下如何发起一个流程和审核流程~~~ 先说一下思路: (1)登录用session获取到用户的id (2) 用户发起一个流程 注意:需要写申请事由 (3)处于节点的审核人去依次审核 注意:每审核通过一个,对应towhere字段要加1: 审核到最后时,对应的isok字段要变为1(此处1表示结束,0表示未结束) 共用到三张表: 第一步:先做一个简单的登录页面,用session获取用户名: denglu.php页面 <!DOCTYPE html> &

  • PHP代码审核的详细介绍

    概述代码审核,是对应用程序源代码进行系统性检查的工作.它的目的是为了找到并且修复应用程序在开发阶段存在的一些漏洞或者程序逻辑错误,避免程序漏洞被非法利用给企业带来不必要的风险代码审核不是简单的检查代码,审核代码的原因是确保代码能安全的做到对信息和资源进行足够的保护,所以熟悉整个应用程序的业务流程对于控制潜在的风险是非常重要的.审核人员可以使用类似下面的问题对开发者进行访谈,来收集应用程序信息. 应用程序中包含什么类型的敏感信息,应用程序怎么保护这些信息的?应用程序是对内提供服务,还是对外?哪些人

  • Java Web实现session过期后自动跳转到登陆页功能【基于过滤器】

    本文实例讲述了Java Web实现session过期后自动跳转到登陆页功能.分享给大家供大家参考,具体如下: 通过过滤器的方式实现 session过期后自动跳转到登陆页 过滤器只在与servlet规范2.3版兼容的服务器上有作用.如果你的Web应用需要支持旧版服务器,就不能使用过滤器. 一.建立基本过滤器 建立一个过滤器涉及下列五个步骤: 1)建立一个实现Filter接口的类SessionFilter .这个类需要三个方法,分别是:doFilter.init和destroy.doFilter方法

  • QQ互联一键登录审核不通过的解决方案

    在QQ互联上申请帐号之后提交了审核, 后台填写APPID和KEY之后自己申请的QQ号可以正常登录,但QQ互联审核的时候一直审核不通过说是"您的网站审核未通过,原因是"点击QQ登录按钮提示登录失败或出现错误信息(无跳转.提示失败.出现错误信息)",请确认申请符合审核标准后,再提交审核",或者是""禁止开发商强制用户重新注册或绑定其他帐号"". 错误提示图: Destoon爱好者对此问题的解决方案是:修改模板目录下的chip/li

  • js实现刷新页面后回到记录时滚动条的位置【两种方案可选】

    当div中绑定数据,给它一个属性overflow-y: scroll,添加长度大小,使其能够出现滚动条:每次刷新的时候滚动条总是会出现在最上方,这使我很头疼,经过查阅网上资料,返现两种方法可行.如下: 第一种方案 将上一个页面的div的scrolltop距离长度记录在cookie中,然后通过js调整刷新页面时的长度记录,代码如下: js代码: <script> var _h = 0; function SetH(o) { _h = o.scrollTop SetCookie("a&q

  • SSH框架网上商城项目第26战之订单支付后发送短信提醒

    上一节我们使用了Java mail完成了给买家发送邮件的功能,还遗留一个功能,就是给买家发送短信,告诉他订单已经生成之类的.这一节主要介绍一下如何在用户支付完成后自动给用户发送短信. 1. 申请短信发送功能 很明显,我们自己不能发短信,也没有做短信的功能,所以我们需要去借助第三方的运营商.但是像中国移动,联通,电信这种不会直接给我们提供短信服务,而是先把短信服务提供给一些运营商,然后这些运营商再提供给我们. 有一个运营商叫"中国网建sms短信通"(官网地址).这个运营商可以给我们提供短

  • Spring源码解析后置处理器梳理总结

    目录 前言 1.InstantiationAwareBeanPostProcessor的postProcessBeforeInstantiation()方法 2.SmartInstantiationAwareBeanPostProcessor的determineCandidateConstructors()方法 3.MergedBeanDefinitionPostProcessor的postProcessMergedBeanDefinition()方法 4.SmartInstantiationA

  • mysql中的find_in_set字符串查找函数解析

    目录 需求 方案 函数 1. 介绍 2. 语法:FIND_IN_SET(needle,haystack) 3. 实战 插曲 总结 需求 系统中,不论是订单还是退货单,有的平台使用需要卖家审核,有的则不需要,所以在系统中可以设置订单或退货单的流程节点. 而对于每个流程节点,客户需求是每个节点都要根据系统下的员工的角色去做分发,从而订单指定到个人,而不是整个公司的员工都可以处理. 方案 对于上述场景,我实现的方案是在订单表和退货单表都增加了对应节点待处理人字段,多个人可处理的话,则用,分隔,保存对应

  • ASP.NET Core 2.0 支付宝扫码支付的实现代码

    前言 自从微软更换了CEO以后,微软的战略方向有了相当大的变化,不再是那么封闭,开源了许多东西,拥抱开源社区,.NET实现跨平台,收购xamarin并免费提供给开发者等等.我本人是很喜欢.net的,并希望.net core能够崛起.我是从.net core 1.1的时候开始使用的,到现在的.net core 2.0..net core 2.0比1.1有了一些改变,api也增加了很多,用着更顺手了,最近在做asp.net core 对接支付宝,百度了一下没找到关于core的支付宝支付相关资料,所以

  • 破解Vista激活机制三大方法总结

    全世界的"黑客"们,都希望找到这个被开发者称为"史上最安全"的操作系统软件的"命门",为此大家前仆后继.目前,网络上已经透露出三种破解Vista激活机制的方法: 1.时间停止法 原理:TimeStop(时间停止)法,首先更改系统时间为2099年12月31日(vista支持的最后时间),破解完后更改为当前时间,通过停止Vista中的计数器以达到强行冻结Vista验证时间的目的,最终系统激活时间定格在30天.黑客组织已经在网络上提供傻瓜激活程序下载,

  • asp.net 购物车的实现浅析

    该购物车的功能如下: . 通过ajax实现添加和删除车上的物品. . 删除的物品会显示出来,可以重新添加到购物车. . 嗯...没有了,具体大家接着看吧. 购物车的结构我打算用一个table来展示,在UserControl里使用ListView展现购物车的物品(因为比拼接字符串要容易维护的多).具体代码如下(ShopCartTest.ascx): 复制代码 代码如下: <asp:ListView ID="ListView1" runat="server">

随机推荐