修复支付功能,添加商品列表,优化代码结构

This commit is contained in:
mkm 2024-05-25 10:38:29 +08:00
parent 6c1ff9a354
commit 885695d643
6 changed files with 77 additions and 20 deletions

View File

@ -21,6 +21,7 @@ use Webman\RedisQueue\Redis;
use Yansongda\Pay\Pay; use Yansongda\Pay\Pay;
use Webman\Push\Api; use Webman\Push\Api;
use JPush\Client as JPush; use JPush\Client as JPush;
use support\Log;
class IndexController extends BaseApiController class IndexController extends BaseApiController
{ {
@ -28,19 +29,17 @@ class IndexController extends BaseApiController
public function index() public function index()
{ {
$auth_code=$this->request->get('auth_code');
// $select=(new Goods())->column('class'); $config = Config::get('payment');
// $a=array_unique($select); Pay::config($config);
// $arr=[];
// foreach($a as $k=>$v){ $result = Pay::alipay()->pos([
// $pid=Goodsclass::where('id',$v)->value('pid'); 'out_trade_no' => time(),
// $arr[$pid][]=$v; 'auth_code' => $auth_code,
// } 'total_amount' => '0.01',
// foreach($arr as $k=>$v){ 'subject' => 'yansongda 测试 - 01',
// Goodsclass::where('id',$k)->update(['children'=>json_encode($v,true)]); ]);
// } d($result);
$a=Goodsclass::where('pid',0)->where('children','<>',null)->column('id');
d ($a);
// $arr = []; // $arr = [];
// foreach ($a as $k => $v) { // foreach ($a as $k => $v) {
// $pid = Goodsclass::where('id', $v)->value('pid'); // $pid = Goodsclass::where('id', $v)->value('pid');

View File

@ -6,6 +6,7 @@ use app\common\enum\PayEnum;
use app\common\logic\PayNotifyLogic; use app\common\logic\PayNotifyLogic;
use app\common\model\retail\Cashierclass; use app\common\model\retail\Cashierclass;
use app\common\service\pay\PayService; use app\common\service\pay\PayService;
use support\Log;
/** /**
* 支付 * 支付
@ -15,7 +16,7 @@ use app\common\service\pay\PayService;
class PayController extends BaseApiController class PayController extends BaseApiController
{ {
public $notNeedLogin = ['notifyMnp']; public $notNeedLogin = ['notifyMnp','alipay_return','alipay_notify'];
/** /**
* @notes 小程序支付回调 * @notes 小程序支付回调
@ -57,4 +58,34 @@ class PayController extends BaseApiController
return $this->fail('订单支付中'); return $this->fail('订单支付中');
} }
} }
/**
* 支付宝同步回调地址
*/
public function alipay_return(){
$app=new PayService();
$result = $app->alipay->callback(Request()->post());
Log::error('支付宝同步回调',$result->toArray());
// if($result && $result->event_type=='TRANSACTION.SUCCESS'){
// $ciphertext=$result->resource['ciphertext'];
// if ($ciphertext['trade_state'] === 'SUCCESS') {
// $extra['transaction_id'] = $ciphertext['transaction_id'];
// $attach = $ciphertext['attach'];
// switch ($attach) {
// case 'cashierclass':
// PayNotifyLogic::handle('cashierclass', $ciphertext['out_trade_no'], $ciphertext);
// $app->wechat->success();
// break;
// }
// }
// }
}
/**
* 支付宝异步回调地址
*/
public function alipay_notify(){
$app=new PayService();
$result = $app->alipay->callback(Request()->post());
Log::error('支付宝异步回调',$result->toArray());
}
} }

View File

@ -13,5 +13,12 @@ class GoodsController extends BaseApiController{
return $this->dataLists(new GoodsLists()); return $this->dataLists(new GoodsLists());
} }
/**
* 商品列表
*/
public function mer_list(){
$this->request->__set('mer_id',$this->request->userInfo['merchant']['mer_id']??0);
return $this->dataLists(new GoodsLists());
}
} }

View File

