zoukankan      html  css  js  c++  java
  • php过滤表单提交的html等危险代码

    表单提交如果安全做得不好就很容易因为这个表单提交导致网站被攻击了,下面我来分享两个常用的php过滤表单提交的危险代码的实例,各位有需要的朋友可参考。

    PHP过滤提交表单的html代码里可能有被利用引入外部危险内容的代码。例如,有些时候用户提交表单中含有html内容,但这可能造成显示页面布局混乱,需要过滤掉。

    方法一:

    复制代码 代码如下:

    //get post data
     function PostGet($str,$post=0)
     {
      empty($str)?die('para is null'.$str.'!'):'';
     
      if( $post )
      {
       if( get_magic_quotes_gpc() )
       {
        return htmlspecialchars(isset($_POST[$str])?$_POST
    [$str]:'');
       }
       else
       {
        return addslashes(htmlspecialchars(isset($_POST[$str])?
    $_POST[$str]:''));
       }
      
      }
      else
      {
       if( get_magic_quotes_gpc() )
       {
        return htmlspecialchars(isset($_GET[$str])?$_GET[$str]:'');
       }
       else
       {
        return addslashes(htmlspecialchars(isset($_GET[$str])?
    $_GET[$str]:''));
       }
      }
     }

    方法二:

    复制代码 代码如下:

    function uhtml($str)    
    {    
        $farr = array(    
            "/s+/", //过滤多余空白    
             //过滤 <script>等可能引入恶意内容或恶意改变显示布局的代码,如果不需要插入flash等,还可以加入<object>的过滤    
            "/<(/?)(script|i?frame|style|html|body|title|link|meta|?|\%)([^>]*?)>/isU",   
            "/(<[^>]*)on[a-zA-Z]+s*=([^>]*>)/isU",//过滤javascript的on事件    
       );    
       $tarr = array(    
            " ",    
            "<123>",//如果要直接清除不安全的标签,这里可以留空    
            "12",    
       );    
      $str = preg_replace( $farr,$tarr,$str);    
       return $str;    
    }  
  • 相关阅读:
    程序命名规则
    CSS样式常用命名参考
    转:数据挖掘资料收集
    javascript占位符
    网站目录,文件夹命名规范
    IIS HTTP 500 内部服务器错误完美解决 IIS 服务器无法加载应用程序 '/LM/W3SVC/1/ROOT'。错误是 '没有注册类别
    人事工资合同管理系统菜单截图
    Vs 正则表达式 查找替换 微软权威参考
    什么是DNS,A记录,子域名,CNAME别名,MX记录,TXT记录,SRV 记录,TTL值
    MT主机控制面板Plesk 使用指南
  • 原文地址:https://www.cnblogs.com/huangshikun/p/7000147.html
Copyright © 2011-2022 走看看