PHP建站技术分享-从入门到精通_各类知识收集PHP建站技术分享-从入门到精通_各类知识收集PHP建站技术分享-从入门到精通_各类知识收集

QQ:420220301 微信/手机:150-3210-7690
当前位置:首页 > 工作总结

PHP学习:Yii框架防止sql注入,xss攻击与csrf攻击的方法

管理员 2025-02-21
工作总结
12

《PHP学习:Yii框架防止sql注入,xss攻击与csrf攻击的方法》要点:
本文介绍了PHP学习:Yii框架防止sql注入,xss攻击与csrf攻击的方法,希望对您有用。如果有疑问,可以联系我们。
 

相关主题:YII框架

PHP学习本文实例讲述了Yii框架防止sql注入,xss攻击与csrf攻击的方法.分享给大家供大家参考,具体如下:

PHP学习PHP中常用到的方法有:

PHP学习/* 防sql注入,xss攻击 (1)*/function actionClean($str){    $str=trim($str);    $str=strip_tags($str);    $str=stripslashes($str);    $str=addslashes($str);    $str=rawurldecode($str);    $str=quotemeta($str);    $str=htmlspecialchars($str);    //去除特殊字符    $str=preg_replace("//|~|!|@|#|\$|%|^|&|*|(|)|_|+|{|}|:|<|>|?|[|]|,|.|/|;|'|`|-|=|\||/", "" , $str);    $str=preg_replace("/s/", "", $str);//去除空格、换行符、制表符    return $str;}//防止sql注入.xss攻击(1)public function actionFilterArr($arr){    if(is_array($arr)){      foreach($arr as $k => $v){        $arr[$k] = $this->actionFilterWords($v);      }    }else{      $arr = $this->actionFilterWords($arr);    }    return $arr;}//防止xss攻击public function actionFilterWords($str){    $farr = array(      "/<(\/?)(script|i?frame|style|html|body|title|link|meta|object|\?|\%)([^>]*?)>/isU",      "/(<[^>]*)on[a-zA-Z]+s*=([^>]*>)/isU",      "/select|insert|update|delete|drop|'|/*|*|+|-|"|../|./|union|into|load_file|outfile|dump/is"    );    $str = preg_replace($farr,'',$str);    return $str;}//防止sql注入,xss攻击(2)public function post_check($post) {   if(!get_magic_quotes_gpc()) {     foreach($post as $key=>$val){       $post[$key] = addslashes($val);     }    }   foreach($post as $key=>$val){    //把"_"过滤掉    $post[$key] = str_replace("_", "_", $val);    //把"%"过滤掉    $post[$key] = str_replace("%", "%", $val); //sql注入    $post[$key] = nl2br($val);    //转换html    $post[$key] = htmlspecialchars($val); //xss攻击   }   return $post;}

PHP学习调用:

PHP学习//防止sql$post=$this->post_check($_POST);//var_dump($post);die;$u_name=trim($post['u_name']);$pwd=trim($post['pwd']);if(empty($u_name)||empty($pwd)){  exit('字段不能非空');}$u_name=$this->actionFilterArr($u_name);$pwd=$this->actionFilterArr($pwd);//防止sql注入,xss攻击$u_name=$this->actionClean(Yii::$app->request->post('u_name'));$pwd=$this->actionClean(Yii::$app->request->post('pwd'));$email=$this->actionClean(Yii::$app->request->post('email'));//防止csrf攻击$session=Yii::$app->session;$csrf_token=md5(uniqid(rand(),TRUE));$session->set('token',$csrf_token);$session->set('token',time());//接收数据if($_POST){  if(empty($session->get('token')) && $session->get('token')!=Yii::$app->request->post('token') && (time()-$session->get('token_time'))>30){    exit('csrf攻击');  }  //防止sql  .....

PHP学习(必须放在接收数据之外)

PHP学习注意:

PHP学习表单提交值,为防止csrf攻击,控制器中需要加上:

PHP学习//关闭csrfpiblic $enableCsrfValidation = false;

PHP学习更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

PHP学习希望本文所述对大家基于Yii框架的PHP程序设计有所帮助.

转载请注明本页网址:
/jiaocheng/3011.html


希望以上内容对你有所帮助!如果还有其他问题,请随时提问。 各类知识收集 拥有多年CMS企业建站经验,对 iCMS, LeCMS, ClassCMS, Fastadmin, PbootCMS, PHPCMS, 易优CMS, YzmCMS, 讯睿CMS, 极致CMS, Wordpress, HkCMS, YznCMS, WellCMS, ThinkCMF, 等各类cms的相互转化,程序开发,网站制作,bug修复,程序杀毒,插件定制都可以提供最佳解决方案。

相关推荐

扫码关注

qrcode

QQ交谈

回顶部