优化你的PHP代码,从现在做起

小编 2026-06-12 阅读:344 评论:0
前言 我一生的文章都会放在这里,我的博客,我希望每一行代码,每一段文字都能帮助你。https://github.com/CrazyCodes/Blog 大家好,我是CrazyCodes ,今天我们不聊工具、规范等等等等的辅助,就聊一下该...

前言

我一生的文章都会放在这里,我的博客,我希望每一行代码,每一段文字都能帮助你。https://github.com/CrazyCodes/Blog

大家好,我是CrazyCodes ,今天我们不聊工具、规范等等等等的辅助,就聊一下该如何写一段“好”的代码,本文以我的职业生涯碰到的代码为例,如有出入请在评论区提出异议,谢谢。

搜索功能

搜索很常见,复杂的搜索大多出行在后台,举个栗子,大概需求是这样的

这是一个后台用户列表的搜索功能

搜索条件

可否并行

是否必填

用户名

可以

手机号码

可以

是否已认证

可以

用户性别

可以

最近登录时间

可以

账户余额

可以

初学者代码

看到这些例子你是否不由的一颤,又要开始造轮子的是不是? 以原生的例子为例,开始你可能会这样写(以下为伪代码)

if (IS_POST) {
    $like = '';
    if (isset($_POST['username'])) {
        $username = $_POST['username'];
        $like .= "username like '%" . $username . "%' and ";
    }

    if (isset($_POST['phone'])) {
        $phone = $_POST['phone'];
        $like .= "phone like '%" . $phone . "%' and";

    }

    if ($_POST['is_auth']) {
        $isAuth = $_POST['is_auth'];
        $like .= "is_auth like '%" . $isAuth . "%' and";

    }

    if ($_POST['sex']) {
        $sex = $_POST['sex'];
        $like .= "sex like '%" . $sex . "%' and";
    }


    if ($_POST['time']) {
        $time = $_POST['time'];
        $like .= "time like '%" . $time . "%' and";
    }


    if ($_POST['wallet']) {
        $wallet = $_POST['wallet'];
        $like .= "wallet like '%" . $wallet . "%' and";

    }

    $like = rtrim($like, 'and');

    $sql = "SELECT * FROM `user` WHERE {$like}";


} else {
    return view('user');
}

封装

恩…,还不错,结构清晰,传统的初学者条型代码,接下来我们先封装一下几块代码。

function post($param)
{
    return isset($_POST[$param]) ? $_POST[$param] : null;
}

if (IS_POST) {
    $like = '';
    if (post('username')) {
        $username = post('username');
        $like .= "username like '%" . $username . "%' and ";
    }

    if (post('phone')) {
        $phone = post('phone');
        $like .= "phone like '%" . $phone . "%' and";

    }

    if (post('is_auth')) {
        $isAuth = post('is_auth');
        $like .= "is_auth like '%" . $isAuth . "%' and";

    }

    if (post('sex')) {
        $sex = post('sex');
        $like .= "sex like '%" . $sex . "%' and";
    }


    if (post('time')) {
        $time = post('time');
        $like .= "time like '%" . $time . "%' and";
    }


    if (post('wallet')) {
        $wallet = post('wallet');
        $like .= "wallet like '%" . $wallet . "%' and";

    }

    $like = rtrim($like, 'and');

    $sql = "SELECT * FROM `user` WHERE {$like}";


} else {
    return view('user');
}

适当使用迭代

恩,至少我们可以自由控制post方法了,但是这类过程化代码维护性太低,我们再改进下

function post($param)
{
    return isset($_POST[$param]) ? $_POST[$param] : false;
}

function postAll()
{
    return $_POST;
}

if (IS_POST) {
    $like = '';


    foreach (postAll() as $key => $value) {
        if (post($key)) {
            $like .= "{$key} like '%{$value}%' and";
        }
    }

    $like = rtrim($like, 'and');

    $sql = "SELECT * FROM `user` WHERE {$like}";


} else {
    return view('user');
}

面向对象

加个迭代代码看起来还算是整洁了点,作为PHP程序员,写代码不面向对象不靠谱,把class加上

function request($param = null)
{
    return new Request($param);
}

class Request
{
    public function __construct(string $param = null)
    {
        return isset($_POST[$param]) ? $_POST[$param] : false;
    }

    public function all()
    {
        return $_POST;
    }
}


class User
{
    public function index()
    {
        if (IS_POST) {
            $like = '';

            foreach (request()->all() as $key => $value) {
                if (request($key)) {
                    $like .= "{$key} like '%{$value}%' and";
                }
            }

            $like = rtrim($like, 'and');

            $sql = "SELECT * FROM `user` WHERE {$like}";

        } else {
            return view('user');
        }
    }
}

对User的改造

我们在对User的类进行改造,做一些判断及筛选

function request($param = null)
{
    return new Request($param);
}

class Request
{
    public function __construct(string $param = null)
    {
        return isset($_POST[$param]) ? $_POST[$param] : false;
    }

    public function all()
    {
        return $_POST;
    }
}


class User
{
    public $request = [
        'username',
        'phone',
        'is_auth',
        'sex',
        'time',
        'wallet'
    ];

    public function index()
    {
        if (IS_POST) {
            $like = '';

            foreach (request()->all() as $key => $value) {
                if (in_array($key, $this->request) && request($key)) {
                    $like .= sprintf("%s like %s and", $key, $value);
                }
            }

            $like = rtrim($like, 'and');

            $sql = "SELECT * FROM `user` WHERE {$like}";

        } else {
            return view('user');
        }
    }
}

这就差不多了,对比真是的代码可能还相差甚远,我写这篇文章的目的不是教会你如何写代码,是想说明编码不是一次性的,应经过多次修改,使代码具有可维护性,扩展性等等的,各种“性”

致谢

感谢你看到这里,希望本篇文章可以帮到你,谢谢

版权声明

本文仅代表作者观点,不代表百度立场。
本文系作者授权百度百家发表,未经许可,不得转载。

热门文章
  • 机房智能化温湿度解决方式之POE供电以太网温湿度传感器

    机房智能化温湿度解决方式之POE供电以太网温湿度传感器
    机房智能化温湿度解决方式之POE供电以太网温湿度传感器 北京盈创力和电子科技有限公司 智能型TCP网口温湿度记录仪 北京IP网络温湿度记录仪厂家,北京盈创力和 北京智能型TCP网口温湿度记录仪IP网络温湿度记录仪是一种新型的基于TCP/IP协议双绞线以太网标准温湿度采集模块,利用它可以实现现场温度值、相对湿度值的采集,同时利用其自身的RJ45通信接口可以方便地和机房监控主机或交换机集线器进行联网。 工作于-40℃~85℃工业级带...
  • Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering

    Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering
    Problem Statement 我们考虑一个具有马尔可夫性质、非线性、非高斯的状态空间模型(State Space Model):对于一个时间序列上的观测结果{yt,t∈N}\\{ y_t , t \\in N \\}{yt​,t∈N},我们认为每个观测结果yty_tyt​的生成依赖于一个无法直接观察的隐变量xt∈{xt,t∈N}x_t \\in \\{x_t , t \\in N \\}xt​∈{xt​,t∈N},即:p(...
  • HTTP状态保持的原理

    HTTP状态保持的原理
    a)在用户登录之后,浏览器返回响应的时候会在响应中添加上cookieb)浏览器接收到cookie之后会自动保存c)当用户再次请求同一服务器中的其他网页的时候,浏览器会自动带上之前保存的cookied)服务接收到请求之后可以请 request 对象中取到cookie 判断当前用户是否登录  Http是无状态的,就是连接时数据互通,关闭后...
  • Hive 系统函数及示例

    Hive 系统函数及示例
    查看所有系统函数 show functions; 函数分类 内置函数【系统函数】 数学函数: floor、round、ceil、cos、log2等 字符串函数: length、reverse、trim、lower、get_json_object、repeat等 收集函数: size 转换函数: cast 日期函数: year、month、datediff、date、date_add等 条件函数: coalesce、case…w...
  • CSRF的原理和防范措施

    CSRF的原理和防范措施
    a)攻击原理:i.用户C访问正常网站A时进行登录,浏览器保存A的cookieii.用户C再访问攻击网站B,网站B上有某个隐藏的链接或者图片标签会自动请求网站A的URL地址,例如表单提交,传指定的参数iii.而攻击网站B在访问网站A的时候,浏览器会自动带上网站A的cookieiv.所以网站A在接收到请求之后可判断当前用户是登录状态,所以...
标签列表