thinkphp 微信服务器验证代码_thinkphp中使用AOP切面编程快速验证数据的方法介绍...

本篇文章给大家带来的内容是关于thinkphp中使用AOP切面编程快速验证数据的方法介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

1) 首先 查看一下我们的目录结构

25aab83d8716411161e27587b58d9aa8.png

2)使用平常的写法来构造一下我们的验证

b03903a177e0723e3d8eb69903f47ca0.png

这里主要分四步在走,相对于使用独立验证器或者挨个数据验证已经优化了大部分的代码了,但是,当在使用中会发现,我们在多个验证或者多个模块的时候会出现重复性的冗余去写这一串代码

问题? 如何将上诉的代码压缩成一行呢

AOP: 在不修改源代码的情况下给程序动态统一添加功能的一种技术。AOP实际是GoF设计模式的延续,设计模式孜孜不倦追求的是调用者和被调用者之间的解耦,提高代码的灵活性和可扩展性,AOP可以说也是这种目标的一种实现

AOP、OOP在字面上虽然非常类似,但却是面向不同领域的两种设计思想。OOP(面向对象编程)针对业务处理过程的实体及其属性和行为进行抽象封装,以获得更加清晰高效的逻辑单元划分。

我们引入aop编程的思想来解决的我们的问题,通过将功能单一的模块合并统一起来

我们在common下创建 validate目录,并且创建一个BaseValidate文件,继承 thinkvalidate

BaseValidate.php<?php

namespace appcommonvalidate;

use appcommoncontrollerBase;

use thinkRequest;

use thinkValidate;

class BaseValidate extends Validate

{

/**

* 基础类控制器

* @param null|array $data

* @return bool

*/

public function goCheck($data = null)

{

# 当 data 不存在的时候去自动校验获取到的参数

if( is_null($data) ) {

# 获取待验证的参数

$data = Request::instance()->param();

}

# 进行验证

if( !$this->check($data) ) {

(new Base())->ajaxjson(Base::error, $this->getError()); # 抛出的自定义异常

}

return true;

}

优化后代码

0e0baaa53600d72f45ac71f69b72f016.png

瞬间舒服了很多吧,省去了非常多的代码了算是,因为这个东西在很多控制器下都是应该需要进行使用的

优化2

如baseValidate中的代码,其中有一串代码是is_null,那是为了校验所有传递上来的数据而编写,当我们需要校验所有的数据的时候只需要这样写

175e1a2a0164fc7b4b0c6c7b0bd20f4e.png

同样可以校验出数据,但是会有一个疑惑,我们没有来获取data数据,无法使用data数据,还是需要在控制器中重新进行获取,这是不可取的,所以我选择这样做

423762415a306966b7a1d457f683e68d.png
1edec82615320aa213f8a11e0b798ae2.png

本篇文章到这里就已经全部结束了,更多其他精彩内容可以关注的PHP视频教程栏目!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的ThinkPHP 5.1版本的微信提现代码示例: ```php <?php namespace app\index\controller; use think\Controller; use think\facade\Config; use think\facade\Log; use think\facade\Request; class Withdraw extends Controller { // 微信提现接口 public function wechatWithdraw() { // 获取请求参数 $params = Request::param(); // 获取微信支付配置信息 $wxPayConfig = Config::get('wxpay'); // 请求参数构造 $data = [ 'mch_appid' => $wxPayConfig['appid'], 'mchid' => $wxPayConfig['mchid'], 'nonce_str' => md5(uniqid()), 'partner_trade_no' => $params['order_no'], 'openid' => $params['openid'], 'check_name' => 'NO_CHECK', // 不校验真实姓名 'amount' => $params['amount'], // 提现金额,单位分 'desc' => '提现描述', 'spbill_create_ip' => $_SERVER['REMOTE_ADDR'], ]; // 生成签名 $data['sign'] = $this->makeSign($data, $wxPayConfig['key']); // 数组转xml格式 $xmlData = $this->arrayToXml($data); // 发送请求 $url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers'; $response = $this->postXmlCurl($xmlData, $url, true, 6, $wxPayConfig['sslcert_path'], $wxPayConfig['sslkey_path']); // 解析返回的xml数据 $result = $this->xmlToArray($response); // 返回结果 if ($result['return_code'] == 'SUCCESS' && $result['result_code'] == 'SUCCESS') { // 提现成功 return json(['code' => 0, 'msg' => '提现成功']); } else { // 提现失败 Log::error('微信提现失败:' . $response); return json(['code' => 1, 'msg' => '提现失败,请重试']); } } // 生成签名 private function makeSign($data, $key) { // 去除数组的空值 $data = array_filter($data); // 按照键名的字典序排序 ksort($data); // 生成字符串 $stringA = ''; foreach ($data as $key => $value) { $stringA .= $key . '=' . $value . '&'; } $stringA .= 'key=' . $key; // 进行MD5签名并转化为大写 return strtoupper(md5($stringA)); } // 数组转xml格式 private function arrayToXml($data) { $xml = "<xml>"; foreach ($data as $key => $value) { if (is_numeric($value)) { $xml .= "<" . $key . ">" . $value . "</" . $key . ">"; } else { $xml .= "<" . $key . "><![CDATA[" . $value . "]]></" . $key . ">"; } } $xml .= "</xml>"; return $xml; } // 发送post请求xml数据 private function postXmlCurl($xmlData, $url, $useCert = false, $timeout = 30, $sslcert_path = '', $sslkey_path = '') { $ch = curl_init(); curl_setopt($ch, CURLOPT_TIMEOUT, $timeout); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); curl_setopt($ch, CURLOPT_HEADER, false); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_POST, true); curl_setopt($ch, CURLOPT_POSTFIELDS, $xmlData); if ($useCert == true) { curl_setopt($ch, CURLOPT_SSLCERTTYPE, 'PEM'); curl_setopt($ch, CURLOPT_SSLCERT, $sslcert_path); curl_setopt($ch, CURLOPT_SSLKEYTYPE, 'PEM'); curl_setopt($ch, CURLOPT_SSLKEY, $sslkey_path); } $data = curl_exec($ch); curl_close($ch); return $data; } // xml转数组 private function xmlToArray($xml) { // 禁止引用外部xml实体 libxml_disable_entity_loader(true); $xmlString = simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA); $result = json_decode(json_encode($xmlString), true); return $result; } } ``` 其,$wxPayConfig是微信支付的配置信息,可以在config目录下的wxpay.php文件进行配置。 该示例仅供参考,实际使用时需要根据自己的业务需求进行相应的修改和完善。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值