有三个类:
1 . 过滤输入(轻量级的)
class input_filter
负责将参数,如$_get,$_post 这些过滤
返回值类型为 数组,用作 made_sql 类的参数
2 . 转换成sql语句
class made_sql
参数的类型为数组和表名(字符串),数组的键名为表的列名,值为插入值
返回值类型为 字符串 ,用作 mysql ->query方法 的参数
3 . 数据库查询
class mysql
用到了单列模式,用静态方法来获取对象,具体参看 instanceof操作符的作用
复制代码 代码如下:
class input_filter
{
private $input_all; // 要过滤的数组
private $rustle; // 过滤后的结果
//构造函数 参数可以是$_get or $_post 这些
public function __construct($input_c)
{
if(is_array($input_c))
$this->input_all = $input_c ;
else
echo 'parameter is not valid';
//初始化,不然后面第一次合并数组php不知道这是什么类型
$this->rustle = array();
}
private function filter_arr() // 主函数
{
foreach ($this->input_all as $key_input => $val_input)
{
//如果键名不是字符串,那么返回错误信息
// for key
if(!is_string($key_input)) // error
{
echo 'this key is not string';
return false;
}
// the # is mysql note .
$key_one = str_replace('#','',$key_input);
$key = htmlspecialchars($key_one,ent_quotes,'utf-8');
// 我没找 # 的html转义符,所以用空代替
$val_one = str_replace('#','',$val_input);
// 这个函数只转化 ' " ,还有个类似函数会转义所有符号
$val = htmlspecialchars($val_one,ent_quotes,'utf-8');
// merger
$rustle_one = array($key=>$val);
//合并数组
$this->rustle = array_merge($this->rustle,$rustle_one);
}
}
//这个函数有点多余,留下以后扩展用
public function get_filter_rustle()
{
$this->filter_arr();
return $this->rustle ;
}
}
调用方法:
复制代码 代码如下:
$filter = new filter_input($_get) ; // or $_post
$input_data = $filter->get_filter();
转换成sql语句:
复制代码 代码如下:
class madesql
{
private $cnow_ary; // type array 传入的参数
private $cname_str;
private $insert_sql; //最终的sql语句 string type
public function __construct($cary,$cname)
{
//检查传入参数类型是否为数组
if (! is_array($cary))
return false;
else
$this->cnow_ary = $cary; // 写入的值
$this->cname_str = $cname; // 数据库表名称
25 }
private function setsql() // 主函数 ,生产sql语句
{
foreach ( $this->cnow_ary as $key_ary => $val_ary )
{
$cols_sql = $cols_sql.','.$key_ary; //列名组合
$vals_sql = $vals_sql.', \''.$val_ary.'\'' ; //值 组合
}
// 因为前面foreach的算法有点问题,第一个字符是逗号
// 所以用sunstr_replace()删除 ,自第一位起(0),只替换一个字符(1)
$cols_sql = substr_replace($vals_sql,'',0,1);
$vals_sql = substr_replace($vals_sql,'',0,1);
$this->insert_sql =
'insert into '.$this->cname_str.' ( '
.$cols_sql.' ) values ( '.$vals_sql.' )'; // 语句成型
}
//扩展用
public function getsql()
{
$this->setsql();
return $this->insert_sql;
}
}
3 . 数据库查询
数据库查询类是参照书上的单列模式(用静态方法获取对象,这样在一个脚本里只有一个数据库查询类的实例)
我想单例模式用于这个类还是有点用的
复制代码 代码如下:
class mysql
{
private $connect;
static $objectmysql; // 存放对象
private function __construct() 7 {
// 创建对象的时候这个构造函数会被调用,用来初始化
$connect = mysql_connect('db address','password','dbname');
$this->db = mysql_select_db('db',$connect);
}
public static function mysql_object()
{
//instanceof 操作符用于检查对象是否属于某个类或者接口的实例。我说的不是很规范...
//如果$objectmysql不是mysql(self)的实例,那么就创建一个
if(! self::$objectmysql instanceof self)
self::$objectmysql = new mysql();
//这时候的$objectmysql就已经是一个对象
return self::$objectmysql;
}
public function query($sql)
{
return mysql_query($sql,$this->db);
}
}
all right ,归纳一下使用方法
复制代码 代码如下:
$filter = new filter_input($_get) ; // or $_post
$input_data = $filter->get_filter();
$madesql = new madesql($input_data,'tablename');
$sql = $madesql->getsql();
$mysql = mysql::mysql_object() ;
if( $mysql->query($sql) )
echo 'ok';
else
echo 'failure';
只需要这几行调用代码即可以完成写入数据库的操作
另外再说一下构造函数的私有公有问题,书上的mysql单例模式中构造函数是声明为了private ,而没有单例模式的类如此则会产生编译错误,即 php 不能创建一个对象 ,查了下。
原因在于创建对象往往在类外面进行,这样就产生了无法访问构造函数的问题。 而单列模式是在自身类中创建对象,因此访问private方法没有限制。
原先以为单例模式只是防止创建相同的对象,现在看来单例模式可以将构造函数封装起来,确实提高了安全性
filter_input类 的结果可以直接用作 madesql类 的参数的 前提是 :
表单的name必须和数据库的列名相同,否则你就白看这么多
0
0
相关文章
php怎么处理大数据量绘图表_php分页查数据绘散点图【技巧】
php获取本机ip与hostname关联吗_php通过hostname取ip【技巧】
php修改权限提示invalidargument_php参数非法修正【技巧】
php微信小程序数据缓存怎么弄_php配合缓存提升性能【技巧】
php判断字符串长度含零宽字符_php零宽字符处理法【步骤】
相关标签:
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。
391
2026.01.28
本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。
135
2026.01.28
AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。
233
2026.01.28
本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。
8
2026.01.28
本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。
10
2026.01.28
本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。
24
2026.01.27
在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。
124
2026.01.26
在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。
98
2026.01.26
热门下载
精品课程
最新文章