@ -8,6 +8,7 @@ use app\common\model\goods\Goods;
use app\common\lists\ListsSearchInterface; use app\common\lists\ListsSearchInterface;
use app\common\model\goods\Goodsclass; use app\common\model\goods\Goodsclass;
use app\common\model\goods\GoodsLabel; use app\common\model\goods\GoodsLabel;
use think\facade\Db;
/** /**
* 商品列表列表 * 商品列表列表
@ -96,6 +97,20 @@ class GoodsLists extends BaseAdminDataLists implements ListsSearchInterface
}else{ }else{
$order['id'] = 'desc'; $order['id'] = 'desc';
} }
$mer_id=$this->request->__get('mer_id');
if($mer_id){
$goods_id=Db::name('merchant_bind_goods')->where('mer_id',$mer_id)->limit($this->limitOffset, $this->limitLength)->column('goods_id');
if($goods_id){
return Goods::where($this->searchWhere)->where('id','in',$goods_id)
->field(['id', 'name','brand','class','unit', 'sell', 'code','imgs','sales','spec'])
->with(['className','brandName','unitName'])
->order($order)
->select()
->toArray();
}else{
return [];
}
}
return Goods::where($this->searchWhere)->where($where) return Goods::where($this->searchWhere)->where($where)
->field(['id', 'name','brand','class','unit', 'sell', 'code','imgs','sales','spec']) ->field(['id', 'name','brand','class','unit', 'sell', 'code','imgs','sales','spec'])
->limit($this->limitOffset, $this->limitLength) ->limit($this->limitOffset, $this->limitLength)
@ -127,6 +142,10 @@ class GoodsLists extends BaseAdminDataLists implements ListsSearchInterface
$where[]=['class','=',$class_all]; $where[]=['class','=',$class_all];
} }
} }
$mer_id=$this->request->__get('mer_id');
if($mer_id){
return Db::name('merchant_bind_goods')->where('mer_id',$mer_id)->count();
}
return Goods::where($this->searchWhere)->where($where)->count(); return Goods::where($this->searchWhere)->where($where)->count();
} }

View File

@ -33,7 +33,7 @@ class PayService extends BasePayService
* @var * @var
*/ */
public $wechat; public $wechat;
protected $alipay; public $alipay;
/** /**
@ -57,6 +57,7 @@ class PayService extends BasePayService
$this->auth = UserAuth::where(['user_id' => $userId, 'terminal' => $terminal])->findOrEmpty(); $this->auth = UserAuth::where(['user_id' => $userId, 'terminal' => $terminal])->findOrEmpty();
} }
$this->wechat=Pay::wechat(); $this->wechat=Pay::wechat();
$this->alipay=Pay::alipay();
} }

View File

@ -13,15 +13,15 @@ return [
// 必填-应用私钥 字符串或路径 // 必填-应用私钥 字符串或路径
'app_secret_cert' => 'MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCktKWIoqSZ8BoSpALMsvTEsEQ1kF++wBeneams0Q17LvqGDBgiGuuICU0tnhBrjEkJFIw+5ApiHdkwbjFRqDqXyNj7B9fMBWp+QeHf6KvmRsPOHZegyvmQlqvMYf6hF4OwVKDrtVi6I1hVdrwf35h8KEGh4QM0WyXno2bJ7OVQDL49enrG7dXZQkwnwiluuxgjKphC2WYHCERGiYbrRKWXtQmzivjw7YTtfSXvypp8N3pSWXkWeLqpGGK3GG3pcUu4U+y4RFknnzSpiv20EJ6gw3pjUDkzexJoGh9byFOMoRVTJpIV8iTshdozd69ny5FjmIoXIouGCjdwp6M+XCXVAgMBAAECggEAJ1Dn4sHQQN7Lmn+EG5DsVLcu0QpxkHsSKmwkUJhme20vaCgi6qE6b/KodacxjDqkhIJfJ/QPdnRhj+n949wggHL1OJcasBzq2tCnNme4APQLcXwm4b8R663LvLH3skSGruTEtP9I+sXNJDl/lqwtHhYN9LJdrXXEipK6yqC97Gl7JznT/VXctOebXqFtdxm1M1zCoxwWwU20rYbNV74VIwIQhhNYaParU7ycVRgxw7wFhImGfy/y4SgHVTOS2Lhj12oDhHVSkhQjyEL4IKlI7Np/5jbZax+NWZjiTUJcDYEK6v6hpw0Skjf7fCBhbiHWTFm0LsBonLhX0b7hKaRYAQKBgQDu6fpxBmqpFy1Vzr/VWIWR9pXNtPqD3aVGWOUm3BuTyTtM8vEr6hcFIzjDae2JzSHTwAlNXQlifx43W630Iq2/AfYLsK1jtfqPRnuB1B4Bd+dixslG5a+mvpYTX0h9nZittWUh07tB8peoRidhnre0kKBZgdsO0XaaEpGkxoaEgQKBgQCwfBEq87wF5a9elUgJuDoqpglFWj8S52YqtolLdtpPpR7CtOLgAQb/ZAZ2Q0knAXcHgNoabqTJ1/psVc33+Lg3bQZyXiy9KUT72SoNhXa+kqWOAqjb4rEqL9x65l1A04Xxd4D0D3Drf0nv4TTaJfjjM/nRRWmqcOEKcvzgakKnVQKBgQCvI9EXCBgqqrXuQGj6kjEgpn581R4MivA82K/rw9Fnjk4tg67ufWWwu3hCMKYUrc8NdqqbDwfxL7TL6iZkYQOzkVF4kmUZQm9Slt21d/UjKG30SDuHAJu6hd5ohyISC/S/6skfeiK9HoS0s/DsrDiJYrhZxUr72uux2Mjx3SMBgQKBgQCX88qoS8Eo5rDO5ANpcviJ/flfgCtscFYUEqQ1mHixOH86r5njup62x/2UV6yla+p7SGMBfSBfNZlFK7+ycLDT8Agr8o/csqrVmQ5PJAmwXf0zP3D6Gb3mj9zq6GuERFtAI1+hQ6Y67ZbQdfwWk7kujnLaz0QCXzwzzfuSkYsgHQKBgFadCh1lJYQcpCjEDD50QAdbfzhVJRSYVEQhj2ekQ+w7hEndXiwptucPt8vs39qRfyXwoez2dWbK9ZUmU3/DTZBtL/1OmpDV2yPYi+xpipgzETB44mQnpcAcvaxU59j0oZQxXsWXHKNfOBzO2KgrReHnY7oUurPPq1A76yEcGmtn', 'app_secret_cert' => 'MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCktKWIoqSZ8BoSpALMsvTEsEQ1kF++wBeneams0Q17LvqGDBgiGuuICU0tnhBrjEkJFIw+5ApiHdkwbjFRqDqXyNj7B9fMBWp+QeHf6KvmRsPOHZegyvmQlqvMYf6hF4OwVKDrtVi6I1hVdrwf35h8KEGh4QM0WyXno2bJ7OVQDL49enrG7dXZQkwnwiluuxgjKphC2WYHCERGiYbrRKWXtQmzivjw7YTtfSXvypp8N3pSWXkWeLqpGGK3GG3pcUu4U+y4RFknnzSpiv20EJ6gw3pjUDkzexJoGh9byFOMoRVTJpIV8iTshdozd69ny5FjmIoXIouGCjdwp6M+XCXVAgMBAAECggEAJ1Dn4sHQQN7Lmn+EG5DsVLcu0QpxkHsSKmwkUJhme20vaCgi6qE6b/KodacxjDqkhIJfJ/QPdnRhj+n949wggHL1OJcasBzq2tCnNme4APQLcXwm4b8R663LvLH3skSGruTEtP9I+sXNJDl/lqwtHhYN9LJdrXXEipK6yqC97Gl7JznT/VXctOebXqFtdxm1M1zCoxwWwU20rYbNV74VIwIQhhNYaParU7ycVRgxw7wFhImGfy/y4SgHVTOS2Lhj12oDhHVSkhQjyEL4IKlI7Np/5jbZax+NWZjiTUJcDYEK6v6hpw0Skjf7fCBhbiHWTFm0LsBonLhX0b7hKaRYAQKBgQDu6fpxBmqpFy1Vzr/VWIWR9pXNtPqD3aVGWOUm3BuTyTtM8vEr6hcFIzjDae2JzSHTwAlNXQlifx43W630Iq2/AfYLsK1jtfqPRnuB1B4Bd+dixslG5a+mvpYTX0h9nZittWUh07tB8peoRidhnre0kKBZgdsO0XaaEpGkxoaEgQKBgQCwfBEq87wF5a9elUgJuDoqpglFWj8S52YqtolLdtpPpR7CtOLgAQb/ZAZ2Q0knAXcHgNoabqTJ1/psVc33+Lg3bQZyXiy9KUT72SoNhXa+kqWOAqjb4rEqL9x65l1A04Xxd4D0D3Drf0nv4TTaJfjjM/nRRWmqcOEKcvzgakKnVQKBgQCvI9EXCBgqqrXuQGj6kjEgpn581R4MivA82K/rw9Fnjk4tg67ufWWwu3hCMKYUrc8NdqqbDwfxL7TL6iZkYQOzkVF4kmUZQm9Slt21d/UjKG30SDuHAJu6hd5ohyISC/S/6skfeiK9HoS0s/DsrDiJYrhZxUr72uux2Mjx3SMBgQKBgQCX88qoS8Eo5rDO5ANpcviJ/flfgCtscFYUEqQ1mHixOH86r5njup62x/2UV6yla+p7SGMBfSBfNZlFK7+ycLDT8Agr8o/csqrVmQ5PJAmwXf0zP3D6Gb3mj9zq6GuERFtAI1+hQ6Y67ZbQdfwWk7kujnLaz0QCXzwzzfuSkYsgHQKBgFadCh1lJYQcpCjEDD50QAdbfzhVJRSYVEQhj2ekQ+w7hEndXiwptucPt8vs39qRfyXwoez2dWbK9ZUmU3/DTZBtL/1OmpDV2yPYi+xpipgzETB44mQnpcAcvaxU59j0oZQxXsWXHKNfOBzO2KgrReHnY7oUurPPq1A76yEcGmtn',
// 必填-应用公钥证书 路径 // 必填-应用公钥证书 路径
'app_public_cert_path' => runtime_path() . '/cert/ali/RSA2048.txt', 'app_public_cert_path' => runtime_path() . '/cert/ali/appCertPublicKey_2021004146699603.crt',
// 必填-支付宝公钥证书 路径 // 必填-支付宝公钥证书 路径
'alipay_public_cert_path' => runtime_path() . '/cert/ali/alipayPublicKey_RSA2.txt', 'alipay_public_cert_path' => runtime_path() . '/cert/ali/alipayCertPublicKey_RSA2.crt',
// 必填-支付宝根证书 路径 // 必填-支付宝根证书 路径
'alipay_root_cert_path' => runtime_path() . '/cert/ali/CSR.csr', 'alipay_root_cert_path' => runtime_path() . '/cert/ali/alipayRootCert.crt',
// 选填-同步回调地址 // 选填-同步回调地址
'return_url' => 'https://erp.lihaink.cn/api/pay/alipay-return', 'return_url' => 'https://erp.lihaink.cn/api/pay/alipay_return',
// 选填-异步回调地址 // 选填-异步回调地址
'notify_url' => 'https://erp.lihaink.cn/api/pay/alipay-notify', 'notify_url' => 'https://erp.lihaink.cn/api/pay/alipay_notify',
// 选填-服务商模式下的服务商 id当 mode 为 Pay::MODE_SERVICE 时使用该参数 // 选填-服务商模式下的服务商 id当 mode 为 Pay::MODE_SERVICE 时使用该参数
'service_provider_id' => '', 'service_provider_id' => '',
// 选填-默认为正常模式。可选为: MODE_NORMAL, MODE_SANDBOX, MODE_SERVICE // 选填-默认为正常模式。可选为: MODE_NORMAL, MODE_SANDBOX, MODE_SERVICE