草庐IT

filter_func

全部标签

php - 使用带有回调函数的 array_filter 删除空数组元素

我正在尝试使用函数array_filter删除数组中的空元素。当我使用这样的外部回调时:functioncallback($a){return!empty($a);}$arr=array("abc",'','ghi');$res=array_filter($arr,"callback");它按预期工作。但是如果我那样使用array_filter:$arr=array("abc",'','ghi');$res=array_filter($arr,function($a){return!empty($a);});它因错误而失败:PHPParseerror:syntaxerror,unexp

php - "filter input, escape output"对 PDO 是否仍然有效

我在“过滤输入,转义输出”之前读过这篇文章,但是当我在PHP中使用PDO时真的需要过滤输入吗?我认为使用PDO我不需要过滤输入,因为准备好的语句会处理sql注入(inject)。我认为“转义输出”仍然有效,但“过滤输入”仍然有效吗? 最佳答案 是的,它仍然有效。过滤不是要防止安全漏洞,而是不要用垃圾填充您的数据库。如果您需要一个日期,请在存储之前确保它至少看起来像一个日期。转义输出是为了防止安全漏洞(即XSS或跨站点脚本)。所以,是的,两者都非常重要,并且与SQL注入(inject)完全无关(尽管相当多的开发人员仍然混淆了SQL查询

php - 我应该使用 PHP Superglobals 还是 Filter Input 来检索 $_GET 数据?

我真的很讨厌全局变量——也许是因为我是C#程序员,但是当我在PHP中工作时,每次我不得不做这样的事情时我都会咬紧牙关:$strUsername=$_GET['username'];是的,我过于简单化了,是的,我正确地清理了所有这些。事实上,对于我构建的框架,几乎在执行开始时就捕获了所有超全局变量,并从那里开始进行依赖注入(inject)。我在PHP手册中遇到过这个函数(你真的每天都能学到新东西):filter_input_array()。所以现在,从技术上讲,我可以这样做而不是从GET超全局中获取所有内容:$GETdata=filter_input_array(INPUT_GET);.

php - 谷歌分析 API : filter by multiple URIs?

问题是我需要过滤大约100个位于数据库中的分析URI(比如说网站最重要的页面),它可以一个一个地查询,但我认为它效率不高。目标是一次过滤所有URI。而不是filters=ga:pagePath==/firstURI我需要一些类似的东西filters=ga:pagePath==/firstURI&&/secondURI&&/thirdURI&&/...URI我玩过http://ga-dev-tools.appspot.com/explorer/?csw=1并搜索了有关它的文档,但找不到任何东西!我希望你能帮助我! 最佳答案 在使用Go

php - 为什么 PHP filter_var 说这是一个有效的电子邮件地址?

当用户注册到我的站点时,我使用filter_varPHP函数来验证电子邮件地址。我使用帖子中的这段代码:$email=filter_var($_POST['email'],FILTER_VALIDATE_EMAIL);然后我做:if(!$email){//returntotheform}else{//sendregistrationinfo}现在当我var_dump($email)时,我得到了输出:string(23)"user."name"@example.com"我想知道为什么这不会返回false。我认为双引号是NotAcceptable,那么为什么PHP说它是有效的呢?

PHP:在 5.4 版中使用构造数组或 func_get_args() 调用反射方法之间的差异令人困惑

这是PHP5.4中关于通过引用传递对象的非常边缘的情况,会出现此错误:PHPWarning:Parameter1toA::foo()expectedtobeareference,valuegiven但仅作为以下的复合效果:使用反射将继承的方法设置为“可访问”,并且该方法采用显式引用参数(&argumentsig)然后使用func_get_args()调用它,而不是手动构建args数组。不知道为什么这些事情都会导致这种行为,或者它们是否应该。重要的是要注意,PHP5.5中不存在这种效果。这是会导致上述错误的代码,但如果您用COMMENTTHISLINE注释该行,代码运行正常(例如,对象被

php - call_user_func(array(self, 'method' )) - 我必须给类(class)命名吗?

在PHP中,call_user_func(array(self,'method_name'))不起作用。self关键字不能在该上下文中使用。我实际上需要包含类的名称call_user_func(array('class_name','method_name'))。但是,如果我不在静态函数中,$this变量会在该上下文中起作用。为什么不同? 最佳答案 如果您想要当前类上下文的名称,请使用get_class()(不带任何参数)或__CLASS__。你已经写出了差异;self是一个关键字,不能用作数组中的引用(在PHP中应该是哪种类型?)

php - 使用显式参数调用函数与 call_user_func_array()

本周早些时候我看到了一段代码(不幸的是,我无法检索),我很好奇作者是如何实现__call()魔法方法的。代码如下所示:classSample{protectedfunctiontest(){var_dump(func_get_args());}publicfunction__call($func,$args){if(!method_exists($this,$func)){returnnull;}switch(count($args)){case0:return$this->$func();case1:return$this->$func($args[0]);case2:return$

PHP 的新 input_filter 不读取 $_GET 或 $_POST 数组

在PHP5.2中添加了一个很好的安全函数,称为“input_filter”,所以不用说:$name=$_GET['name'];你现在可以说:$name=filter_input(INPUT_GET,'name',FILTER_SANITIZE_STRING);它会自动清理你的字符串,还有:FILTER_SANITIZE_ENCODEDFILTER_SANITIZE_NUMBER_INTFILTER_SANITIZE_EMAILFILTER_SANITIZE_URL等所以这是一个非常方便使用的安全功能,我想完全切换到它。问题是...我经常在处理$_GET和$_POST数组之前对其进行操

微服务门神-Gateway过滤器Filter

目录引言概念局部过滤器简单无法参数过滤器 带参数过滤器全局过滤器转视频版引言书接上篇:微服务门神-Gateway路由,讲完了解Gateway路由规则之后,接下来看下Gateway第二核心组件:Filter概念过滤器就是在请求的传递过程中,对请求和响应做一些功能操作。在Gateway中,Filter的生命周期只有两个:“pre”和“post”。PRE:前置过滤,这种过滤器在请求被路由之前调用。我们可利用这种过滤器实现身份验证、在集群中选择请求的微服务、记录调试信息等。POST:后置过滤,这种过滤器在路由到微服务以后执行。这种过滤器可用来为响应添加标准的HTTPHeader、收集统计信息和指标、将