标签:
HTTP协议:超文本传输协议,b/s架构项目遵循的基本协议,浏览器服务器通信的基本原理(请求连接(TCP/IP协议),连接成功,浏览器发送请求,服务器处理请求,浏览器处理结果,关闭连接),HTTP协议两部分(请求,响应),url,特点(支持客户/服务器模式,简单快速[只需请求方法和路径],灵活[任意数据],无连接[每次连接只处理一个请求],无状态[事务处理没有记忆能力])
HTTP请求:四部分(请求行,请求头,空行,请求主体),请求行(请求方式,请求文件,协议/版本),请求头(host,accept-encoding,referer,connection,accept-language,cookie,user-agent,accept,content-length(post),if-modified-since(get),content-type(post)),空白行,请求主体(post请求数据),telnet模拟请求
HTTP响应:四部分(状态行,响应头,空行,响应主体),状态行(协议/版本,状态码,状态说明),响应头(server,date,last-modified,content-length,content-type,location,refresh,content-encodeing,cache-control),空行,响应主体(内容),header之前不能输出,header设置cookie
函数调用前不能输出的函数:session_start,setcookie,header,output_buffering
常用回应状态信息:1XX(服务器接收请求,继续处理),2XX(成功,200),3XX(重定向,302重定向,304没有修改),4XX(请求错误,404找不到,403禁止),5XX(服务器错误,502无效响应)
PHP模拟响应和请求:响应(跳转,刷新,发送图片,下载(application/octet-stream,content-disposition:attachment;filename),请求(fsockopen,fwrite,feof,fgets,get请求,post请求)
面向对象:面向过程(操作流程)和面向对象(操作主体),oop(一种软件设计架构思想)
基本概念:类(对象的抽象),对象(类的实例化/类类型(自定义数据类型)),实例化,成员(类中的变量,函数,常量)
语法操作:定义类(class),实例化(new,带括号,不带括号),强制转换(object),stdClass(空类),访问修饰限定符(var,public,protected,private,区别),对象访问成员(->),类中成员只有三个(属性,方法和常量,不能echo),属性定义的值必须是固定值,如何访问私有属性(方法,$this)
内存说明:类,对象,方法,属性(从空间使用上划分,非内存划分)
魔术方法:构造方法(初始化),析构方法(释放资源,unset对象),构造方法私有化
构造方法兼容:类名方法
大小写区分:属性,数组下标和变量
对象传递:引用传递
对象比较:==(同类对象且属性值相同),===(同一对象)
DB类:类文件命名(类名.class.php)
作业:封装getAll和getRow方法
自动加载:实例化对象前必须有类定义,自动加载(__autoload),自动加载原理,自动加载冲突(spl_autoload_register)
类常量:定义(const),内存划分,访问(类访问,范围解析操作符,对象访问(方法)),self关键字,self和this区别,魔术常量(__CLASS__,__METHOD__)
静态成员:定义(static),属性,方法,访问(范围解析操作符),静态属性与常量的访问区别
对象计数器制作:思路
静态方法与非静态方法区别($this)
魔术方法:__toString()(echo对象),__clone()(复制成不同对象,克隆不走构造方法,阻止克隆(private))
单例模式:概念(一个类只有一个对象),原因(省资源),原理(三私一公)
工厂模式:概念(产生对象),原因(方便管理),工厂单例模式
面向对象不一定有类(js)
Oop三大特性:封装,继承,多态
封装:数据和数据操作,制作类的过程,隐藏对象的属性和实现细节(私有化),对外提供使用接口(限制读和写)
继承:一个对象直接使用另一个对象的属性和方法,减少代码的重复性
多态:接口的多种不同的实现方式,PHP中没有
继承:语法(extends),继承原理,继承成员控制(protected),继承访问(子类访问父类,父类访问子类)
继承冲突:重写,控制级别(子类弱于父类),访问父类同名方法(parent)
PHP单继承,链式继承(多继承),继承的使用(表类继承DB类)
特殊类:不能被继承的类和只能被继承的类,final类,final方法(可以被继承但不能别重写),abstract类(不能实例化),abstract方法
项目设计:项目大,团队多(接口规范,抽象类规范),项目小(不使用)
接口:专门规定类的结构,语法(interface),接口体(常量和方法,不能实现方法,只能public),实现接口(implements),子类必须实现接口所有方法,实现多个接口
面试题:PHP是否支持多继承?如何模拟?接口是不是类?接口是不是抽象类?
PHP重载:用户操作不存在或者不可用的成员属性或者方法时的处理
属性重载:__get(),__set(),__isset()(isset和empty时调用),__unset()(unset调用)
方法重载:__call(),__callStatic()
重载意义:限定用户操作的条件,纠错
对象保存与还原:file_put_contents保存,file_get_contents获取,对象不能直接保存
序列化:serialize
反序列化:unserialize,PHP_Incomplete_Class,得不到原对象原因(资源释放),引入类文件即可得到原对象,自动加载类,数据库连接失效
对象保存与还原:__wakeup(),__sleep(),数组保存
对象判断:instanceof,继承对象同属于子类和父类
对象涉及方法:class_exists,interface_exists,method_exists,get_class(得到对象类名),get_parent_class(得到父类名)
对象遍历:属性遍历,常规foreach遍历,类内foreach遍历($this),类内具体属性遍历(iterator预定义接口)
【PDO】:PDO,功能(方便移植),原理,配置(扩展)
PDO主要类:PDO(数据库连接,sql传输),PDOStatement(结果集,预处理),PDOException(PDO异常处理)
PDO类:构造函数(dsn数据源,用户名,密码),对象销毁(没有提供,unset,null),执行SQL(无结果集exec(增删改),lastInsertId;有结果集PDOStatement query),错误处理(errorCode,errorInfo)
PDOStatement类:相关函数(rowCount,columnCount),遍历结果集(fetch[FETCH_ASSOC,FETCH_NUM,FETCH_BOTH,FETCH_OBJ,FETCH_BOUND],bindColumn,fetchAll,fetchColumn,fetchObject,setFetchMode),预处理(prepare[prepare name from ‘语句?’,using],execute[array参数],bindParam[推荐,先绑定后赋值],bindValue[不推荐,先赋值后绑定,每次都要绑定]),事务处理(beginTransaction,commit,rollBack)
PDO属性设置:setAttribute,getAttribute,属性名与值(PDO::ATTR_AUTOCOMMIT(1,0),PDO::ATTR_CASE(PDO::CASE_LOWER,PDO::CASE_UPPER,PDO::CASE_NATURAL),PDO::ATTR_ERRMODE(PDO::ERRMODE_SILENT,PDO::ERRMODE_WARNING,PDO::ERRMODE_EXCEPTION),PDO::ATTR_PERSISTENT(TRUE,FALSE))
PDOException类:try-catch-throw
反射:reflection反射机制,反射(ReflectionClass::export(类)),反射类内部(new ReflectionClass(类),getConstants,getProperties,getMethods)
Ecshop安装:虚拟主机,gd库扩展,配置数据库,配置后台管理员,安装测试数据,访问后台
购物系统:仿造ecshop制作一个小型的商品管理与购物系统
功能:后台用户登录(表单,session,cookie,验证码),商品分类管理(无限极分类),商品管理(文件处理,缩略图,水印处理,分页,商品批量管理,所见即所得编辑器使用),时间允许(前台商品浏览,购物车动作,用户管理等)
设计项目:从项目管理者角度设计项目(项目架构(框架,源码,开发模式),代码结构(项目目录划分,功能划分)
当前流行开发模式:二次开发,框架开发
数据架构:数据大小,更新频率;两大数据库阵营(SQL,NOSQL),初级架构(表,表功能,表结构,表内数据关系)
前台和后台:前台(用户看,显示数据),后台(管理员看,管理数据),前后台按功能划分,美工和程序员按工作内容划分
项目目录结构,代码分部:项目分前台后台,admin为后台目录;前后台公共部分前台includes下,后台公共文件admin/includes,前后台都有默认访问入口index.php
项目代码设计:数据是核心,代码是访问和管理数据;数据存放在mysql里,PHP通过db.class.php访问数据库(includes下);逻辑与显示分开;公共功能用类封装(文件上传,图片处理,分页)
后台用户登录功能设计:登录表单(登录,验证码,退出,找回密码,记住密码),admin/templates/login.php,代码由简单到复杂;一类事务请求一个PHP文件(登录:admin/privilege.php)
后台项目初始化:运行环境(错误级别,错误显示),基本目录常量,配置文件系统,公共代码(自动加载函数,跳转等),admin/includes/init.php
Admin/includes/init.php:编码设置(header),目录常量(__DIR__,反斜杠处理,ROOT_DIR,ADMIN_DIR,INCLUDE_DIR,ADMIN_INCLUDE_DIR,ADMIN_TEMPLATE_DIR),5.3低版本目录常量(__FILE__)
配置文件系统:/config/config.php,数据库连接信息,二维数组(便于区分)
加载配置文件:admin/includes/init.php,配置文件目录常量,配置文件全局化($GLOBALS[‘config’])
运行环境设置:ini_set()(error_reporting,display_errors),错误级别关系
登录界面:从ecshop拿,js文件,image文件,css文件
登录功能:privilege.php实现,引入初始化文件,引入login.php文件,action(区分动作),if分支判断动作
用户登录表单设计:请求privilege.php,设计隐藏域act,$_REQUEST(GPC,request_order,variables_order)
验证用户信息:设计管理员表(库,表,字段(id,用户名,密码,注册时间,上次登录时间和IP)),插入一条数据,接收用户提交数据进行验证,数据库操作(使用DB类,每张表一个类(/includes/adminTable.class.php))
表类设计:继承db类,属性(table_name,fields)
验证调用表类:自动加载(/includes/function.php),初始化文件引入公共函数库,实例化表对象(传入数据库连接信息,连接数据库),修改实例化方式(db类中自动调用配置文件),使用用户名和密码验证用户(正确得到用户信息,错误返回FALSE),修改用户密码(md5加密)
工作原理分析:用户请求到得到验证结果
验证结果处理:界面跳转(PHP中header,js中document.location.href,HTML中refresh),创建跳转模板/admin/templates/redirect.php,跳转函数admin_redirect在/includes/function.php,privilege中调用跳转函数
验证用户是否登录:定义变量判断,get传参,会话数据
开启会话机制:默认关闭(php.ini的session.auto_start),session_start开启,$_SESSION(访问会话数据),session实现用户登录判断
Session原理:session_start()开启session并读取session文件内容到$_SESSION,脚本结束将$_SESSION内容写到session文件,然后释放$_SESSION变量
会话周期:浏览器关闭session失效,浏览器与服务器会话流程
Cookie会话技术:服务器在浏览器保存数据,cookie原理,session与cookie的区别
Cookie使用:设置cookie,获得cookie($_COOKIE和$_REQUEST),修改$_COOKIE(再次访问无效),cookie变量有效期,session失效原理,清除cookie(setcookie),cookie目录区分,cookie跨域,cookie变相保存数组
Session文件:存储(php.ini中session.save_path)
Cookie文件:浏览器指定的存储目录,IE和FF区别,FF查看cookie文件
Session登录判定:用户登录时session记录用户信息,index.php中判定session信息,初始化文件开启session
模拟session实现跨脚本
框架布局后台:使用ecshop后台布局,index.php
Index.php实现:与privilege.php处理方式一致,使用ecshop的模板
退出登录:清除session,跳转到privilege.php登陆页,top.php(target属性)
用户信息显示:$_SESSION,用户上次登录时间(登录后修改上次登录时间)
Session深入:$_SESSION只能是关联数组,session可以保存对象,session过期受cookie影响,session文件销毁(session_destroy,$_SESSION,setcookie),session分层(session.save_path,手动建立文件夹)
禁用cookie后session使用(其他方式让浏览器带sessionID),a标签自动携带sessionID(session.use_trans_id,session.use_only_cookie),PHP脚本传递(手动添加,session_id(),session_name())
项目退出:cookie失效
验证码:验证码意义(防恶意请求),原理(Completely Automated Public Turing Test to Tell Computers and Humans Apart (全自动区分计算机和人类的图灵测试),将验证码内容放到图片上),验证码流程(生成,保存到session中,添加到图片上,用户输入,验证),对比ecshop验证码
GD库:图像处理扩展,GD处理图片流程(创建图片资源(已有或者新建),操作图片(裁剪图片,修改图片,填充图片,缩略图,写验证码),保存或者输出,释放资源)
制作验证码:获得验证码内容,验证码写到session,验证码写到图片,验证码图片显示到表单
封装验证码类:复杂化验证码方法(背景颜色随机,文字颜色随机,添加像素点,添加干扰线)
项目应用验证码:请求动作获得验证码图片,验证用户登录时使用验证码,新增验证验证码方法(验证码类内),点击验证码图片更换验证码(js)
保存用户登录信息:cookie存储记录标识(用户ID),判断用户是否登录(判断session,判断cookie),增加通过用户ID获取用户信息方法,危险
制作商品分类:数据表设计(主键,分类名,排序,父ID),插入数据,category.php,商品分类列表界面,修改连接(menu),商品分类类,调用商品分类的方法,模板显示分类数据
无限极分类:原理(找顶级分类,找子分类),非递归实现(指定父分类),递归(递归点,递归出口),递归原理,缩进(层级标识),根据排序字段排序
构造表全名:表名,db类表前缀,db类中增加表名构造,表类中使用
给字段属性赋值:添加获得表结构方法(获得所有键,主键)
分类文件访问验证:将登录验证放到init.php,引入init.php文件验证,分离需要验证的请求(登录相关不需要验证,$_SERVER[‘SCRIPT_NAME’],basename(),dir_name())
分类操作:增加分类(新增表单,提交表单,处理表单数据,分类入库),分类指定上级分类,数组接收数据提交数据,删除分类(提示用户(js),判断分类是否可被删除(是否末级),删除分类)
编辑分类功能:流程(用户点击菜单进入编辑,显示分类数据,用户编辑操作,提交表单,处理编辑数据)
重封装通过id获取数据方法(重复,放到db类),表单添加隐藏分类ID
商品分类完成:没有商品数量,分类列表缓存(判断缓存,更新缓存),无限极分类缩放
商品管理:数据表设计(仿照ecshop),数据插入,goods.php,完善商品列表(菜单连接,动作处理,数据对象操作,列表模板,图标)
分页:流程(确定数据显示数量,确定页数,limit),分页跳转(首页,上一页,下一页,末页,数字页,下拉页)
项目分页:修改配置文件(每页显示数据条数),修改列表功能(页码,每页显示数目参数),修改列表功能(获得总记录数,数据,二维数组),修改调用列表功能
分页类:单独分页不含数据处理(参数),HTML(标签,ID)
删除商品:处理方法(回收站),增加删除标志(修改数据表),删除流程(确认(js),修改删除标志,修改列表功能,更新列表)
回收站操作:分页显示(配置文件,分页类使用),恢复
新增商品:流程(连接,动作,表方法,模板,选项卡功能)
插入功能重复:新增插入方法(db类,验证数组信息,数组拼凑SQL,返回插入结果),调用插入功能
文件上传:post,enctype(mutipart/form-data),$_FILES(专门接收文件数据,字段说明,错误说明(0没有问题,1超出大小,2超出大小,3部分上传,4没有上传,6没有临时文件夹,7文件写入临时文件夹出错)),文件上传原理(PHP服务端),移动临时文件(move_uploaded_file),文件验证(大小,类型,重命名,strrchar)
图片上传类:配置文件(上传大小,上传类型(字符串),上传路径),上传命名规则(不重复,保持原来后缀,易于识别(前缀)),文件上传流程(错误判断,文件大小判断,文件类型判断,重命名,是否上传成功,返回新文件名),文件处理失败商品仍上传(错误提示)
商品插入流程回顾:收集表单数据,设置初始值(点击量),上传文件判断,制作缩略图判断,调用模型,插入数据
制作缩略图:流程(获得图片资源(原始图,目标图),处理(采用,复制),保存或者输出,释放资源),采样(矩形区域确定)
封装缩略图制作:数据获取(原图大小,目标图大小,函数类型使用),缩略图比例(宽高比),缩略图制作流程细化(计算原图宽高和缩略图最大尺寸,确定缩略图大小,创建图片资源(原图,缩略图),采样复制,保存输出,销毁资源)
缩略图补白:缩略图大小固定(不够的地方补白,制作缩略图背景)优劣(方便设计显示,与原图不一致)
水印制作:图片上的标识,两种(文字,图片),基本流程(原图,水印图,合并)
项目水印:配置文件,流程详细(获得原图资源,判断水印图资源,获得水印图资源,获得图片宽高,判断水印位置,计算水印位置,判断合并结果,保存,返回水印图名称),修改上传图片的名字为水印图
MVC:软件设计典范(模型Model,视图View,控制器Controller),输入处理和输出的分离,MVC框架(功能划分M,V,C),PHP代码发展(混编,显示和逻辑分离,数据逻辑与业务逻辑分离),action(C处理一类事务,C包含多个Action),区分(模块module,模型model,模板template)
自动安全更新方法:拼凑sql语句,更新,流程(清理无效字段,拼凑sql语句(更新部分,条件),强制设定条件(判断条件,自动分析条件),返回执行结果)
自动删除:根据ID进行删除(单个=,数组in),流程(参数添加引号,拼凑删除条件,返回删除结果)
Session入库:session入内存,session入库(修改session存储机制),session入库原理,修改session系统(session读写功能),修改流程(准备读写方法,告知session系统(session_set_save_handler())
Session表设计:字段(sessionID,数据,过期时间)
Session方法完善:读(根据sessionID数据库查询),写(根据sessionID,session数据写入或者更新数据),开启(提取公共连接数据库代码),数据库连接资源作用域,销毁(根据sessionID删除数据),回收(根据配置清理过期session,expire字段),session配置(gc_maxlifetime,gc_probobility,gc_divisor)
封装session类:构造函数(设置session处理器,数组传递参数,开启session,开启父类构造函数),完善各个方法
Session方法执行顺序(读在回收前),修改读方法(不读取过期数据,读判断expire),session销毁(停止执行写方法)
在线编辑器:ckeditor,简介,引入(js引入,调用),保存编辑数据,配置ckeditor(高度,工具栏),ckfinder,配置文件上传(开启上传,上传目录)
单一入口
标签:
原文地址:http://www.cnblogs.com/lifushan/p/5472212.html