xml地图|网站地图|网站标签 [设为首页] [加入收藏]

正规赌博平台

当前位置:网上十大正规赌博平台 > 正规赌博平台 > Filter过滤器全面解析,Yii2实现上下联动下拉框功

Filter过滤器全面解析,Yii2实现上下联动下拉框功

来源:http://www.nb-machinery.com 作者:网上十大正规赌博平台 时间:2019-07-12 12:18

本文实例讲述了Yii2实现上下联动下拉框功能的方法。分享给大家供大家参考,具体如下:

我们先看看cookie是什么东东? 

PHP 过滤器用于验证和过滤来自非安全来源的数据,比如用户的输入。

首先我先解释下什么是上下联动的下拉框

cookie是服务器留在客户端的用于识别用户或者存储一些数据的小文件(注意,session存储在服务器端,这是两者的区别之一)。我们平时登录某门户时,会有选项“是否保存登录”或者“下次自动登录”,当我们勾选了之后,服务器就会在我们的浏览器创建cookie文件来保存我们的信息。每当计算机通过浏览器请求页面时,它会同时发送cookie。通过PHP,可以创建并取回cookie的值。cookie在web中是很重要的角色,早在网景浏览器的时候就产生了cookie。cookie经常被用于用户验证系统。 

什么是 PHP 过滤器?

假如一个view里面有两个select,第一个是公司名,第二个是分公司名。公司有多个,每个公司又有多个分公司,我们实现的就是点击当前公司后,分公司里面显示的事当前公司的分公司。

1.创建cookie
函数setcookie()可以在PHP中生成cookie。由于cookie是HTTP头标部分的内容,因此必须在输出任何数据之前调用setcookie(),这个限制和header()类似,定义:
bool setcookie( string name[,string value][,int expire][,string path][,string domain][,bool secure][,bool httponly])  

PHP 过滤器用于验证和过滤来自非安全来源的数据。

或者你直接理解成选择所属省份后,下面的select显示的是当前省份的县。

