• 技术文章 >后端开发 >php教程

    PHP安全技术之 实现php基本安全_PHP教程

    2016-07-21 15:34:15原创461
    1.不要依赖注册全局变量功能(register_globals)

    注册全局变量的出现曾经让PHP变得非常易用,但也降低了安全性(方便之处经常会破坏安全性)。建议在编程时把register_globals指令关闭,在PHP6中这个功能也会被取消。

    2.在使用变量之前对其进行初始化。

    如果register_globals功能是启动的,即使程序员不使用它,恶意用户也可能利用为初始化变量的漏洞来侵入我们的系统。比如:

    if(conditon){

    $auth=TRUE;

    }

    如果变量$auth没有在这段之前被初始化为FALSE,那么用户就可以向脚本传递$_GET[‘auth']、$_POST[‘auth']或$_COOKIE[‘auth']轻易的实现验证。

    3.检验和净化全部输入数据。

    4.在利用变量引用包含文件时要小心。

    如果脚本中有这样的代码:

    require($page);

    那么就应该确保$page不会来自外部资源(比如$_GET),或者,如果它的确来自于外部资源,那么就要确保它包含适当的值。

    5.在使用任何服务器上执行命令的函数都要多加小心。

    这些函数包括eval()、exec()、system()、passthru()、popen()和反撇号(``)。这些函数都能够在服务器上执行命令,永远都不要随意使用。如果在命令里不得不包含便来那个,就应该对这个变量进行彻底的安全检查。还应该使用escapeshellarg() escapeshellcom()进行额外的预处理。

    6.更改默认的会话目录,或者使用数据库保存会话数据。

    7.不要使用浏览器提供的文件名在服务器上保存上传的文件。

    8.如果被提交的数据需要在web页面中重新显示,一定要注意其中的HTML,更重要的是JAVASCRIPT

    可以利用函数

    string htmlspecialchars ( string string [, int quote_style [, string charset]])

    对提交的数据进行处理

    9。不要在站点上暴露你的PHP错误信息

    PHP错误信息能够在你开发的过程中把错误信息输出方便你的检查,但是如果暴露在Web上面,很可以成为攻击者的入口。

    10.防止SQL注入攻击。

    应该使用特定语言的数据库转义函数,比如mysqli_real_escape_data(),确保提交的内容不会破坏查询操作。

    11.永远不要在服务器上保存phpinfo()脚本。

    www.bkjia.comtruehttp://www.bkjia.com/PHPjc/322426.htmlTechArticle1.不要依赖注册全局变量功能(register_globals) 注册全局变量的出现曾经让PHP变得非常易用,但也降低了安全性(方便之处经常会破坏安全性...

    php入门到就业线上直播课:查看学习

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:PHP 安全 技术 实现 php 基本 不要 依赖 注册 全局 变量 功能 register globals
    上一篇:PHP isset()与empty()的使用区别详解_PHP教程 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 你知道如何用PHP实现多进程吗• 求解:phpcms模板怎样转码?该怎么解决• php怎的快捷知道某个函数在哪个文件用过• CI框架源码阅览-Model.php • 这个网站有源程序吗?高手一上,拜谢
    1/1

    PHP中文网