PHP用正则匹配form表单中所有元素的类型和属性值实例代码


Posted in PHP onFebruary 28, 2017

前言

最近工作中遇到一个需求,需要在正则匹配页面中,所有可能存在的 form 表单的元素,可能有 input,action,select,textarea等等所有可能的元素,本文给出一个代码示例。感兴趣的朋友们可以参考学习。

实例代码如下

假设页面 1.html 的网页源代码是:

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8" />
 <title>一个含有 form 表单的登录注册页面</title>
 <style type="text/css">
 *{padding:0;margin:0;font-size:12px;}
 .tbl{margin:20px auto;border:1px solid #AACCEE;padding:30px 30px;border-radius:4px;}
 .tbl td{line-height:30px;vertical-align:top;}
 textarea{resize:none;height:60px;}
 </style>
 </head>
 <body>
 <form action="register.php" method="post">
 <input type="hidden" name="cookie" value="SJKjki80KJ8jkl2" />
 <table cellpadding="0" cellspacing="0" class="tbl"> 
 <tr>
 <th colspan="2">注册</th>
 </tr>
 <tr>
 <td>昵称:</td>
 <td><input type="text" name = 'name' required="" /></td>
 </tr>
 <tr>
 <td>密码:</td>
 <td><input name="password" type="password" required="required" /></td>
 </tr>
 <tr>
 <td>年龄:</td>
 <td><input name="age" value="22" required="required" ></td>
 </tr>
 <tr>
 <td>性别:</td>
 <td>
 <input type="radio" name="sex" value="1" /> 男
 <input type="radio" name="sex" value="0" /> 女
 </td>
 </tr>
 <tr>
 <td>地区:</td>
 <td>
 <select name="area">
 <option value="jiangsu">江苏</option>
 <option value="shandong">山东</option>
 <option value="fujian">福建</option>
 <option value="beijing">北京</option>
 </select>
 </td>
 </tr>
 <tr>
 <td>城市:</td>
 <td>
 <select name="city">
 <option value="qingdao">青岛</option>
 <option value="longyan">龙岩</option>
 <option value="beijing">北京</option>
 <option value="wuxi">无锡</option>
 </select>
 </td>
 </tr>
 <tr>
 <td>兴趣:</td>
 <td>
 <input type="checkbox" name="xingqu[]" value="1" > 篮球
 <input type="checkbox" name="xingqu[]" value="2"> 足球
 <input type="checkbox" name="xingqu[]" value="3" > 跳高
 </td>
 </tr>
 <tr>
 <td>照片:</td>
 <td><input type="file" name="photo" /></td>
 </tr>
 <tr>
 <td>简介:</td>
 <td><textarea name="summary" required="">这里填入个人简介</textarea></td>
 </tr>
 <tr>
 <td>备注:</td>
 <td><textarea name="remark" required="">1</textarea ></td>
 </tr>
 <tr>
 <td colspan="2"><input type="submit" name="register" value="注册"></td>
 </tr>
 </table> 
 </form>
 <form action="login.php" method="post">
 <table cellpadding="0" cellspacing="0" class="tbl">
 <tr>
 <th colspan="2">登录</th>
 </tr>
 <tr>
 <td>昵称:</td>
 <td><input type="text" name = 'name' required="required" /></td>
 </tr>
 <tr>
 <td>密码:</td>
 <td><input name="password" type="password" required="required" /></td>
 </tr>
 <tr>
 <td>备注:</td>
 <td><textarea name="remark" required="">2</textarea></td>
 </tr> 
 <tr>
 <td colspan="2"><input type="submit" name="register" value="登录"></td>
 </tr>
 </table> 
 </form> 
 </body>
</html>

我们需要获取到这个页面所有 form 表单,及每个 form 表单所包含的各类表单元素,例如:input,select,textarea等等。

匹配的源代码是:

$content = file_get_contents('1.html');
$arr_form = get_page_form_data($content);
if(empty($arr_form))
{
 echo '抱歉!未匹配到 form 表单元素';
}else
{
 foreach($arr_form as $k => $v)
 {
 echo 'form'.($k+1).':<br />';
 if(!empty($v['action']))
 {
 echo '----action:<br />';
 echo '--------'.$v['action'].'<br />';
 }
 if(!empty($v['method']))
 {
 echo '----method:<br />';
 echo '--------'.$v['method'].'<br />';
 } 
 if(!empty($v['inputs']))
 {
 echo '----inputs:<br />';
 foreach($v['inputs'] as $key => $value)
 {
 echo '--------name:'.$value['name'].' type:'.$value['type'].' value:'.$value['value'].'<br />';
 }
 } 
 if(!empty($v['textarea']))
 {
 echo '----textarea:<br />';
 foreach($v['textarea'] as $key => $value)
 {
 echo '--------name:'.$value['name'].' value:'.$value['value'].'<br />';
 }
 } 
 if(!empty($v['select']))
 {
 echo '----select:<br />';
 for($m = 0;$m < count($v['select']);$m ++)
 {
 echo '--------name:'.$v['select'][$m]['name'].'<br />';
 if(!empty($v['select'][$m]['option']))
 {
 foreach ($v['select'][$m]['option'] as $key => $value) 
 {
 echo '------------value:'.$value.'<br />';
 }
 }
 }
 }
 }
}
// 获取页面中的 form 表单中的所有 input、textarea 元素中 name、value、type 等属性值
function get_page_form_data($content)
{
 $arr_form = array();
 $form = regular_form_tags($content);
 for($i = 0;$i < count($form[0]);$i ++)
 {
 $arr_form[$i]['action'] = regular_form_action($form[1][$i]);
 $arr_form[$i]['method'] = regular_form_method($form[1][$i]);
 $input = regular_input_tags($form[2][$i]);
 for($j = 0;$j < count($input[0]);$j ++)
 {
 $arr_form[$i]['inputs'][$j]['name'] = regular_input_name($input[0][$j]);
 $arr_form[$i]['inputs'][$j]['type'] = regular_input_type($input[0][$j]);
 $arr_form[$i]['inputs'][$j]['value'] = regular_input_value($input[0][$j]);
 }
 $textarea = regular_textarea_tags($form[2][$i]);
 for($k = 0;$k < count($textarea);$k ++)
 {
 $arr_form[$i]['textarea'][$k]['name'] = regular_textarea_name($textarea[$k]);
 $arr_form[$i]['textarea'][$k]['value'] = regular_textarea_value($textarea[$k]);
 }
 $select = regular_select_tags($form[2][$i]);
 for($l = 0;$l < count($select[0]);$l ++)
 {
 $arr_form[$i]['select'][$l]['name'] = regular_select_name($select[1][$l]);
 $option = regular_option_tags($select[2][$l]);
 for($n = 0;$n < count($option[$l]);$n ++)
 {
 $arr_form[$i]['select'][$l]['option'][$n] = regular_option_value($option[$l][$n]);
 } 
 }
 }
 return $arr_form;
}
// 正则匹配 form 标签
function regular_form_tags($string)
{ 
 $pattern = '/<form(.*?)>(.*?)<\/form>/si'; 
 preg_match_all($pattern,$string,$result);
 return $result;
}
// 正则匹配 form 标签的 action 属性值
function regular_form_action($string)
{
 $pattern = '/action[\s]*?=[\s]*?([\'\"])(.*?)\1/';
 if(preg_match($pattern,$string,$result))
 {
 return $result[2];
 }
 return null;
}
// 正则匹配 form 标签的 method 属性值
function regular_form_method($string)
{
 $pattern = '/method[\s]*?=[\s]*?([\'\"])(.*?)\1/';
 if(preg_match($pattern,$string,$result))
 {
 return $result[2];
 }
 return null;
}
// 正则匹配 input 标签
function regular_input_tags($string)
{
 $pattern = '/<input.*?\/?>/si'; 
 if(preg_match_all($pattern,$string,$result))
 {
 return $result; 
 }
 return null;
}
// 正则匹配 input 标签的 name 属性值
function regular_input_name($string)
{
 $pattern = '/name[\s]*?=[\s]*?([\'\"])(.*?)\1/';
 if(preg_match($pattern,$string,$result))
 {
 return $result[2];
 }
 return null;
 
}
// 正则匹配 input 标签的 type 属性值
function regular_input_type($string)
{
 $pattern = '/type[\s]*?=[\s]*?([\'\"])(.*?)\1/';
 if(preg_match($pattern,$string,$result))
 {
 return $result[2];
 }
 return null;
}
// 正则匹配 input 标签的 value 属性值
function regular_input_value($string)
{
 $pattern = '/value[\s]*?=[\s]*?([\'\"])(.*?)\1/';
 if(preg_match($pattern,$string,$result))
 {
 return $result[2];
 }
 return null; 
}
// 正则匹配 textarea 标签
function regular_textarea_tags($string)
{
 $pattern = '/(<textarea.*?>.*?<\/textarea[\s]*?>)/si'; 
 if(preg_match_all($pattern,$string,$result))
 {
 return $result[1];
 }
 return null;
}
// 正则匹配 textarea 标签的 name 属性值
function regular_textarea_name($string)
{
 $pattern = '/name[\s]*?=[\s]*?([\'\"])(.*?)\1/si'; 
 if(preg_match($pattern,$string,$result))
 {
 return $result[2];
 }
 return null;
}
// 正则匹配 textarea 标签的 name 属性值
function regular_textarea_value($string)
{
 $pattern = '/<textarea.*?>(.*?)<\/textarea>/si'; 
 if(preg_match($pattern,$string,$result))
 {
 return $result[1];
 }
 return null;
}
// 正则匹配 select 标签
function regular_select_tags($string)
{
 $pattern = '/<select(.*?)>(.*?)<\/select[\s]*?>/si';
 preg_match_all($pattern,$string,$result);
 return $result;
}
// 正则匹配 select 标签的 option 子标签
function regular_option_tags($string)
{
 $pattern = '/<option(.*?)>.*?<\/option[\s]*?>/si';
 preg_match_all($pattern,$string,$result);
 return $result; 
}
// 正则匹配 select 标签的 name 属性值
function regular_select_name($string)
{
 $pattern = '/name[\s]*?=[\s]*?([\'\"])(.*?)\1/si';
 if(preg_match($pattern,$string,$result))
 {
 return $result[2];
 }
 return null;
}
// 正则匹配 select 的子标签 option 的 value 属性值
function regular_option_value($string)
{
 $pattern = '/value[\s]*?=[\s]*?([\'\"])(.*?)\1/si';
 if(preg_match($pattern,$string,$result))
 {
 return $result[2];
 }
 return null;
}

运行效果如下图所示:

PHP用正则匹配form表单中所有元素的类型和属性值实例代码

PHP用正则匹配form表单中所有元素的类型和属性值实例代码

这样我们就可以实现获取任意一个页面中的 form 表单所有存在的元素啦!

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者使用PHP能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

PHP 相关文章推荐
Mysql的GROUP_CONCAT()函数使用方法
Mar 28 PHP
PHP 自定义错误处理函数的使用详解
May 10 PHP
php中strstr、strrchr、substr、stristr四个函数的区别总结
Sep 22 PHP
PHP中执行cmd命令的方法
Oct 11 PHP
php面向对象中static静态属性与方法的内存位置分析
Feb 08 PHP
PHP使用ODBC连接数据库的方法
Jul 18 PHP
PHP异常处理Exception类
Dec 11 PHP
浅谈php中fopen不能创建中文文件名文件的问题
Feb 06 PHP
PHP PDOStatement::rowCount讲解
Feb 01 PHP
PHP fopen函数用法实例讲解
Feb 15 PHP
关于laravel 子查询 &amp; join的使用
Oct 16 PHP
PHP的new static和new self的区别与使用
Nov 27 PHP
PHP中让json_encode不自动转义斜杠“/”的方法
Feb 28 #PHP
PHP连接MYSQL数据库的3种常用方法
Feb 27 #PHP
php获取今日开始时间和结束时间的方法
Feb 27 #PHP
php+mysql+jquery实现日历签到功能
Feb 27 #PHP
php查找字符串中第一个非0的位置截取
Feb 27 #PHP
php实时倒计时功能实现方法详解
Feb 27 #PHP
php自定义截取中文字符串-utf8版
Feb 27 #PHP
You might like
用PHP产生动态的影像图
2006/10/09 PHP
php不使用插件导出excel的简单方法
2014/03/04 PHP
php实现encode64编码类实例
2015/03/24 PHP
PHP实现添加购物车功能
2017/03/06 PHP
php中用unset销毁变量并释放内存
2020/05/10 PHP
用jquery和json从后台获得数据集的代码
2011/11/07 Javascript
基于jquery的图片幻灯展示源码
2012/07/15 Javascript
Lab.js初次使用笔记
2015/02/28 Javascript
JavaScript中Null与Undefined的区别解析
2015/06/30 Javascript
JS基于Ajax实现的网页Loading效果代码
2015/10/27 Javascript
jQuery事件委托之Safari
2016/07/05 Javascript
Vue2.x中的父组件传递数据至子组件的方法
2017/05/01 Javascript
详解Vue.js Mixins 混入使用
2017/09/15 Javascript
jQuery完成表单验证的实例代码(纯代码)
2017/09/30 jQuery
微信小程序使用image组件显示图片的方法【附源码下载】
2017/12/08 Javascript
JS 正则表达式验证密码、邮箱格式的实例代码
2018/10/28 Javascript
详解使用React.memo()来优化函数组件的性能
2019/03/19 Javascript
ES6知识点整理之模块化的应用详解
2019/04/15 Javascript
Javascript Symbol原理及使用方法解析
2020/10/22 Javascript
解决vue安装less报错Failed to compile with 1 errors的问题
2020/10/22 Javascript
详解Vue的mixin策略
2020/11/19 Vue.js
Python实现遍历数据库并获取key的值
2015/05/17 Python
解决tensorflow1.x版本加载saver.restore目录报错的问题
2018/07/26 Python
python 多个参数不为空校验方法
2019/02/14 Python
解决python3.x安装numpy成功但import出错的问题
2020/11/17 Python
HTML5之WebGL 3D概述(下)—借助类库开发及框架介绍
2013/01/31 HTML / CSS
美国运动鞋和服装网上商店:YCMC
2018/09/15 全球购物
Craghoppers德国官网:户外和旅行服装
2020/02/14 全球购物
领导干部培训感言
2014/01/23 职场文书
个人欠款担保书
2014/05/20 职场文书
组织鉴定材料
2014/06/02 职场文书
后进生评语大全
2015/01/04 职场文书
不同意离婚代理词
2015/05/23 职场文书
运动会报道稿大全
2015/07/23 职场文书
Android使用EventBus发送消息,Fragment中接收消息的方法会执行多次
2022/04/24 Java/Android
Mysql中的触发器定义及语法介绍
2022/06/25 MySQL