JavaScript快速入门-07-异常处理与调试
全部标签 在我的主SinatraController中,我想在从表单发布后调试参数散列。我已经添加了:putsparams.inspect和set:logging,:true如果一切顺利,params.inspect会起作用。但是,如果在执行Controller之前发生错误,我不会像默认情况下在Rails中那样获得有关错误的任何信息。获取有用调试信息的最佳方式是什么?Thisexample根本不起作用(在我添加此代码后应用程序甚至无法启动):configuredoLog=Logger.new("sinatra.log")Log.level=Logger::INFOend其次是:Log.info"
通过Sinatra路由您的请求的正确方法是什么,以便它在不进行任何处理的情况下提供文件?我正在寻找人们在Sinatra框架中执行此操作的最常见方式?我通常将所有静态内容放在“内容”路径中。例子:/内容/CSS/内容/图片/内容/js如何使用通配符提供内容下的所有内容?我很惊讶这里没有这样的真实例子:http://sinatra-book.gittr.com/ 最佳答案 Sinatra和Rails对静态内容使用路径public-例如,./public/javascripts/。这些路径中的所有文件随后将由Web服务器(例如Thin、P
根据“officiallysupportruby2.X”,我知道调试器gem不是也永远不会与ruby2.0兼容。在Ruby2.0的变更日志中是:DebugsupportDTracesupport,whichenablesrun-timediagnosisinproductionTracePoint,whichisanimprovedtracingAPIRuby2.0是否有开箱即用的调试工具?有人可以给我解释一下吗? 最佳答案 可以使用调试器gem,但它仍然存在问题。安装byebug这是为Ruby2.0调试而编写的。对于断点,请在
一种方式:javascript_tagdo=="varall_product_ids=#{existing_ids.to_json};"=="varproducts_json=#{@filter.data.to_json};"或:=%Q{varall_product_ids=#{existing_ids.to_json};varproducts_json=#{@filter.data.to_json};}有没有更好的解决方案? 最佳答案 slimjavascript:varall_product_ids="#{existing_id
我正在编写一个应用程序,它使用普通的旧Ruby对象(PORO)从Controller中抽象出授权逻辑。目前,我有一个名为NotAuthorized的自定义异常类,我在Controller级别rescue_from,但我很想知道:DoesRails4alreadycome有一个异常(exception)表明某项操作未获授权?我是否通过实现此异常(exception)来重新发明轮子?澄清:引发AuthorizationException不会发生在Controller内部的任何地方,它发生在Controller外部完全分离的PORO内部。该对象不知道HTTP、路由或Controller。
我正在尝试在Rails4中同时处理多个请求,我在Rails3中使用config.threadsafe!和Puma可以很轻松地做到这一点。假设我有这个ControllerclassConcurrentController我过去可以使用puma-t2:16-p3000(对于最少2个线程)启动puma,然后点击index然后show并且仍然可以正确呈现show。在Rails4中,如果我尝试做同样的事情,Puma现在会锁定index请求并且show永远不会被渲染。当我为服务器按下Ctrl-C时,Puma给我这个错误:Rackapperror:#为了让Rails4并发工作,我在这里缺少什么?co
有一种方法可以将ruby条件放入javascriptblock中吗?即javascript:varconfig={common_value_1:1,common_value_2:2};-ifmy_value===true#thismustbearubyconditionconfig.custom_true_value_1="1";config.custom_true_value_2="#{my_value}";-elseconfig.custom_false_value_1="1";config.custom_false_value_2="#{my_value}";或者是否有其他解
我正在寻找异常处理经典问题的解决方案。考虑以下代码:deffoo(n)puts"for#{n}"sleepnraise"after#{n}"endbeginthreads=[][5,15,20,3].eachdo|i|threadseputs"EXCEPTION:#{e.inspect}"puts"MESSAGE:#{e.message}"end此代码在5秒后捕获异常。但是如果我将数组更改为[15,5,20,3],上面的代码会在15秒后捕获异常。简而言之,它总是捕获第一个线程中引发的异常。任何想法,为什么会这样。为什么每次3秒后不捕获异常?我如何捕获任何线程引发的第一个异常?
我正在使用RubyonRails3,我想在命名空间中处理模型(类)命名空间。也就是说,如果我有一个名为NS1的命名空间和一个名为NS2的命名空间的“子命名空间”,我想在中处理模型(类)NS2。如果我运行一个脚手架railsgeneratescaffoldns1/ns2/Articleid:integertitle:string它将生成以下模型文件:models/ns1/ns2/article.rbfilemodels/ns1/articles.rbmodels/ns1/articles.rb包含:moduleNs1::Articlesdefself.table_name_prefix'
您可以创建异常的子类以使其更具描述性,但是您应该如何设置默认的“消息”?classMyErrorepe.messageendbeginraiseMyErrorraiseException=>epe.messageend第一个应该输出'Acustommessage'第二个应该输出'You'vetriggeredaMyError'关于最佳实践有什么建议吗? 最佳答案 定义一个初始化方法,它将消息作为具有默认值的参数。然后使用该消息调用StandardError的初始化方法(使用super)。classMyError