总结
豆包 AI 助手文章总结

php安全

php中文网
发布: 2016-06-23 14:35:56
原创
1492人浏览过

一、安全威胁

机密数据的泄漏
数据丢失和数据损坏
数据修改
拒绝服务 dos
软件错误
否认

二、web安全的应用
处理安全性问题的策略
识别所面临的威胁
了解与我们打交道的用户
代码的安全性
web服务器和php的安全性
数据库服务器的安全性
保护网络
计算机和操作系统的安全性
灾难计划

a.识别所面临的威胁
访问或修改敏感数据
数据丢失或破坏
拒绝服务
恶意代码注入

一、安全和加密

立即学习PHP免费学习笔记(深入)”;

很多安全问题都是由于轻信了第三方提供的数据造成的。比如对于输入数据,在对其进行
验证之前都应该将其视为嫌疑数据。
如果是把嫌疑数据发送给用户浏览器,就可能导致跨站点脚本(XSS)问题。
如果把嫌疑数据用于SQL查询,那么有可能会造成SQL注射问题。

二、过滤
在使用第三方提供的数据,包括你的用户提供的数据时,首先检验其合法性非常重要。这个过
程叫过滤

加密的本质就是扰乱数据。


三、预防Session定置


方案:
只要用户的授权范围改变,如成功登录后,就通过session_regenerate_id()来重
新生成session标识符:
session_regenerate_id();
$_SESSION['logged_in']=true;
?>
四、过滤输入

你需要确保在使用所用输入数据之前先进行过滤。
方案:
初始化一个空数组用于保存过滤后的数据。在验证输入有效后,将输入保存到这
个数组中。

五、避免跨站点脚本

安全地消除跨站点脚本(XSS)对你的PHP应用程序的攻击。
方案:
通过htmlentities()对所有HTML输出进行转义,并保证指明正确的字符编码:
六、避免SQL注入

七、将密码置于站点文件外部

第一章 如何写一个安全的表单

  1.声明一个安全数组

  2.过滤和判断

  3.删除多余的键值

  4.更新

代码DEMO:   

  if(isset($_POST['dosubmit'])) {
    $info = array();
    $info = checkuserinfo($_POST['info']);

    if(isset($info['password']) && !empty($info['password']))
      {
    $this->op->edit_password($info['userid'], $info['password']);
     }
    $userid = $info['userid'];

    //删除多余键值
    $admin_fields = array('username', 'email', 'roleid','realname');
    foreach ($info as $k=>$value) {
    if (!in_array($k, $admin_fields)){
    unset($info[$k]);
    }
    }
    //更新
  $this->db->update($info,array('userid'=>$userid));

  showmessage(L('operation_success'),'','','edit');

}

 http://os.51cto.com/art/201204/328938.htm

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
豆包 AI 助手文章总结
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号