草庐IT

screen_capture_injected

全部标签

php - 准备好的语句会完全保护我的网站免受 MySQL 注入(inject)吗?

我在查询中使用准备好的语句和MySQLi来防止注入(inject)攻击。准备好的语句会完全消除对mysql_real_escape_string的需要吗?在保护我的网站时,还有什么我应该考虑的吗? 最佳答案 只要您正确使用准备好的语句,它们就可以。您必须确保绑定(bind)所有外部变量,而不是将它们直接放在查询中。例如$stmt=$mysqli->prepare("SELECTDistrictFROMCityWHEREName=".$name);正在准备此语句,但它没有使用任何一种绑定(bind)方法,因此没有任何用处。它仍然容易受

php - 这个脚本容易受到 LFI(本地文件注入(inject))的攻击吗?

我想知道这个小片段是否受到本地文件注入(inject)漏洞的影响。我知道可以通过在请求中放入“%00”(空字节)来忽略任何内容。但是如果/some/dir/目录下没有以'prefix_'开头的子目录,是否可以利用呢?怎么办?在此先感谢您的回答。 最佳答案 你的意思是这样的吗?$lang.='en/../../../../../etc/passwd'.0x00;你可以通过以下方式避免这种情况$path='/some/dir/prefix_'.$_GET['path'].'whatever';$path=realpath($path);

php - 这是过滤数据和防止 SQL 注入(inject)和其他攻击的安全方法吗?

我创建了两个简单的函数来过滤插入的数据,然后再将其输入到mysql查询中。对于表单字段(我也使用正则表达式来单独检查每个字段。//Formfilterfunctionfilter($var){//HTMLisnotallowed$var=strip_tags(trim($var));//Checkmagicquotesandstripslashesif(get_magic_quotes_gpc()){$var=stripslashes($var);}//Notusingitrightnow,isitrecommended?//$var=htmlentities($var,ENT_QUO

php - 防止 SQL 注入(inject)

我正在尝试学习php并想使用一个函数来保护表单免受SQL注入(inject)攻击!但是以某种方式记录我的数据库中的每个数据,其中包含任何特殊字符,如'"=)/()/*/我的过滤函数:functionfilter($data){$data=trim(htmlentities(strip_tags($data)));if(get_magic_quotes_gpc())$data=stripslashes($data);$data=mysql_real_escape_string($data);return$data;}注册页面获取POST数据:foreach($_POSTas$key=>$

php - 实体、存储库和组合 - 依赖注入(inject)

我正在尝试了解DDD,但有些关于实体和存储库的内容我无法理解。从这里的其他问题中,我意识到将存储库注入(inject)实体是一个坏习惯。但是如何在组合对象时避免注入(inject)存储库?让我们来看一个简单的情况——事件和事件应用程序。这看起来很简单。$event->add($application);$eventRepository->save($event);我相信$application是一个实体,所以我相信应该有一些$applicationRepository。这是否意味着我应该将$applicationRepository注入(inject)到$eventRepository

php - PDO、准备好的语句和 SQL 注入(inject)

在阅读了几篇关于PDO和MySQLi准备语句的文章之后,也已经阅读了stackoverflow.com上关于准备语句和SQL注入(inject)的数十个问题,人们说通过正确使用准备语句,不再需要从中转义条目用户,但我认为我仍然担心存在安全问题。第一个问题:如果我在准备好的语句中使用它们之前仍然使用reg-exp和转义来清理条目,这是否就像我过度使用它一样?第二个问题:如果准备好的语句正在做关于SQL注入(inject)的工作-来自人们的评论和回答-为什么仍然有受损的数据库和越来越多的关于信用卡号码和密码的暴露数据,甚至来自“大”和知名网站?这是否意味着准备好的陈述本身并没有那么免疫,或

Php,依赖注入(inject) - 杀死静态方法,但不需要 instatize

这是一个基本的类构造,在使用DI之前(我知道,它的结构有点不正确,请尽量关注问题)classMobile{publicfunctiongetWeight(){return4;}}classUser{publicstaticfunctiongetWeight(){$mobile=newMobile();return$mobile->getWeight();}}更新后,使用DI:classUser{public$mobile;publicfunctiongetWeight(){return$this->mobile->getWeight();}}如果我们检查一下,使用getWeight()

php - 如何在完整的 OO 应用程序中处理依赖注入(inject)

我在类设计上遇到了难题。我尽力遵守SOLID原则,但我不知道如何处理依赖注入(inject)。这是我的困境:我读到在类中实例化对象以避免引入依赖性是一种不好的做法。那么在一个完整的对象应用程序中,我们的依赖应该在哪里创建呢?在一个只负责依赖实例化的特殊对象中?如果是,这个对象的名称是什么以及如何定义它?就是我们所说的“控制者”吗?这个“Controller”,对它进行单元测试的正确方法是什么?我们应该对其进行单元测试吗?在完整的POO应用程序中,如何避免在类之间传递我们的对象(通常是相同的)?例如,一个DB对象,Log,...这样,我们冒着拥有带有许多参数的构造函数的风险,不是吗?为了

php - Laravel 4 Controller 中的依赖注入(inject)实例所有对象

我想在Laravel4Controller中编写可测试的代码。我知道DI(依赖注入(inject)),我知道可测试代码可能如下所示:classUsersControllerextendsBaseController{publicfunction__construct(User$user,Notice$notice){$this->user=$user;$this->notice=$notice;}publicfunctiongetIndex(){...$this->user...$this->notice...}publicfunctiongetPage(){...$this->use

php - 将依赖注入(inject)容器传递给静态方法

我有一些传统类(class)。许多类是使用工厂类实例化的。还有一个单例类。将来我想用DIC完全取代它们。目前代码库很大,无法做到这一点。现在我的目标是将DI-Container注入(inject)到Singleton类实例化的每个服务中。Singleton类有一个带有此签名的静态方法。finalclassSingleton{privatestatic$singletonCache=array();publicstaticfunctiongetInstance($namespace,$className){}}我想检查这个函数的内部:$instance=new$className();i