您的位置】:知源论文网 > 理工类论文 > 计算机 > 正文阅读资讯:网站设计的信息安全隐患预防

网站设计的信息安全隐患预防

[作者:未知[来源:互联网]| 打印 | 关闭 ]
有的标签,然后才能与黑名单中的标签进行对比。本系统采用的是寻找'<'和'>'来查找数据中的所有标签。标签中有可能出现嵌套,判定的方法是第1个'<'之后还有'<',并且在'>'之前,如果用$tagOpen_nested来记录第2个'<'的位置,$tagOpen_end来记录第1个'>'的位置,那么判断是否为嵌套的方法为:($tagOpen_nested!==false)&&($tagOpen_nested<$tagOpen_end)如果表达式为真的话那么必定是嵌套标签。

用$fromTagOpen记录'<'之后的所有字符串,那么当前处理的标签名为:$currentTag=substr($fromTagOpen,0,$tagOpen_end);当然还要检查是否为关闭标签,如果是关闭标签还要取出'/',检测和处理代码如下:if(substr($currentTag,0,1)=="/"){$isCloseTag=TRUE;$tagName=substr($tagName,1);}找到标签名之后,就可以进行过滤,代码如下if((!preg_match("/^[a-z][a-z0-9]*$/i",$tagName))||(!$tagName)||((in_array(strtolower($tagName),$this->tagBlacklist))&&($this->xssAuto))){$postTag=substr($postTag,($tagLength+2));$tagOpen_start=strpos($postTag,'<');}这样黑名单中的标签和那些非标准的html标签就被过滤掉了,过滤后的内容存储在$postTag中。

获取属性的方法就是在'<'和'>'之间'='两边就是属性名和属性值。代码如下while($currentSpace!==FALSE){$fromSpace=substr($tagLeft,($currentSpace+1));$nextSpace=strpos($fromSpace,'');$openQuotes=strpos($fromSpace,'"');$closeQuotes=strpos(substr($fromSpace,($openQuotes+1)),'"')+$openQuotes+1;if(strpos($fromSpace,'=')!==FALSE){if(($openQuotes!==FALSE)&&(strpos(sub-str($fromSpace,($openQuotes+1)),'"')!==FALSE))$attr=substr($fromSpace,0,($closeQuotes+1));else$attr=substr($fromSpace,0,$nextSpace);}else$attr=substr($fromSpace,0,$nextSpace);if(!$attr)$attr=$fromSpace;$attrSet[]=$attr;$tagLeft=substr($fromSpace,strlen($attr));$currentSpace=strpos($tagLeft,'');}这样所有的属性都被存进$attrSet数组中了。方便调用filterAttr()函数对属性进行过滤。

3结语

对电子商务网站设计中常见的漏洞进行了介绍,并针对电子商务网站常见的安全隐患和漏洞给出了相应的解决方案,尤其是本文设计的电子商务网站攻击过滤类,能很好的增加电子商务网站的信息安全性,使得消

Tags: