我有 $_POST 变量从引号上有斜杠的标签传入。我知道魔术引号已关闭,并使用 if (get_magic_quotes_gpc()) 语句去除斜杠以防万一。但是,斜杠仍在添加。这是为什么?
表单
<form method="POST" action="">
<input type="text" name="spe_set" />
<input type="submit" value="Submit" />
</form>
PHP
print_r($_POST['spe_set']); // if I wrote "Test's", this prints as "Test\'s"
所以,我做到了,
if ( get_magic_quotes_gpc() )
$tempvar = stripslashes($_POST['spe_set']);
else
$tempvar = $_POST['spe_set'];
print_r($tempvar); // Still says "Test\'s"
最佳答案
我在网上找不到任何关于 get_magic_quotes_gpc() 返回错误结果的引用,所以我会给你一个 list 来尝试缩小问题的范围(这可能是一条评论,但它太长了):
我要做的第一件事是尝试编辑 php.ini 文件以确保 magic_quotes_gpc 确实设置为关闭。尝试此操作的最佳位置是在与有问题的脚本相同的目录中创建/编辑 php.ini 文件,因为这是在获取脚本之前可以覆盖 INI 设置的最后一个地方(并且 global_quotes_gpc 不能被重写为低于该值,因为在脚本运行时损坏已经完成)。
在您的 php.ini 文件中,添加以下行:
magic_quotes_gpc = Off
magic_quotes_runtime = Off
magic_quotes_sybase = Off
只有其中的第一个会影响 POST 变量(“gpc”代表“Get、Post 和 Cookies”),但最好全部设置它们,因为它们都很糟糕。
设置这些行后,您可以确定魔术引号真的关闭了。如果这解决了问题,那么您需要在目录结构中查找它首先打开的位置。这可能在更高目录的 php.ini 文件、.htaccess 文件,甚至是您的 http.conf 文件中。如果您不确定自己在这里做什么,您可能想让您的房东参与进来。
如果问题仍然存在,那么您应该检查脚本中是否有对 addslashes() 函数的调用。如果您使用的是 Linux,这很容易,因为您可以从项目的根目录运行命令 grep -ir "addslashes"*。如果您在 Windows 上运行,您应该查看 Cygwin、unxutils 或其他 unix 层。我绝对喜欢 unxutils,它是我在 Windows 设置或新工作中安装的第一批东西之一。
虽然我不明白为什么任何框架都会内置这样的东西,但我想有些白痴可能会尝试它。出于这个原因,您可能还应该确保对框架文件进行 grep。请务必检查框架提供的所有 php.ini 文件,尽管我在上面已经描述过这些文件。
最后,您应该确保设置 error_reporting到 E_ALL | E_STRICT。这可以从 php.ini 文件或使用 error_reporting() 完成。功能。确保在任何其他 PHP 运行之前设置此项。您应该始终使用最高的错误报告设置进行开发,这样您就可以在每个错误出现在用户面前之前看到它,无论多么小。为确保您可以看到这些错误,还要确保 display errors也已启用。
虽然您粘贴到问题中的代码示例是有效的,但我提到了 error_reporting 以防万一它不是从您的代码中直接复制/粘贴的,或者万一有其他代码导致错误。通过设置错误报告,您可以看到任何可能阻止 get_magic_quotes_gpc() 或 stripslashes() 正常运行的错误。如果您可以修复这些错误,您的其余代码将按预期工作。
祝你好运。
关于php - 魔术报价关闭,仍然斜线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6866686/
下面的代码在我第一次运行它时就可以正常工作:require'rubygems'require'spreadsheet'book=Spreadsheet.open'/Users/me/myruby/Mywks.xls'sheet=book.worksheet0row=sheet.row(1)putsrow[1]book.write'/Users/me/myruby/Mywks.xls'当我再次运行它时,我会收到更多消息,例如:/Library/Ruby/Gems/1.8/gems/spreadsheet-0.6.5.9/lib/spreadsheet/excel/reader.rb:11
我今天看到了一个ruby代码片段。[1,2,3,4,5,6,7].inject(:+)=>28[1,2,3,4,5,6,7].inject(:*)=>5040这里的注入(inject)和之前看到的完全不一样,比如[1,2,3,4,5,6,7].inject{|sum,x|sum+x}请解释一下它是如何工作的? 最佳答案 没有魔法,符号(方法)只是可能的参数之一。这是来自文档:#enum.inject(initial,sym)=>obj#enum.inject(sym)=>obj#enum.inject(initial){|mem
一段时间以来,我一直在使用open_uri下拉ftp路径作为数据源,但突然发现我几乎连续不断地收到“530抱歉,允许的最大客户端数(95)已经连接。”我不确定我的代码是否有问题,或者是否是其他人在访问服务器,不幸的是,我无法真正确定谁有问题。本质上,我正在读取FTPURI:defself.read_uri(uri)beginuri=open(uri).readuri=="Error"?nil:urirescueOpenURI::HTTPErrornilendend我猜我需要在这里添加一些额外的错误处理代码...我想确保我采取一切预防措施来关闭所有连接,这样我的连接就不是问题所在,但是我
我有一个super简单的脚本,它几乎包含了FayeWebSocketGitHub页面上用于处理关闭连接的内容:ws=Faye::WebSocket::Client.new(url,nil,:headers=>headers)ws.on:opendo|event|p[:open]#sendpingcommand#sendtestcommand#ws.send({command:'test'}.to_json)endws.on:messagedo|event|#hereistheentrypointfordatacomingfromtheserver.pJSON.parse(event.d
使用ruby的watir测试网络应用程序时,浏览器最后会保持打开状态。网上的一些建议是,要进行真正的单元测试,您应该在每次测试时(在拆卸调用中)打开和关闭浏览器,但这很慢而且毫无意义。或者他们做这样的事情:defself.suites=superdefs.afterClass#Closebrowserenddefs.run(*args)superafterClassendsend但这会导致摘要输出不再显示(诸如“100次测试、100次断言、0次失败、0次错误”之类的内容仍应显示)。我怎样才能让ruby或watir在我的测试结束时关闭浏览器? 最佳答案
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我来自C、php和bash背景,很容易学习,因为它们都有相同的C结构,我可以将其与我已经知道的联系起来。然后2年前我学了Python并且学得很好,Python对我来说比Ruby更容易学。然后从去年开始,我一直在尝试学习Ruby,然后是Rails,我承认,直到现在我还是学不会,讽刺的是那些打着简单易学的烙印,但是对于我这样一个老练的程序员来说,我只是无法将它
我想设置秒数aflash在自动关闭之前向用户显示通知。 最佳答案 您可以在页面上使用一些简单的JavaScript(在此示例中使用jQuery):$('document').ready(function(){setTimeout(function(){$('#flash').slideUp();},3000);});假设保存您的flash消息的HTML元素的id是#flash,这将向上滑动并在3000毫秒(3秒)后将其隐藏。 关于ruby-on-rails-如何在一段时间后关闭Rails
所以我正在使用acts_as_taggablegem提供的标签。这些帖子是我正在标记的内容。我怎么能说类似=>的东西(这里是伪代码)ifacollectionofPostshasatagwithacorrespondingStockQuote,displaythestockquote所以现在我有一个acts_as_taggable的Post资源。这是我的帖子索引操作现在的样子:defindex@stock=StockQuote::Stock.quote("symbol")ifparams[:tag]@posts=Post.tagged_with(params[:tag])else@po
在rails开发环境中,cache_classes是关闭的,所以你可以修改app/下的代码,不用重启服务器就可以看到变化。不过,在所有环境中,中间件只会创建一次。所以如果我有这样的中间件:classMyMiddlewaredefinitialize(app)@app=appenddefcall(env)env['model']=MyModel.firstendend我在config/environments/development.rb中执行此操作:config.cache_classes=false#thedefaultfordevelopmentconfig.middleware.
我有一个连接到服务器的rubytcpsocket客户端。在发送数据之前如何检查套接字是否已连接?我是否尝试“拯救”断开连接的tcpsocket,重新连接然后重新发送?如果是这样,有没有人有一个简单的代码示例,因为我不知道从哪里开始:(我很自豪我设法在rails中获得了一个持久连接的客户端tcpsocket。然后服务器决定杀死客户端,一切都崩溃了;)编辑我已经使用此代码解决了一些问题-如果未连接,它将尝试重新连接,但如果服务器已关闭则不会处理这种情况(它将继续重试)。这是正确方法的开始吗?谢谢defself.write(data)begin@@my_connection.write(