好多参数啊!Σ(⊙▽⊙"a 不急,让我们看看各个参数的作用: 
name  :  必选,表示cookie的名字。 
value  :  可选,表示cookie值,存储在客户端,当为空时,表示撤销客户端中该cookie的资料(这样可以删除cookie)。 
expire  :  可选,表示cookie的有效截止时间,也就是过期时间,如果没有指定或者指定为0,那么通常是在关闭浏览器时失效。 
path  :  可选,cookie有效路径。 
domain  :  可选,cookie有效域名。 
secure  :  表示在HTTPS的安全传输时才有效。 
实例(建立一个名字为test,值为China的cookie):

验证和过滤用户输入或自定义数据是任何 Web 应用程序的重要组成部分。

原理:

 <?php
 setcookie("test",China");
 ?> 

设计 PHP 的过滤器扩展的目的是使数据过滤更轻松快捷。

点击第一个select后,执行ajax获取当前公司的分公司,并使用jQuery修改分公司内容

 使用setcookie()给的值只能是数字或者字符串,不能是其他的复杂结构。

为什么使用过滤器?

两个select的部分视图代码如下:

2.获取cookie 创建cookie后,就可以使用预定义变量$_COOKIE来获取cookie。不过,只能在其他页面获取cookie,因为在php中,被设置的cookie不会在本页面生效,除非该页面被刷新。
实例:

几乎所有 web 应用程序都依赖外部的输入。这些数据通常来自用户或其他应用程序(比如 web 服务)。通过使用过滤器,您能够确保应有程序获得正确的输入类型。

<?= $form->field($model, 'companies_company_id')->dropDownList(
  yiihelpersArrayHelper::map(backendmodelsCompanies::find()->all(),'company_id','company_name'),
  [
    'prompt'=>'select Company',
    'onchange'=>'
      $.post("index.php?r=branches/lists&id='.'" $(this).val(),function(data){
        $("select#departments-branches_branch_id").html(data);
      });',
  ]
) ?>
<?= $form->field($model, 'branches_branch_id')->dropDownList(
  yiihelpersArrayHelper::map(backendmodelsBranches::find()->all(),'branch_id','branch_name'),
  [
    'prompt'=>'Select Branches',
  ]
) ?>
 <?php
 setcookie("test","China");
 echo "cookie is ".$_COOKIE["test"];
 ?> 

您应该始终对外部数据进行过滤!

list方法代码:

 这里之所以要刷新页面,是因为cookie的值不会在调用setcookie()之后立即存储在 C OOKIE变量中,而是随着http请求被发送至服务器,这时候cookie的值才会出现在 COOKIE变量中,而是随着http请求被发送至服务器,这时候cookie的值才会出现在_COOKIE中。(博客园对于dollar符不支持么。。。啊啊啊) 

输入过滤是最重要的应用程序安全课题之一。

public function actionLists($id)
{
  $countBranches = Branches::find()
    ->where(['companies_company_id' => $id])
    ->count();
  $branches = Branches::find()
    ->where(['companies_company_id' => $id])
    ->all();
  if ($countBranches > 0) {
    foreach ($branches as $branche) {
      echo "<option value='" . $branche->branch_id . "'>" . $branche->branch_name . "</option>";
    }
  } else {
    echo "<option>-</option>";
  }
}

3.cookie的有效期 cookie有生命周期,也就是cookie存在的有效时间。可以设置第三个参数来设置有效时间。
实例(设置cookie有效时间的几种方式): 

什么是外部数据?

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

setcookie("cookie_one","A",time() 60*60);    //cookie在一小时后失效
setcookie("cookie_two","B",time() 60*60*24);  //cookie在一天后失效
setcookie("cookie_three","C",mktime(23,53,19,10,09,2020));  //cookie在2020年10月9日23时53分19秒失效
setcookie("cookie_four","D");   //关闭浏览器后cookie失效  

•来自表单的输入数据

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

4.cookie的有效路径 cookie中的路径用来控制设置的cookie在哪个路径下有效,默认为'/',在所有路径下都有效,也就是在整个服务器域名下都有效,当设定了其他路径之后,则只在设定的路径以及子路径下有效,例如:
setcookie('test', time(), 0, '/path'); 
上面的设置会使test在/path以及子路径/path/abc下都有效,但是在根目录下就读取不到test的cookie值。 

•Cookies

您可能感兴趣的文章:

  • Yii2 ActiveRecord多表关联及多表关联搜索的实现
  • yii2实现根据时间搜索的方法
  • yii2带搜索功能的下拉框实例详解
  • 浅析Yii2 GridView 日期格式化并实现日期可搜索教程
  • 浅析Yii2 GridView实现下拉搜索教程
  • yii2框架中使用下拉菜单的自动搜索yii-widget-select2实例分析
  • Yii2基于Ajax自动获取表单数据的方法
  • Yii2的XSS攻击防范策略分析
  • Yii2中Restful API原理实例分析
  • Yii2实现同时搜索多个字段的方法

一般情况下,大多是使用所有路径的,只有在极少数有特殊需求的时候,会设置路径,这种情况下只在指定的路径中才会传递cookie值,可以节省数据的传输,增强安全性以及提高性能。

•服务器变量

5.删除cookie 删除cookie比较简单,也是通过setcookie()来实现的(不要使用unset()!!!)下面的代码就是个简单例子:setcookie("test",""); 
通过将第二个参数设为空来达到删除cookie的目的。如果设置cookie时,为cookie提供了特定的值,那么在删除cookie时,仍然需要提供这些参数,以便PHP可以正确地删除cookie。

•数据库查询结果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

函数和过滤器

您可能感兴趣的文章:

  • php中cookie的使用方法
  • PHP setcookie设置Cookie用法(及设置无效的问题)
  • PHP之COOKIE支持详解
  • PHP CURL获取cookies模拟登录的方法
  • php cookie 登录验证示例代码
  • PHP会话控制:Session与Cookie详解
  • PHP读取CURL模拟登录时生成Cookie文件的方法
  • curl不使用文件存取cookie php使用curl获取cookie示例
  • php session和cookie使用说明

如需过滤变量,请使用下面的过滤器函数之一:

•filter_var() - 通过一个指定的过滤器来过滤单一的变量

•filter_var_array() - 通过相同的或不同的过滤器来过滤多个变量

•filter_input - 获取一个输入变量,并对它进行过滤

•filter_input_array - 获取多个输入变量,并通过相同的或不同的过滤器对它们进行过滤

在下面的例子中,我们用 filter_var() 函数验证了一个整数:

<?php
$int = 123;
if(!filter_var($int, FILTER_VALIDATE_INT))
{
echo("Integer is not valid");
}
else
{
echo("Integer is valid");
}
?> 

上面的代码使用了 "FILTER_VALIDATE_INT" 过滤器来过滤变量。由于这个整数是合法的,因此代码的输出是:"Integer is valid"。

假如我们尝试使用一个非整数的变量,则输出是:"Integer is not valid"。

如需完整的函数和过滤器列表,请访问我们的 PHP Filter 参考手册。

Validating 和 Sanitizing

有两种过滤器:

Validating 过滤器:

•用于验证用户输入

•严格的格式规则(比如 URL 或 E-Mail 验证)

•如果成功则返回预期的类型,如果失败则返回 FALSE

本文由网上十大正规赌博平台发布于正规赌博平台,转载请注明出处:Filter过滤器全面解析,Yii2实现上下联动下拉框功

关键词: mg4355娱乐城