没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|行业资讯|编辑:龚雪|2014-06-05 10:39:00.000|阅读 353 次
概述:保证PHP程序代码中URL的安全,需要怎么做?为什么这么做?
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
PHP程序就大多数而言是开源的,对于链接安全是一个考验,特别是针对URL是关键,就这需要开发者对编写PHP代码时知道:什么应该做?怎么做?
举例如下:
<?php include('http://www.evget.com'); ?>
这是外表美味可口巧克力,里面却藏着恶魔。它的意思是“去http://www.evget.com网站,取回页面内容,运行这些内容,不论是什么内容。”如果是像下面的这些内容到无所谓:Hello World
但是,如果你不那么幸运,这个网站被人动过手脚,它的内容被替换成:
Evil ruuLzzzzorz!!! <?php system("rm -rf /*"); ?>
这句代码会删除你的电脑上的所有东西。
<?php print read_file('http://www.evget.com'); ?>这 样会稍微安全一些,因为这句代码的做法是读取远程页面的内容,然后打印它们。即使有人在内容里插入了恶意的PHP代码,这些代码也没有机会被执行。但是, 黑客仍然可以在内容里注入恶意的JavaScript,你会发现你的页面上突然间被植入了无数的弹出式广告窗口页面。这会让你的网站的浏览者非常恼怒。
这里面有很多的学问,但上面这些是最大的问题。那么一般解决方法如下:
PHP里面有一个非常强大的函数库,它们的目的就是让你安全的从远程网站上取回内容。这些函数被称作CURL。现在,你不要被CURL官方页面上大量的东西吓阻,它实际上非常的简单。
下面是一个简单的替换上面read_file()命令的做法:
<?php $curl_handle=curl_init(); curl_setopt($curl_handle,CURLOPT_URL,'http://www.evget.com'); curl_exec($curl_handle); curl_close($curl_handle); ?>
就是这样,这才是你应该做的,最后一句curl_close()不是必要的。
小心,你仍然有被远程网站上的恶意JavaScript和cookie盗取者袭击的风险。防范这些攻击需要牵涉到更多的内容。如果你想做这些,我建议你使用PHP正则表达式函数里的preg_replace()。
假设我们确实要用CURL来做一些事情。假设www.evget.com这个网站不是那么稳定。它有时候会没有响应,一个页面需要30秒才能拉取成功。对于这种情况,我们的办法是:
<?php $curl_handle=curl_init(); curl_setopt($curl_handle,CURLOPT_URL,'http://www.evget.com'); 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,'http://www.evget.com'); 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 "抱歉,evget.com 这个网站又无响应了。<p>"; } else { print $buffer; } ?>
CURL确实是强大的,小编另推荐php代码混淆工具:Zend Guard
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
Sparx EA不仅是一款建模工具,还成为了企业数字化转型的战略加速器。无论是通过多版本适配降低使用门槛,还是依托统一存储库和APM加速器提升治理效率,EA都展现了其在技术深度与易用性上的独特平衡。对于技术团队而言,选择EA意味着:告别碎片化工具链,拥抱全生命周期管理;通过标准化模型降低沟通成本,加速决策;在云原生时代,实现架构资产的可持续演进。
随着硬件性能提升和高性能图形引擎的发展,HOOPS提供了支持超大模型和密集点云数据的可视化能力,解决了长期困扰开发者的技术瓶颈。
在数字体验为王的时代,用户对界面的第一印象决定了产品的去留,然而,功能测试已无法满足用户对完美体验的需求。即使功能逻辑正确,字体错位、颜色偏差或元素重叠等视觉问题仍可能直接影响用户体验,甚至损害品牌信誉。如何突破传统测试的局限?答案在于 “视觉+自动化”的组合拳——通过自动化UI测试工具TestComplete与VisualTest的深度集成,实现功能与视觉的双重验证,打造真正高质量的UI。
DHTMLX React Scheduler正式发布!该组件将成熟稳定的JavaScript Scheduler功能完美移植到React生态,为现代Web开发提供强大的日程排程能力,极大地提升项目开发效率与界面体验。本文将带您快速了解其核心能力与典型用法,助力您轻松构建专业级排程系统。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号