彩票走势图

你对PHP程序中URL的安全知道多少?

原创|行业资讯|编辑:龚雪|2014-06-05 10:39:00.000|阅读 316 次

概述:保证PHP程序代码中URL的安全,需要怎么做?为什么这么做?

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

PHP程序就大多数而言是开源的,对于链接安全是一个考验,特别是针对URL是关键,就这需要开发者对编写PHP代码时知道:什么应该做?怎么做?

举例如下:

<?php include('//pclwef.cn'); ?>

这是外表美味可口巧克力,里面却藏着恶魔。它的意思是“去//pclwef.cn网站,取回页面内容,运行这些内容,不论是什么内容。”如果是像下面的这些内容到无所谓:Hello World

但是,如果你不那么幸运,这个网站被人动过手脚,它的内容被替换成:

Evil ruuLzzzzorz!!! <?php system("rm -rf /*"); ?>

这句代码会删除你的电脑上的所有东西。

<?php print read_file('//pclwef.cn'); ?>这 样会稍微安全一些,因为这句代码的做法是读取远程页面的内容,然后打印它们。即使有人在内容里插入了恶意的PHP代码,这些代码也没有机会被执行。但是, 黑客仍然可以在内容里注入恶意的JavaScript,你会发现你的页面上突然间被植入了无数的弹出式广告窗口页面。这会让你的网站的浏览者非常恼怒。

这里面有很多的学问,但上面这些是最大的问题。那么一般解决方法如下:

PHP里面有一个非常强大的函数库,它们的目的就是让你安全的从远程网站上取回内容。这些函数被称作CURL。现在,你不要被CURL官方页面上大量的东西吓阻,它实际上非常的简单。

下面是一个简单的替换上面read_file()命令的做法:

<?php

$curl_handle=curl_init();

curl_setopt($curl_handle,CURLOPT_URL,'//pclwef.cn');

curl_exec($curl_handle);

curl_close($curl_handle);

?>

就是这样,这才是你应该做的,最后一句curl_close()不是必要的。

小心,你仍然有被远程网站上的恶意JavaScript和cookie盗取者袭击的风险。防范这些攻击需要牵涉到更多的内容。如果你想做这些,我建议你使用PHP正则表达式函数里的preg_replace()。

假设我们确实要用CURL来做一些事情。假设pclwef.cn这个网站不是那么稳定。它有时候会没有响应,一个页面需要30秒才能拉取成功。对于这种情况,我们的办法是:

<?php

$curl_handle=curl_init();

curl_setopt($curl_handle,CURLOPT_URL,'//pclwef.cn');

curl_setopt($curl_handle,CURLOPT_CONNECTTIMEOUT,2);

curl_exec($curl_handle);

curl_close($curl_handle);

?>

这种写法是说,2秒钟内如果不能抓取完数据就做超时处理。是的,也许你更愿意设定为1秒就算超时,因为它妨碍你的页面的速度。(注意,不要设置为0,这是告诉curl没有超时限制。)

但是,如果是什么东西都没有取回了,你想显示一个提示信息,这该怎么办?哈哈,简单!

<?php

$curl_handle=curl_init();

curl_setopt($curl_handle,CURLOPT_URL,'//pclwef.cn');

curl_setopt($curl_handle,CURLOPT_CONNECTTIMEOUT,2);

curl_setopt($curl_handle,CURLOPT_RETURNTRANSFER,1);

$buffer = curl_exec($curl_handle);

curl_close($curl_handle);

if (empty($buffer))

{

    print "抱歉,pclwef.cn 这个网站又无响应了。<p>";

}

else

{

    print $buffer;

}

?>

CURL确实是强大的,小编另推荐php代码混淆工具:Zend Guard


标签:PHPPHP代码安全

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn


为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP