7个鲜为人知却非常实用的PHP函数

这篇文章主要介绍了7个鲜为人知却非常实用的PHP函数,本文总结了如highlight_string()、str_word_count()、levenshtein()、get_defined_vars()、escapeshellcmd()等非常有用但不常见的函数,需要的朋友可以参考下

概述

PHP有着众多的内置函数,其中大多数函数都被开发者广发使用。但也有一些同样有用却被遗忘在角落,本文将介绍7个鲜为人知功能却非常酷的函数。

highlight_string()

当需要在网页中展示PHP代码时,highlight_string()函数就显得非常有用。该函数通过PHP内置定义的颜色,返回函数中代码的高亮显示版本,代码如下:

  1. <?php
  2. highlight_string('<?php echo "hello world" ; ?>');
  3. echo highlight_string('<?php echo "hello world" ; ?>',true);
  4. ?>

str_word_count()

这个函数可以方便的将输入的字符串参数中的单词个数返回,代码如下:

  1. <?php
  2. $str = "hello world";
  3. echo str_word_count($str); //输出 2
  4. ?>

levenshtein()

该函数可以方便的返回两个参数之间的levenshtein(编辑距离)。曾经遇到过一个需求,用户在编辑身份证的时候,限制用户只能修改4位数字,使用的就是这个函数,代码如下:

  1. <?php
  2. $idcard='230406198506206797';
  3. $newIdcard='230406198506207798';
  4. echo levenshtein($idcard,$newIdcard); //输出 2
  5. ?>

get_defined_vars()

这个函数在调试程序的时候非常有用,它会返回包含所有已定义变量的数组,其中包含环境、系统以及用户自定义变量,代码如下:

  1. <?php
  2. var_dump(get_defined_vars());
  3. ?>

escapeshellcmd()

该函数用来跳过字符串中的特殊符号,防止恶意用户耍花招破解服务器系统,可以搭配exec()与system()函数使用,代码如下:

  1. <?php
  2. $command = './configure '.$_POST['configure_options'];
  3. $escaped_command = escapeshellcmd($command);
  4. system($escaped_command);
  5. ?>

checkdate()

该函数可以用来检测日期参数的有效性,它可以验证输入的每一个参数的合法性,代码如下:

  1. <?php
  2. var_dump(checkdate(12, 31, 2000));
  3. var_dump(checkdate(2, 29, 2001));
  4. //输出
  5. //bool(true)
  6. //bool(false)
  7. ?>

php_strip_whitespace()

该函数会返回删除了注释与空格后的PHP源码,这对实际代码数量和注释数量的对比很有用,代码如下:

  1. <?php
  2. // 注释1
  3. /*
  4. * 注释2
  5. */
  6. echo php_strip_whitespace(__FILE__);
  7. do_nothing();
  8. ?>