OOP(面向对象编程)
是object oritended programming 缩写。
具有灵活性,可维护性。
三个目标:重用性,灵活性,可扩展性
特点: 封装,继承,多态
特性: 对象行为 对象状态 对象标识 相同对象行为和对象状态的具有不同标识
类
是具有属性和方法对象的抽象
成员属性 成员方法
class 类名{
行为属性 修饰符$属性名=属性值;//属性值也可以不加
//行为方法
修饰符function 方法名(参数){
主体
return 返回值
}
}
类的实例化就是对象
$变量名=new 类名();//创建出一个对象$变量名
同一个类可以new出多个不同的对象,而且所有的对象都是独立,里面的成员属性和方法不会共享
$this 特殊引用 代表的是本对象,而且只能成员方法里面访问对象的属性
-> 调用成员属性和成员方法
魔术方法
1、构造函数
实例化对象的时候,自动调用这个构造函数 ,目的是初始化属性值
function __construct(){
函数主体
}
2、析构函数
对象被销毁前,会自动会调用析构方法
function __destruct()
函数主体
}
当对象被销毁之前,自动调用析构函数(注意析构方法是没有任何参数的)
3、__get 在非公有属性输出的时候,会自动的调用__get方法
4、__set在 非公有属性赋值的时候,会自动的调用__set方法
5、__unset 销毁一个对象的私有或受保护的属性时,自动调用此方法,并将属性名以第一个参数传进去
6、 __isset 判断一个对象的私有或受保护的属性是否存在时,会自动调
7、__clone 当对象克隆的时候,会自动调用__clone()方法
普通的对象 类似于数组,常量等等
特殊的对象 一个对象含有子对象和资源
8、 __toString 当输出对象的时候,会自动调用__toString()这个方法,返回的是字符串 括号里面是没有任何参数的
9、__call当输出一个不存在的成员方法,自动的调用__call()方法 __call(不存在方法名,参数);
10. __autoload 当实例化一个不存在的类的时候,自动的调用__autoload();
11. __sleep 当串行化的时候自动的调用__sleep()方法
12. __wakeup当反串行化的时候自动调用__wakeup()方法
13. serialize 串行化 在网络中传输对象数据的时候,向数据库中保存文件的时候
14. unserialize 反串行化 PHP串行化可以把变量包括对象,转化成连续bytes数据,你可以将串行化后的变量存在一个文件里或在网络上传输,然后再反串行化还原为原来的数据。
为什么要使用串行化:
1)数据通信,不同的站点之间的数据通信,例如A站点去取B站点的某些数据,返回数据用serialize后作为字符串传输,接收方unserialize一下即可还原成实际的数据
2)数据存储,同样的,也是为了作为字符串,将变量的值存储到 文件/数据库 里面,当需要用到的时候取出来处理一下即可
总结一下:serialize的主要作用是为了数据共享和传输,将一些数据共享给其他文件或者站点
封装
就是在类的成员方法和成员属性前面,加上类似于 public private protected 修饰符,目的是尽量的隐藏对象的内部细节,目的是达到访问控制(记住不是拒绝访问)
修饰符:
public 公有的
private 私有
protected 受保护的
在类的外部的访问范围:
在类的外部可以访问公有属性和方法
在类的外部不可以访问私有属性和方法
在类的外部不可以访问受保护属性和方法
在类的内部的访问范围:
在类的内部都可以访问公有的,私有的,受保护的属性和方法
setName getName 私有属性提供公有的方法
继承
在现实生活里 子承父业 类里面,子类继承过来的是所有属性和方法 extends 单继承类
一个子类只能有一个父类,一个父类可以有多个子类,一个子类不可以有多个父类在子类里面不可以访问私有的属性和方法,可以访问公有属性和方法,可以访问受保护的属性和方法 覆盖
在子类中定义一个和父类相同方法相同属性,父类的此方法和属性会被覆盖 扩展 在子类里面定义一个新增加的方法或者属性,就叫做扩展
parent::父类的被覆盖的方法名()来访问这个被覆盖的父方法final 修饰类和方法 修饰的类不能被子类继承 修饰的方法不能被子类覆盖(重用)
static 修饰成员方法和属性 也叫静态方法 就是在类的外部不去实例化的时候,取到对象的数据 类名::属性名或者是方法 self::
代替$this 去访问属性和方法
const 用来定义常量
const是一个在类中定义常量的关键字,我们都知道在PHP中定义常量使用的是”define()”这个函数,但是在类里面定义常量使用的是”const”这个关键字
const只能修饰的成员属性(常量属性),其访问方式和static修饰的成员访问的方式差不多,也是使用”类名”,在方法里面使用”self”关键字。但是不用使用”$”符号,也不能使用对象来访问。
const CONSTANT =‘constant value’; //定义
echo self::CONSTANT; //类内部访问
echo ClassName::CONSTANT; //类外部访问
instanceof 用来检测实例对象是否属于某一个类
抽象类和接口
抽象类:
当类中有一个方法,他没有方法体,也就是没有花括号,直接分号结束。
如 public abstract function fun();
象这种方法我们叫抽象方法,必须使用关键字abstract定义,
包含这种方法的类必须是抽象类也要使用关键字abstract加以声明.
抽象类的特点:
不能实例化,也就new成对象
若想使用抽象类,就必须定义一个类去继承这个抽象类,并定义覆盖父类的抽象方法(实现抽象方法)。含有抽象方法的类肯定是抽象类,但是不是所有的抽象类都必须包含抽象方法。
接口:
假如一个抽象类中所有的方法都是抽象的,那么我们可以使用另外一种方式定义:接口
接口使用关键字interface来定义,接口中只能有常量与抽象方法。
格式:
interface 接口名{
[常量定义]
[抽象方法定义] //注意不要有abstract关键字
}
在接口里面只能有常量和抽象方法实现方式:class 类名 implements 接口名,接口名2{
实现体….
}
3.抽象类和接口的区别?
(1)对接口的使用方式是通过关键字implements来实现的,而对于抽象类的操作是使用类继承的关键字extends实现的,使用时要特别注意。
(2)接口没有数据成员,但是抽象类有数据成员,抽象类可以实现数据的封装。
(3)接口没有构造函数,抽象类可以有构造函数。
(4)接口中的方法都是public类型,而抽象类中的方法可以使用private、protected或public来修饰。
4.多态
*多态(使用方式):对于同一个方法,传入不同对象,实现了不同的效果,这个就是多态的意思,
需要使用的技术:继承或实现,方法的覆盖(重写)。
异常处理
异常(Exception)处理用于在指定的错误发生时改变脚本的正常流程。是PHP5中的一个新的重要特性。
异常处理是一种可扩展、易维护的错误处理统一机制,并提供了一种新的面向对象的错误处理方式。
异常处理格式:
try{
使用try去包含可能会发生异常的代码.
一旦出现异常try进行捕获异常,交给catch处理。
抛出异常语句:throw 异常对象。
}catch(异常对象参数){
在这里做异常处理。
}
在php5中有一种新的错误处理机制–异常处理:(采用面向对象方式的)
对象函数
1、class_alias — 为类创建一个别名
class_alias("Stu","Demo"); //为类Stu起来一个别名Demo
$s = new Demo();
var_dump($s);
2、class_exists — 检查类是否已定义
先判断stu类是否存在,然后再执行
if(class_exists("Stu")){
$s2 = new Stu();
}
3、get_class_methods — 返回由类的公共方法名组成的数组
获取Stu类中的所有方法(公有)
var_dump(get_class_methods("Stu"));
//array(1) { [0]=> string(6) "getAge" [1]=> string(7) "getName" }
echo "<hr/>";
4、get_class_vars — 返回由类的默认公有属性组成的数组
var_dump(get_class_vars("Stu"));
//array(1) { ["name"]=> string(8) "zhangsan" }
echo "<hr/>";
5、get_class — 返回对象的类名
echo "s2对象的类名:".get_class($s2);
echo "<hr/>";
6、method_exists — 检查类的方法是否存在
//判读方法是否存在
if(method_exists($s2,"getAge")){
echo $s2->getAge();
}
7、property_exists — 检查对象或类是否具有该属性
if(property_exists($s2,'name')){
echo $s2->name;
}
8、is_a — 如果对象属于该类或该类是此对象的父类则返回 TRUE
echo "<hr>";
if(is_a($s2,'Stu')){
echo "对象属于该类";
}
PDO
php data object,为php访问数据库定义了轻量级的、一致性的接口,它提供了一个数据库访问抽象层,这样,无论你使用什么数据库,都可以通过一致的函数执行查询和获取数据,大大简化了数据库的捉拿和,并能够屏蔽不同数据库之间的差异,使用pdo可以很方便地进行跨数据库程序的开发,以及不同数据库间的移植,是将来php在数据库处理方面的主要发展方向,它可以支持mysql,oracle,mssql等多种数据库.
选择PDO的原因:跨数据库,带预处理(防sql注入)、支持事务操作.
PDO的环境配置:
开启支持PDO
WINDOWS :在php.ini配置文件中开启:
extension=php_pdo.dll
extension=php_pdo_mysql.dll
Linxu:在php程序目录(/usr/local/php/)下配置/etc/php.ini
extension=”pdo.so”;
extension=”pdo_mysql.so”; //如果该文件不存在,需要在php安装目录下编辑并安装
PDO对象:
PDO
PDOStatement(预处理对象)
PDOException(异常)
PDO类的方法::
错误处理模式方法
*PDO::ATTR_ERRMODE=>错误处理模式:(可以是以下三个)
PDO::ERRMODE_SILENT:不报错误(忽略)(0)
PDO::ERRMODE_WARNING:以警告的方式报错(1) *PDO::ERRMODE_EXCEPTION:以异常的方式报错(推荐使用)。(2)
Pdo连接数据库
$pdo=new PDO("mysql:host=localhost;dbname=DBNAME","USER","PWD");
开启错误处理模式
$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
其他方法
1. query($sql); 用于执行查询SQL语句。返回PDOStatement对象
2. exec($sql); 用于执行增、删、改操作,返回影响行数;
3. setAttribute(); 设置一个"数据库连接对象"属性。
4. beginTransaction 开启一个事物(做一个回滚点)
5. commit 提交事务
6. rollBack 事务回滚操作。
7. errorCode 获取错误码
8. errorInfo 获取错误信息
9.lastInsertId 获取刚刚添加的主键值.
10.prepare 创建SQL的预处理,返回PDOStatement对象
预处理对象PDOStatement对象:
我们可以通过PDO的方法来获取PDOStatement:
1.PDO的query(查询sql)方法获取,用于解析结果集
2.PDO的prepare(SQL)方法获取,用于处理参数式sql并执行操作。
PDOstatement对象的方法:
1、fetch() 返回结果集的下一行,结果指针下移,到头返回false 。
参数: PDO::FETCH_BOTH (default)、:索引加关联数组模式
PDO::FETCH_ASSOC、 :关联数组模式
PDO::FETCH_NUM、 :索引数组模式
PDO::FETCH_OBJ、 :对象模式
PDO::FETCH_LAZY :所有模式(SQL语句和对象)
2、fetchAll() 通过一次调用返回所有结果,结果是以数组形式保存
参数:
PDO::FETCH_BOTH (default)、
PDO::FETCH_ASSOC、
PDO::FETCH_NUM、
PDO::FETCH_OBJ、
PDO::FETCH_COLUMN表示取指定某一列
如:$rslist = $stmt->fetchAll(PDO::FETCH_COLUMN,2);取第三列
3、execute() 负责执行一个准备好了的预处理语句
4、rowCount() 返回使用增、删、改、查操作语句后受影响的行总数
5、setAttribute()为一个预处理语句设置属性
6、errorCode() 获取错误码
7、errorInfo() 获取错误信息
8、bindParam() 将参数绑定到相应的查询占位符上
9、bindValue() 将一值绑定到对应的一个参数中
防sql语句注入的两种方法:
在PDO中参数式的SQL语句有两种(预处理sql):
insert into stu(id,name) value(?,?); //?号式(适合参数少的)
insert into stu(id,name) value(:id,:name); // 别名式(适合参数多的)
在PDO中为参数式SQL语句赋值有三种:
1.使用数组
$stmt->execute(array("lamp1404","qq2"));
$stmt->execute(array("id"=>"lamp1404","name"=>"qq2"));
2.使用方法单个赋值
$stmt->bindValue(1,"lamp1901");
$stmt->bindValue(2,"qq2");
$stmt->execute();
$stmt->bindValue(":id","lamp1901",PDO::PARAM_STR); //带指定类型
$stmt->bindValue(":name","qq2",PDO::PARAM_STR);
$stmt->execute();
- 使用方法绑定变量
$stmt->bindParam(":id",$id);
$stmt->bindParam(":name",$name);
$id="lamp1401";
$name="qq2";
$stmt->execute();