首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Yii2 进阶篇

为什么使用过滤器 通常情况下,过滤器将代码绑定到所有的操作上,也就是说,每一个操作的执行,都需要先或后执行过滤器,所以,可以用来执行权限检测、缓存处理等事情 在哪里使用过滤器 在控制器中,定义: public...Return parent::beforeAction($action)== 错误处理 凡是非致命错误都以异常的形式抛出,是可以捕获的 错误处理器是以组件的形式配置在main中的 错误响应的格式是可以选择的...创建模型.png 创建控制器,实例化表单模型和渲染视图 ? 创建控制器.png 视图中使用ActiveForm创建表单元素 ? 创建元素表单.png 在控制器中接收表单数据并绑定数据到表单模型 ?...修改表单模型 在验证中加入 maxFiles 配置表示最多可以上传多少个文件 修改表单模型的upload 方法 如果是多文件上传,这里的$this->imageFile 就会是一个数组,所以可以使用foreach...验证码 Yii2中的验证码是通过扩展的操作来实现的,叫做 yii\captcha\CaptchaAction 只需要将它绑定到actions中就可以直接访问,无需任何更改: ?

2K31

细读Yii2的Response

错误也会经过错误处理返回一个Response。 一个Response完整的流程有哪些?...将所有response的内容更加输出格式转换成响应的字符串,并确定http返回码。 设置响应头。输出所有自定会返回头和标注http协议返回头。 输出内容。将字符串内容输出,并刷新缓冲区 触发后置事件。...在web/Response 文件中定义了状态码数组,几乎涵盖了所有的http状态码,并给出了标注的状态码文字说明。如果想了解http状态码,看Yii2的Response文件就足够了。...每个请求都需要占用一定的内存去处理数据。为了避免我限制申请内存造成php程序报内存不足,因此对于文件读取程序,必须设置读取限制。读取完及时刷新出去。...浏览器就会弹出一个下载提示框。

