资讯中心
News
公司网站经常遇到安全漏洞及防御方法
发布时间:2022-10-09 00:00   您所在的位置: 网站首页 > 新闻资讯 > 建站智库
现在,基于PHP的网站开发已经成为现在网站开发的主流,新概念小编从PHP网站攻击与保险防范方面开展探究,旨在减少网站漏洞,希望对大伙有所赞助! 一、常见PHP网站保险漏洞 相对PHP的漏洞,现在常见的漏洞有五种。分别是Session文件漏洞、SQL注入漏洞、脚本命令执行漏洞、全局变量漏洞和文件漏洞。这里分别对这些漏洞开展简要的介绍。 1、session文件漏洞 Session攻击是黑客更常用到的攻击手段之一。当一个顾客浏览某一个网站时,为了免客户每进人一个页面都要输人账号和密码,PHP设置了Session和Cookie用于方便顾客的使用和访向。 2、SQL注入漏洞 在开展网站开发的时候,程序员由于对顾客输人数据缺乏全面判断或者过滤不严使得服务器执行一部分恶意信息,比如顾客信息查询等。黑客可以依据恶意程序返回的结果获取相应的信息。这便是月行胃的SQL注入漏洞。 3、脚本执行漏洞 脚本执行漏洞常见的原因是由于程序员在开发网站时对顾客提交的URL参数过滤较少引起的,顾客提交的URL可能包含恶意代码使得跨站脚本攻击。脚本执行漏洞在以前的PHP网站中经常存在,不过伴随着PHP版本的升级,这些间题已经减少或者不存在了。 4、全局变量漏洞 PHP中的变量在使用的时候不像其他开发语言那样必须要事先声明,PHP中的变量可以不经声明就直接使用,使用的时候系统自动创建,而且也不必须要对变 量类型开展表明,系统会自动依据上下文环境自动确定变量类型。这种方法可以大大减少程序员编程中出错的概率,使用起来特别的方便。 5、文件漏洞 文件漏洞通常是由于网站开发者在开展网站制作时对外部提供的数据缺乏充分的过滤使得黑客利用其中的漏洞在Web进程上执行相应的命令。假如在 lsm.php中包含这样子一段代码:include($b.”/aaa.php”.),这对黑客来说,可以通过变量$b来实现远程攻击,可以是黑客自已的代码,用来实现对网站的攻击。可以向服务器提交a.php include=http://lZ7.0.0. 1/b.php,然后执行b.php的指令。 二、PHP常见漏洞的防范措施 1、相对Session漏洞的防范 从前面的剖析可以知道,Session攻击更常见的便是会话劫持,也便是黑客通过多种攻击手段获取顾客的Session ID,然后利用被攻击顾客的身份来登录相应网站。为此,这里可以用以下几种方法开展防范:一是定期改换Session ID,改换Session ID可以用PHP自带函数来实现;二是改换Session名称,通常情况下Session的默认名称是PHPSESSID,这样的变量一般是在cookie中保留的,假如更改了它的名称,就可以阻档黑客的部分攻击;三是对透明化的Session ID开展关闭处置,所谓透明化也便是指在http请求没有使用cookies来制定Session id时,Sessioin id使用链接来传递.关闭透明化Session ID可以通过操作PHP.ini文件来实现;四是通过URL传递隐藏参数,这样子可以确保即使黑客获取了session数据,不过由于相应参数是隐藏的,它也很难获得Session ID变量值。 2、对SQL注入漏洞的防范 黑客开展SQL注入手段好多,而且灵活多变,不过SQL注人的共同点便是利用输入过滤漏洞。因此,要想从根本上防止SQL注入,根本解决措施便是加强对请求命令尤其是查询请求命令的过滤。具体来说,包含以下几点:一是把过滤性语句开展参数化处置,也便是通过参数化语句实现顾客信息的输入而不是直接把顾客输入嵌入到语句中。二是在网站开发的时候尽可能少用解释性程序,黑客经常通过这种手段来执行非法命令;三是在网站开发时尽可能防止网站出现bug,否则黑客可能利用这些信息来攻击网站;仅仅通过防御SQL注入还是不够的,另外还需要经常使用专业的漏洞扫描工具对网站开展漏洞扫描。 3、对脚本执行漏洞的防范 黑客利用脚本执行漏洞开展攻击的手段是多种多样的,而且是灵活多变的,对此,必须要采用多种防范方法综合的手段,才能有效防止黑客对脚本执行漏洞开展攻击。这里常用的方法方法有以下四种。一是对可执行文件的路径开展预先设定。可以通过safe_moade_exec_dir来实现;二是对命令参数开展处置,一般用escapeshellarg函数实现;三是用系统自带的函数库来代替外部命令;四是在操作的时候进可能减少使用外部命令。 4、对全局变量漏洞防范 相对PHP全局变量的漏洞问题,以前的PHP版本存在这样子的问题,不过伴随着PHP版本升级到5.5以后,可以通过对php.ini的设置来实现,设置ruquest_order为GPC。另外在php.ini配置文件中,可以通过对Magic_quotes_runtime开展布尔值设置能否对外部引人的数据中的溢出字符加反斜线。为了确保网站程序在服务器的任何设置状态下都能运行。可以在整个程序开始的时候用get_magic_quotes_runtime检测设置状态确定能否要手工处置,或者在开始(或不必须要自动转义的时候)用set_magic_quotes_runtime(0)关掉。 5、对文件漏洞的防范 相对PHP文件漏桐可以通过对服务器开展设置和配置来到达防范目的。这里具体的操作如下:一是把PHP代码中的错误提示关闭,这样子可以防止黑客通过错误提示获取数据库信息和网页文件物理路径;二是对open_basedir尽心设置,也便是对目录外的文件操作开展禁止处置;这样子可以对本地文件或者远程文件起到保护作用,防止它们被攻击,这里还需要注意防范Session文件和上载文件的攻击;三是把safe-made设置为开启状态,从而对将要执行的命令开展规范,通过禁止文件上传,可以有效的提高PHP网站的保险系数。
本文章由新概念互动原创,如没特殊注明,转载请注明来自:http://www.jianzhan0.com/zhiku/76790.html