tp 框架开发整理总结
发布时间 - 2019-06-21 00:00:00 点击率:次tp3.2文档 http://www./xiazai/shouce/31
大写字母的用法A函数用于实例化控制器格式:[资源://][模块/]控制器 A($name,$layer='',$level='')@param string $name 资源地址 @param string $layer 控制层名称 @param integer $level 控制器层次 @return Controller|false
B执行某个行为 B($name,$tag='',&$params=NULL)
@param string $name 行为名称 @param string $tag 标签名称(行为类无需传入) @param Mixed $params传入的参数 @return void
这是随着行为应运而生的新生函数,可以执行某个行为,例如B('app_begin');
就是在项目开始之前,执行这个行为定义的所有函 数,支持2个参数,第二个参数支持需要接受一个数组
例如
B('app_begin',array("name"=>"tdweb","time"=>time()));
C 读取及设置配置参数C($name=null,$value=null,$default=null)
@paramstring|array $name 配置变量 @param mixed $value 配置值 @param mixed $default 默认值 @return mixed
获取值:
- 获取所有设置:C(); 不传递任何参数,返回一个包含所有设置的数组。
- 获取指定配置:C('URL_MODEL') 这样就能得到URL_MODEL的配置信息
- 获取指定二维数组配置:C("array.name"),这样就返回数组array下的key为name所对应的值
设置值:
- 为二维数组赋值C("array.name","value"),原理同上(获取array.name的值),后边的value是值
- 批量赋值:
$test=array("URL_MODEL"=>1,"THIN_MODEL"=>true"); C($test); 这样直接将数组里的值赋值了判断是否赋值:
C("?URL_MODEL")这样前边加个"?",如果已经赋值,则返回true需要说明的是,这里虽然更改了配置的值,但是仅仅是这个页面做了更改,到下个页面就不起作用了,
如果想改就永久更改,那么需要配合F函数,将配置文件写入config.PHP才行。
D函数用于实例化模型类格式 [资 源://][模块/]模型 D($name='',$layer='')
@paramstring $name 资源地址 @param string $layer 模型层名称 @return Model
D函数有2个优点:
- 一是如果之前实例化过这个Model,那么就不再实例化了,省资源;
- 二是方便调试,如果不存在 这个Model,会抛出TP异常,非常人性化。
如果访问本项目的Model直接D("Model名称");就可以了,如果打算跨项目访问,就使用 D("Model名称","项目名称");
E抛出异常处理 E($msg, $code=0)
@param string $msg异常消息 @param integer $code 异常代码默认为0 @return void
F快速文件数据读取和保存针对简单类型数据字符串、数组 F($name, $value='',$path=DATA_PATH)
@param string $name 缓存名称 @param mixed $value 缓存值 @param string $path 缓存路径 @return mixed
- 快速保存数据:F("mydata","这里是要保存的数据"),这样就在项目Data目录下保存了一个名叫mydata.php的文件,里边的内容是该函数的第二个参数。
- 指定保存时间 :F("mydata","这里是要保存的数据","60"),这样,如果下次再访问,间隔大于60秒则删除次缓存文件。
- 指定保存目录:F("mydata","这里是要保存的数据","60",DATA_PATH) ,这样就指定保存在data目录下
- 立即删除缓存:F("mydata",null),第二个参数传递一个null值,这样就删除了mydate这个缓存
- 读取缓存数据:F("mydata"),这样就读取这个缓存了
G记录和统计时间(微秒)和内存使用情况
G($start,$end='',$dec=4)使用方法:
G('begin'); // 记录开始标记位 // ... 区间运行代码 G('end'); // 记录结束标签位 echo G('begin','end',6); //统计区间运行时间精确到小数后6位 echo G('begin','end','m'); // 统计区间内存使用情况 如果end标记位没有定义,则会自动以当前作为标记位其中统计内存使用需要 MEMORY_LIMIT_ON 常量为true才有效
@param string $start 开始标签 @param string $end 结束标签 @paraminteger|string $dec小数位或者m @return mixed
I获取输入参数支持过滤和默认值
I($name,$default='',$filter=null)使用方法:
I('id',0); //获取id参数自动判断get或者post I('post.name','','htmlspecialchar s'); //获取$_POST['name'] I('get.'); //获取$_GET
L()获取和设置语言定义(不区分大小 写)
L($name=null,$value=null)@paramstring|array $name 语言变量 @param mixed $value 语言值或者变量 @return mixed语言定义函数,L("intro")获取定义成intro的语言,l("intro","介绍")为intro赋值
M函数用于实例化一个没有模型文件的Model
M($name='',$tablePrefix='',$connection='')@param string $name Model名称支持指定基础模型例如MongoModel:User @param string $tablePrefix表前缀 @param mixed $connection 数据库连接信息 @return Model
N设置和获取统计数据
N($key,$step=0,$save=false)使用方法:
N('db',1); // 记录数据库操作次数 N('read',1); // 记录读取次数 echo N('db'); // 获取当前页面数据库的所有操作次数 echo N('read'); // 获取当前页面读取次数@param string $key 标识位置 @param integer $step 步进值 @return mixed
R远程调用控制器的操作方法 URL 参数格式 [资源://][模块/]控制器/操作
R($url,$vars=array(),$layer='')@param string $url调用地址 @paramstring|array $vars调用参数支持字符串和数组 @param string $layer 要调用的控制层名称 @return mixed
T获取模版文件格式资源://模块@ 主题/控制器/操作
T($template='',$layer='')@param string $name 模版资源地址 @param string $layer 视图层(目录)名称 @return string
U()URL组装支持不同URL模式
U($url='',$vars='',$suffix=true,$domain=false)@param string $url URL表达式,格式:'[模块/控制器/操作#锚点@域名]?参数1=值1&参数2=值2...' @paramstring|array $vars传入的参数,支持数组和字符串 @param string $suffix 伪静态后缀,默认为true表示获取配置值 @paramboolean $domain 是否显示域名 @return string
使用方法:
- 取得当前模块的Action地址 :U("/nowMethod");
- 取得当前模块的Action地址,并传递参数:U("/nowMethod?params=test");
- (如果不习惯上边那种方式,可以使用U("/nowMethod",array("params"=>"test");这样的数组方式传递参数,效果是一样的)
- 访问其他模块的方法:U("Other/otherMethod"),这样就是访问Other模块下的otherMethod方法
跨项目访问:
U("appname://Other/otherMethod");使用路由访问:
U("appName://routeName@moduleName/actionName?params");另外,如果想直接跳转,那么就在第二个参数写1
U("/nowMethod",1)这样就直接调转到指定URL了
W渲染输出Widget
W($name,$data=array())@param string $name Widget名称 @param array $data 传入的参数 @return void
S缓存管理
S($name,$value='',$options=null)@param mixed $name 缓存名称,如果为数组表示进行缓存设置 @param mixed $value 缓存值 @param mixed $options 缓存参数 @return mixed
- 全局缓存读写函数,和C类似,不过是直接写成文件,写在Temp目录下,不过在缓存有一点需要注意,
- 如果缓存名称是aaa,那么缓存生成的文件名称就是md5("aaa")的值。
技术
防止xss攻击
简单的防止
当网站不涉及复杂的用户交互时,可以对用户所有提交的文本进行htmlspecialchars函数处理。
- 版本为:3.2
- 步骤:
- 一:在项目配置文件中添加配置: 'DEFAULT_FILTER' => 'htmlspecialchars', //默认过滤函数
- 二: 使用框架带的I方法获取来自用户提交的数据;
-
例子
M('Member')->save(array('content'=>I('post.content')));
对COOKIE进行IP绑定
- cookie的信息一但被别人通过XSS攻击获取后也一样等同于把自己的帐号密码给了别人。
- 对cookie进行IP绑定,(当然也可以获取用户客户端更多的其它信息进行同时绑定)可以根据用户的IP来判断这个cookie是不是来原始授权用户。
示例
- 用户设置了自动登录时保存自动登录信息:
$auto=I('post.auto');//用户设置了自动登录 if(!empty($auto)){ cookie('auto',encrypt(serialize($data)));//将登录信息保存到cookie,其中$data里含有加密后的帐号,密码,和用户的IP,这里的cookie已在全局中设置过期日期为一周 } - 用户关闭浏览器再次访问网站时,进行自动登录
if (!is_login()) {//是否未登录状态? $auth=cookie('auto'); if(!empty($auth)){//是否未有自动登录cookie? $data=unserialize(decrypt($auth)); if(!empty($data) && !empty($data['username']) && !empty($data['password']) && !empty($data['last_login_ip'])){ $user=M('Member')->where(array('username'=>$data['username'],'password'=>$data['password']))->find(); if(!empty($user['id'])&&($user['last_login_ip']==get_client_ip())){//cookie帐号密码是否有效?//IP来源是否相同? login_session($user['id'], $user['username'], $data['last_login_ip']);//用户自动登录成功 } } } }
- 优点:大多数场景下可使被XSS攻击盗取的cookie失效。
- 缺点:由于IP存在多台电脑共用的可能,对绑定做不到十分精细
为COOKIE添加httponly配置
可以保证cookie只在http请求中被传输,而不被页面中的脚本获取,现市面上绝大多数浏览器已经支持。
HTML5的新特性:
为iframe的增加的sandbox属性,可以防止不信任的Web页面执行某些操作.相信这个方法以后会被广泛使用。
富文本过滤
5.0文档
http://www./xiazai/shouce/32
# php
# html5
# xss
# Array
# NULL
# 常量
# Cookie
# 字符串
# default
# http
# 自动登录
# 第二个
# 绑定
# 就在
# 目录下
# 抛出
# 配置文件
# 步进
# 默认值
# 自己的
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
,怎么在广州志愿者网站注册?
laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
如何为不同团队 ID 动态生成多个独立按钮
重庆市网站制作公司,重庆招聘网站哪个好?
HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】
如何在香港免费服务器上快速搭建网站?
用yum安装MySQLdb模块的步骤方法
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
香港服务器如何优化才能显著提升网站加载速度?
iOS发送验证码倒计时应用
HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】
详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点
,网页ppt怎么弄成自己的ppt?
如何在阿里云部署织梦网站?
如何安全更换建站之星模板并保留数据?
Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面
如何构建满足综合性能需求的优质建站方案?
如何快速搭建安全的FTP站点?
Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程
Laravel DB事务怎么使用_Laravel数据库事务回滚操作
百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏
Linux系统命令中screen命令详解
HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】
如何在阿里云服务器自主搭建网站?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
浅谈redis在项目中的应用
Laravel如何生成API文档?(Swagger/OpenAPI教程)
Laravel如何为API生成Swagger或OpenAPI文档
Swift开发中switch语句值绑定模式
如何在Tomcat中配置并部署网站项目?
Laravel Debugbar怎么安装_Laravel调试工具栏配置指南
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环
如何挑选优质建站一级代理提升网站排名?
java ZXing生成二维码及条码实例分享
七夕网站制作视频,七夕大促活动怎么报名?
如何用好域名打造高点击率的自主建站?
Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤
Android自定义控件实现温度旋转按钮效果
Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧
如何在七牛云存储上搭建网站并设置自定义域名?
如何自定义建站之星模板颜色并下载新样式?
Python制作简易注册登录系统
使用Dockerfile构建java web环境
Laravel怎么使用Blade模板引擎_Laravel模板继承与Component组件复用【手册】
通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】


string $name 资源地址
@param string $layer 模型层名称
@return Model