1K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    yii2开发后记

    基础总结 1.修改默认控制器/方法 yii默认是site控制器,可以在web.php中设置$config中的'defaultRoute'='xxxx';使用自定义默认的控制器。...yii的默认方法是index,可以在vender/yiisoft/yii2/base/Controller.php 中进行初始设置,也可以在控制器中改写defaltAction='action'。...而且,像input这样的小部件,用ActiveForm类来展现,yii会对每个自动加入ajax验证,其一般的小部件都放在yii\widget\里,我们还可以在此文件夹里构建自定义的小部件类。...规则设置 yii中对验证规则的定义,使用rules()方法可以一条定义多条规则,也可以根据不同的场景进行定义。外部验证时用$model->validate()方法来执行验证。...5.yii模型属性转数组 YII用toArray()方法可以将模型的属性转换为数组进行输出,可独立使用,也可以在查询时用连续操作方式使用。

    3.2K50

    Yii2 速查表

    '=>1]//判断v是否为数字且大于等于1、小于等于90 数组各元素验证 /* 要求验证的元素必须为数组,否则会返回假并报错 */ ["categoryIds","each","rule"=>[...基本用法 使用Query Builder需要使用的类 $query = (new \yii\db\Query()); // yii2使用Query对象来采集SQL的各个部分,然后由Query Builder...可以使用缓存的版本。 400: 错误的请求。可能通过用户方面的多种原因引起的,例如在请求体内有无效的JSON 数据,无效的操作参数,等等。 401: 验证失败。...415: 不支持的媒体类型。 所请求的内容类型或版本号是无效的。 422: 数据验证失败 (例如,响应一个 POST 请求)。 请检查响应体内详细的错误消息。 429: 请求过多。...500: 内部服务器错误。 这可能是由于内部程序错误引起的。 (adsbygoogle = window.adsbygoogle || []).push({});

    1.8K40

    Yii2的MVC新特性

    每一个Model Class其实很多时候都是跟一些更加核心的类(比如Active Record)配合着使用,而在Yii2中,Active Record的增强也让我很惊喜,后续我打算再写一遍文章来专门介绍...Yii2的Model验证,rules()函数具体担当为Model的每一个attributes进行过滤验证,而scenarios()则可以根据不同的场景需要来声明哪一个attributes是无需验证的(Which...在Views还有一个值得注意的地方就是this变量,在Yii1.1中,this可以说就是链接Controller和Views的中介;而在Yii2中, 控制器(Controllers) 首先直接来看一下代码...没错,Yii2中已充分开始使用PHP命名空间,当初在Yii1.1的时候一直听说Yii2会使用更高级的PHP特性来完全重写,果然啊,点个赞。...而且现在的Controller中,每个输出变为了返回,就像上面的actionTest()一样,你现在可以完全返回一个字符串了,有没有一丝丝Laravel的影子?

    2.7K20

    这周撸了两款小程序,总结下经验。

    以上是关于小程序登录的前后台逻辑,如果你使用yii2类框架,很多都内置了,并不复杂。 但是这里还有几个问题 小程序端何时进行登录逻辑? 发起请求时access_token过期了如何处理?...客服消息 在小程序开发中,客服消息的重要性不言而喻,它除了作为客服服务外,还作为小程序到微信浏览器的一个渠道,比如本次在「宝宝爱识图」的开发中,我用它来实现将收款微信号到用户的推送工作,这主要是解决在ios...服务器端 接下来总结下服务器端,我使用yii2的restful组件作为接口支持,关于restful的基本功能请参考yii2官方文档或我之前录制的课程《Yii2的RESTful讲解》,在这里分享我认为关键的点...让yii2能解析json的请求内容 默认情况下yii2并不能识别请求中的json格式,而我们小程序在发起请求时喜欢用它,因此我们要对yii2进行一下配置。...在yii2的restful中的用户认证使用了行为机制,我们来看下流程代码 // 在需要授权的控制器内 class CardController extends ActiveController {

    1.4K50

    yii2开发中19条推荐实践

    虽然每个人的编程风格不同,但是有些建议能让你的代码更加规范和稳定,本次就我这次网站更新总结如下几点,希望对你的yii2学习和使用有所帮助。...环境说明 服务器环境: CentOS 开发环境及IDE:mac & phpstorm Yii:v2.0.15 基础版 接下来开说 开发前 先说说开发前的事情,磨刀不误砍柴工,将yii2配置到一个最易开发的状态...Composer 这个是做yii2开发的基石,除非没有办法使用,否则请不要放弃,除了更容易的安装yii2及第三方扩展外,能使用Composer代表着你的服务器最少能运行起来php-cli,那么你就可以使用...中文化 默认安装yii2时,程序的相关信息是英文的,第一步我们需要改成中文的,很简单。...将验证的工作交给模型的rule和场景吧。一切。

    3.3K70

    yii2的加密解密那些事儿

    大家好,又见面了,我是你们的朋友全栈君。 我们做程序的时候,加密解密是绕不开的话题,使用yii2开发应用的时候,都内置了哪些有关加密解密(安全)方便的支持那?本文将为你揭晓。...一般用法如下 // 使用generatePasswordHash为用户的密码加密,$hash存储到库中 $hash = Yii::$app->getSecurity()->generatePasswordHash...validateData 函数的第三个参数应该与使用 hashData() 生成数据时的值相同. 它指示数据中的散列值是否是二进制格式. 如果为false, 则表示散列值仅由小写十六进制数字组成....,这样就实现了电影中经常出现的按位破解密码的场景。...而使用 compareString 比较两个字符串,无论字符串是否相等,函数的时间消耗是恒定的,这样可以有效的防止时序攻击。

    91820

    浅谈csrf攻击以及yii2对其的防范措施

    凡是我yii2学习社群的成员都知道,我不止一次给大家说构造表单100%使用yii2的ActiveForm来实现,这除了能和AR更好结合外就是自动生成csrf隐藏域,一个非常安全的举措。...老王自己也有一个银行账号 wang2,他尝试登录并且通过浏览器发送请求给银行,代码如下 https://bank.abc.com/withdraw?...这种方法最简单,并且不需要修改业务代码,我们只需要对到达服务器的每个请求做一次拦截分析即可。...在CSRF这块,yii2框架采取了HTTP头部和参数token并行的方式,针对于每个请求,在beforeAction都会做一次判断,如下 // vendor/yiisoft/yii2/web/Controller.php...以上是整体的思路,为了让你看的更清晰,我画一个图并增加一些名词解释。 [tu.png] 以上是yii2的csrf策略部署,当然我还是推荐你使用 xdebug等调试工具 一步一步看看这个过程。

    2.5K60

    JSON.parse 执行出错:SyntaxError: Unexpected end of JSON input

    在计算机编程中,当我们处理 JSON 数据时,SyntaxError: Unexpected end of JSON input 这个错误通常出现在尝试解析 JSON 数据时出现了问题。...出现这个错误的原因主要有以下几种:JSON 字符串未完全传输或读取:如果你从网络请求、文件或其他来源获取 JSON 数据,但由于某种原因数据没有完全接收,可能会导致解析时出现问题。...因此,JSON.parse() 在尝试解析这个字符串时,会因为无法找到数组的结束符号而抛出 SyntaxError: Unexpected end of JSON input 错误。...四、如何避免这个错误?确保数据完整性:当你从外部来源(如服务器、文件系统等)获取 JSON 数据时,一定要确保数据完整,避免出现数据截断或丢失的情况。...你可以使用一些工具,如 JSONLint,来验证 JSON 数据是否正确。增加异常处理:使用 try...catch 语句来捕获解析错误,以便在发生错误时能够及时处理,而不是让程序崩溃。

    34910

    软件常见漏洞的解析

    软件漏洞基于成因可分类:内存破坏类漏洞、逻辑错误类漏洞、输入验证类漏洞、设计错误类漏洞、配置错误类漏洞。 缓冲区漏洞 当程序尝试读取或写入超出范围的缓冲区时,会发生缓冲区溢出。...建议可以采用安全的系统函数(对操作数据进行长度判断的函数)例如strcpy_s 下面也是同样会出现溢出的风险, 降低缓冲区漏洞方案 若要防止利用缓冲区溢出漏洞,可以使用包含功能或扩展的编译器来限制输入...整数漏洞 当计算尝试递增一个大于用于在相关表示形式中存储该整数的整数值时,存在整数溢出漏洞。发生此错误时,整数值可能会转换为负数或非常小的数字。...下面的代码显示了由不精确的类型转换生成的常见错误。 尽管该函数检查通知的 size参数值是否符合最大数组大小的限制,但没有与参数值的信号相关的检查。...4、不受限制的登录尝试或会话限制。 特权或身份验证漏洞通常在开发的体系结构和设计、实现或操作阶段引入。任何语言都可能出现这些漏洞。

    2.3K50

    搭建自己的PHP框架心得(二)

    本框架的知识点应用都会写在博客里,大家有什么异议的可以一起讨论,也希望看博客的也能学习到它们。...另外,call_user_func系列函数还可以传入在第一个参数里传入匿名参数,可以很方便的回调某些事件,这些特性在复杂的框架里应用也十分广泛,如yii2的事件机制里回调函数的使用就是基于此。...作用介绍: 防止在浏览器有输出之后再使用setcookie,或者header,session_start函数造成的错误。...对输出的内容进行处理,例如进行gzip压缩,例如进行简繁转换,例如进行一些字符串替换。 生成静态文件,其实就是捕捉整页的输出,然后存成文件,经常在生成HTML,或者整页缓存中使用。...后续 yii2里的数据表和model类属性之间的映射很酷(虽然被深坑过), 前面一直避开的模块(module,我可以想像得到把它也添加到URI时解析的麻烦)有时间考虑一下。 边写边优化。

    1.3K80

    SQL命令 INSERT(三)

    尝试编译引用READONLY字段的插入会导致SQLCODE-138错误。请注意,此错误现在在编译时发出,而不是仅在执行时发出。使用链接表向导链接表时,可以选择将字段定义为只读。...源系统上的字段可能不是只读的,但如果IRIS将链接表的字段定义为只读,则尝试引用此字段的INSERT将导致SQLCODE-138错误。 字段值: 每个字段值都必须通过数据类型验证。...例如,除非字符串通过当前模式的日期验证,否则尝试将字符串数据类型值插入日期字段会失败;但是,尝试将日期数据类型值插入字符串字段会成功,将日期作为文字字符串插入。...数字类型不匹配:如果通过ODBC或JDBC提供了无效的双精度数,则会出现SQLCODE-104错误。 每个字段值必须将显示传递到逻辑模式转换。...尝试以无法转换为逻辑存储值的格式插入字段值会导致SQLCODE-146错误(对于日期)或SQLCODE-147错误(对于时间)。

    2.5K10

    放大零点击漏洞

    最后,我看看如何处理数组数据,我发现有几个位置可以将字节数组变体转换为字符串,但并非所有人都检查过字节数组是否具有空终止符。这意味着如果将这些变体转换为字符串,则该字符串可能包含未初始化内存的内容。...我最终发现,当用户在浏览器中登录 Zoom 时,浏览器无法处理序列化的数据包,因此 MMR 必须将它们转换为字符串,以便可以通过 Web 请求访问它们。...我首先研究了创建一个可以触发 Zoom 客户端之外的每个错误的客户端的可能性,但是客户端身份验证看起来很复杂,并且我缺少这部分代码的符号,所以我没有继续这样做,因为我怀疑它会非常耗时。...我尝试使用 CVE-2021-34424 泄漏这样的地址,但无法使其正常工作。 此漏洞允许攻击者提供任意大小的字符串,然后将其复制到越界,直到在内存中遇到空字符,然后返回。...总体而言,虽然本研究期间发现的客户端错误与零项目在其他视频会议平台中发现的错误相当,但服务器错误令人惊讶,尤其是当服务器缺少 ASLR 并且支持非端到端的操作模式时加密。

    1.2K10

    Yii2工作中的一些方法技巧

    作为自己的周总结,平时遇到的问题,以及一不小心踩的坑,记录下来自己当复习: 表单验证 表单验证,两个参数中至少需要一个(2个以上): public function rules() {...给mysql数据库表添加字段后,立即使用这个字段时会出现未定义的情况(Getting unknown property) 原因:yii 对数据表结构进行了缓存。...(比如网站链接等)时,该内容会不换行,导致该列宽度被顶的特别长,甚至超出div的宽度。...Module name,Controller name和action name #在控制器里面使用 $this->module->id; $this->id; $this->action->id;...: // 引用命名空间 use yii\helpers\VarDumper; // 使用 VarDumper::dump($var); // 使用2 第二个参数是数组的深度 第三个参数是是否显示代码高亮

    3.3K31

    java字符串的字节数组_Java字节数组到字符串到字节数组

    参考链接: Java程序将文件转换为字节数组,反之亦然 我正在尝试将byte []转换为字符串,将byte []的字符串表示形式转换为byte []的转换...我将byte []转换为要发送的字符串,然后我期望我的...2)Java使用Big-Endian编码,但是M $系统使用Little-Endian。处理字符串(基于字符)的byte []数组时,这没有问题。...请检查API文档  数组API  要将响应字符串转换回原始字节数组,必须使用split(",")之类的东西并将其转换为一个集合,然后将其中的每个单个项目转换为一个字节以重新创建字节数组。  ...在Java中将字节数组转换为字符串并将字符串转换回字节数组很简单。我们需要知道何时以正确的方式使用"新"。  ...可以按照以下步骤完成:  字节数组到字符串的转换:  byte[] bytes = initializeByteArray();  String str = new String(bytes);  字符串到字节数组的转换

    5.2K30

    Java 中的异常处理——后端必不可少的编程技术

    如果在操作文件时出现任何 I/O…Exception 异常,则 catch 语句块将打印一条错误消息。不管是否抛出异常,finally 块中的代码都会执行。在这个例子中,我们尝试关闭文件输入流。...NumberFormatException - 尝试将字符串转换为数字时,格式不正确时抛出。...ArrayIndexOutOfBoundsException:当使用超出数组长度的索引值访问数组或尝试通过负数索引访问数组中的元素时,抛出该异常。...在循环中使用条件语句、限制索引值和增加错误检查以避免捕获数组越界异常。 FileNotFoundException:在尝试打开不存在的文件时抛出该异常。...NumberFormatException:当尝试将字符串转换为数值类型,但该字符串中的字符不是数值或可转换为数字时,会抛出NumberFormatException 异常。

    10100

    搭建自己的PHP MVC框架详解

    在处理逻辑的时候,还要考虑到错误和异常的处理。...3、框架内的配置变量等使用专用的配置文件来保存,这里我仿照了TP里的数组返回法,用了一个compileConf()函数来解析数组,将数组的键定义为常量,值为数组的值。 if (!...作用介绍: ① 防止在浏览器有输出之后再使用setcookie,或者header,session_start函数造成的错误。...③ 对输出的内容进行处理,例如进行gzip压缩,例如进行简繁转换,例如进行一些字符串替换。 ④ 生成静态文件,其实就是捕捉整页的输出,然后存成文件,经常在生成HTML,或者整页缓存中使用。...阶段: yii2里的数据表和model类属性之间的映射很酷(虽然被深坑过), 前面一直避开的模块(module,我可以想像得到把它也添加到URI时解析的麻烦)有时间考虑一下。

    1.1K50
    领券