PHP (Hypertext Preprocessor)是一种 HTML 内嵌式的语言,也是目前比较流行的网页编程语言。它支持的后端数据库种类凡多,几乎含盖了当前的所有数据库系统。同时它包含了一般语言有的数学运算、时间处理、文件系统、字符串处理、行程处理等功能,再加上它是免费的系统,使得成本与效益比,几乎等于无限大。
下面是我在用PHP做网站时,总结出一些小技巧,拿出来飨以大家。
1、判断某个函数是否被支持
由于在PHP中我们可以灵活的使用增加或者减少php支持的模块,所以有的时候我们在使用PHP之前,总是会首先确定某个模块是否被加载,比如,看看GD图形模块是否被支持,可以用下面的这段代码:
<ol class="dp-c"> <li class="alt"><span><span class="keyword">if</span><span>(!function_exists(</span><span class="string">"imagecreate"</span><span>)) </span></span></li> <li><span>?> </span></li> </ol>
同样的道理,我们可以利用类似的代码,测试 MSSQL,OCI等模块是否被支持。
2、在字符串中把网址改成超级链接
在网页中提交表单时,经常在提交的说明文本中出现一些网址,比如个人主页等信息,如果在显示时自动将其转为超级链接,那将是一件很惬意的事,就像用WORD编辑文档时自动出现超级链接一样。下面这段代码就很好的实现了其功能。
<ol class="dp-c"> <li class="alt"><span><span class="vars">$string</span><span> = </span><span class="string">"连接赛迪网 站点"</span><span>; </span></span></li> <li> <span class="comment">//注:连接后需要有个空格或回车。 </span><span> </span> </li> <li class="alt"> <span class="vars">$string</span><span> = </span><span class="func">eregi_replace</span><span>(</span><span class="string">"http://([^ ,rn]*)"</span><span>,</span><span class="string">"<a href= tarrget=_blank></a>"</span><span>,</span><span class="vars">$string</span><span>); </span> </li> <li> <span class="vars">$string</span><span> = </span><span class="func">eregi_replace</span><span>(</span><span class="string">"ftp://([^ ,rn]*)"</span><span>,</span><span class="string">"<a href= target=_blank></a>"</span><span>,</span><span class="vars">$string</span><span>); </span> </li> <li class="alt"> <span>print </span><span class="vars">$string</span><span>; </span> </li> <li><span>?> </span></li> </ol><br>
3、用PHP处理多个同名复选框
如果一个表单中有多个同名复选框,在提交到php时却只有一个值,而并不像asp那样是一串用逗号分割的值。解决的方法是利用数组。将复选框的name后面加上[],例如: 改为:。这样php将得到一个叫pp的阵列。在提交的表单中先用Count(pp)来判断数组的个数即选中的个数,然后对数组进行分别处理就行了.
同样的道理也适应于处理下拉框的多选问题。
4、利用static实现表格的颜色隔行显示
我们用PHP从数据库查询数据,并将结果输出到浏览器上,如果结果有很多行,表格的bgcolor(背景色)如果全是单色的,浏览者会感觉不太舒服。那么怎样做使表格各行的颜色不同呢?请看下面代码:
<ol class="dp-c"> <li class="alt"><span><span class="keyword">function</span><span> getcolor() </span></span></li> <li><span>{ </span></li> <li class="alt"> <span class="keyword">static</span><span> </span><span class="vars">$colorvalue</span><span>;</span><span class="comment">//定义一个静态变量 </span><span> </span> </li> <li> <span class="keyword">if</span><span>(</span><span class="vars">$colorvalue</span><span>==</span><span class="string">"#eeeeee"</span><span>) </span> </li> <li class="alt"> <span class="vars">$colorvalue</span><span>=</span><span class="string">"#F5F5F5"</span><span>; </span> </li> <li> <span class="keyword">else</span><span> </span><span class="vars">$colorvalue</span><span>=</span><span class="string">"#eeeeee"</span><span>; </span> </li> <li class="alt"> <span class="keyword">return</span><span>(</span><span class="vars">$colorvalue</span><span>); </span> </li> <li><span>} </span></li> <li class="alt"> <span>print(</span><span class="string">"<table border=1>n"</span><span>);</span><span class="comment">//下面输出10行 </span><span> </span> </li> <li> <span class="keyword">for</span><span>(</span><span class="vars">$i</span><span>=0;</span><span class="vars">$i</span><span><span class="vars">$i</span><span>++) </span></span> </li> <li class="alt"><span>{ </span></li> <li> <span class="vars">$bcolor</span><span>=getcolor();</span><span class="comment">//换背景颜色 </span><span> </span> </li> <li class="alt"> <span>print(</span><span class="string">"<tr bgcolor=$bcolor>n"</span><span>); </span> </li> <li> <span>print(</span><span class="string">"<td>$i</td>n"</span><span>); </span> </li> <li class="alt"> <span>print(</span><span class="string">"</tr>"</span><span>); </span> </li> <li><span>} </span></li> <li class="alt"> <span>print(</span><span class="string">"</table>n"</span><span>); </span> </li> <li><span>?> </span></li> </ol>
说明:
此程序中定义了一个静态变量static $colorvalue意思是在函数调用结束后,此变量$colorvalue还保留值,没有消失。当再次调用getcolor()函数时,变量$colorvalue的值是上次函数调用结束时$colorvalue的值。
5、在php中避免重复引用的办法
大家知道,在C语言中,我们可以用#define来定义一个MACRO名字,通过检查是否该MACRO名字定义过来决定该头文件是否被引用。在PHP中也有同样的问题,比如:A引用B,C, B引用C,如果不采取措施,C将被引用2次。这样可能会导致一些奇怪的问题。解决办法:定义一个全局变量,并且通过检查该变量是否定义过来解决这个问题.办法很简单,类似C。 只是这个全局变量我建议都用["user_packages"] ["headfilename"]的命名规则。
<ol class="dp-c"> <li class="alt"><span><span class="keyword">if</span><span> (!</span><span class="func">empty</span><span class="keyword">empty</span><span>(</span><span class="vars">$GLOBALS</span><span>[</span><span class="string">"FOODTAILS"</span><span>][</span><span class="string">"GLOBALDEFINE"</span><span>])) </span><span class="keyword">return</span><span>; </span></span></li> <li> <span class="vars">$GLOBALS</span><span>[</span><span class="string">"FOODTAILS"</span><span>][</span><span class="string">"GLOBALDEFINE"</span><span>] = true; </span> </li> <li class="alt"> <span class="keyword">class</span><span> FOODTAILS ; </span> </li> <li><span>?> </span></li> </ol>
另外,在主程序中尽量采用require_once "headfiles.php"; 以避免重复引用。
6、如何避免表单的重复提交
我们在做网站时,常常为一些灌水文章而烦恼。有时,由于网络状况等原因用户不知道提交是否成功,也会再次提交同一份表单,这就造成了表单的重复提交不起。有一个简单的方法可以避免同一表单的重复提交。 首先,先定义一个session变量用来保存一个表单的提交序列号。这里我定义为“$userLastAction”。然后在表单里加入一个hidden变量,把值设为$userLastAction+1:> 最后,在处理提交之前判断表单是否已被提交过。
<ol class="dp-c"> <li class="alt"><span><span class="keyword">if</span><span>(</span><span class="vars">$lastAction</span><span>></span><span class="vars">$userLastAction</span><span>){ </span></span></li> <li> <span class="vars">$userLastAction</span><span>++; </span><span class="comment">// 序列号加1 </span><span> </span> </li> <li class="alt"> <span class="comment">// 处理表单数据 </span><span> </span> </li> <li><span>} </span></li> <li class="alt"><span>?> </span></li> </ol>
这个技巧的主要原理是不允许用户回退后再次提交,也就是说回退后修改再提交也是不允许的,但是还是不能避免Ctrl-C/Ctrl-V的灌水办法。
7、下载文件的下载次数回填
我们在下载软件时,经常会看到此软件的下载统计次数,而这些统计数给网站管理员分析软件的受欢迎程度带来了方便。其实现原理是:在后端数据库中存放软件的唯一标识和下载数,在用户下载软件时,首先更新对应软件的下载次数即下载次数加1,然后再到下载文件上正式开始下载。请看下面的实现代码:
a、先建一数据表download (后端用MySql)
download表中含有下列两个字段:
id 下载的文件的唯一标识
downnum 下载次数,默认值为0
b、实现
假设已经从数据库取出:描述文件名 五笔字型 ;下载文件名:wbzx.zip ;标识号id值为2
处理后生成的超级链接代码为:
五笔字型
下面的代码download.php处理下载次数累计及根据传递的文件名定位下载文件。
<ol class="dp-c"> <li class="alt"><span><span class="comment">//连接Mysql数据库代码略 </span><span> </span></span></li> <li> <span class="vars">$res</span><span>=mysql_query(</span><span class="string">"update download set downnum=(downnum+1) where id="</span><span class="vars">$id</span><span class="string">""</span><span> ,</span><span class="vars">$db</span><span>); </span> </li> <li class="alt"> <span>header(</span><span class="string">"location:$filename"</span><span>); </span> </li> <li><span>?> </span></li> </ol>

要保护应用免受与会话相关的XSS攻击,需采取以下措施:1.设置HttpOnly和Secure标志保护会话cookie。2.对所有用户输入进行输出编码。3.实施内容安全策略(CSP)限制脚本来源。通过这些策略,可以有效防护会话相关的XSS攻击,确保用户数据安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显着提升应用在高并发环境下的效率。

thesession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceIsiseededeedeedeedeedeedeedto to to avoidperformance andununununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函数配置会话名称。具体步骤如下:1.使用session_name()函数设置会话名称,例如session_name("my_session")。2.在设置会话名称后,调用session_start()启动会话。配置会话名称可以避免多应用间的会话数据冲突,并增强安全性,但需注意会话名称的唯一性、安全性、长度和设置时机。

会话ID应在登录时、敏感操作前和每30分钟定期重新生成。1.登录时重新生成会话ID可防会话固定攻击。2.敏感操作前重新生成提高安全性。3.定期重新生成降低长期利用风险,但需权衡用户体验。

在PHP中设置会话cookie参数可以通过session_set_cookie_params()函数实现。1)使用该函数设置参数,如过期时间、路径、域名、安全标志等;2)调用session_start()使参数生效;3)根据需求动态调整参数,如用户登录状态;4)注意设置secure和httponly标志以提升安全性。

在PHP中使用会话的主要目的是维护用户在不同页面之间的状态。1)会话通过session_start()函数启动,创建唯一会话ID并存储在用户cookie中。2)会话数据保存在服务器上,允许在不同请求间传递数据,如登录状态和购物车内容。

如何在子域名间共享会话?通过设置通用域名的会话cookie实现。1.在服务器端设置会话cookie的域为.example.com。2.选择合适的会话存储方式,如内存、数据库或分布式缓存。3.通过cookie传递会话ID,服务器根据ID检索和更新会话数据。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SublimeText3汉化版
中文版,非常好用

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),