jjzjj

ruby - Shotgun 上的 Sinatra 和 Ruby 1.9.2 问题

我有一个简单的sinatra应用。require'rubygems'require'sinatra'get'/'do"Hello"end当我在Shotgun上运行它时,出现以下错误:BootErrorSomethingwentwrongwhileloadingsimple.rbLoadError:nosuchfiletoload--simple.rb:29:inrequire':29:inrequire'/home/thedinga/.rvm/gems/ruby-1.9.2-p0@global/gems/shotgun-0.8/lib/shotgun/loader.rb:114:ini

ruby - Sinatra:点击 URL 时运行 ruby​​ 代码

我想在每次访问url/code时运行一个脚本(code.rb)。如何运行脚本?require'sinatra'get'/'do#runthescriptend 最佳答案 要么fork另一个进程:system('rubycode.rb')...或者简单地将脚本加载到当前上下文中:load'code.rb'#*not*require 关于ruby-Sinatra:点击URL时运行ruby​​代码,我们在StackOverflow上找到一个类似的问题: https:

ruby - 如何在 heroku 中使用 haml?

我尝试使用sinatra让haml在没有gem的情况下工作(据我所知,Heroku不允许安装gem)到目前为止我做了什么:在我的项目中克隆hamlgitrepo在我的sinatra主文件中添加:require'haml/lib/haml.rb'以下作品:get'/test'doHaml::Engine.new('%ptest').renderend但以下不是:get'/test2'dohaml:my_templateend我得到错误:NoMethodError-nil:NilClass的未定义方法each'(haml):20:inrender'./haml/lib/haml/engin

ruby - 在一个进程多个数据库连接 sinatra 应用程序中使用什么 ORM?

已检查ActiveRecord、DataMapper、Sequel:有些使用全局变量(静态变量)有些需要在使用模型加载源文件之前打开数据库连接。在使用不同数据库的sinatra应用程序中使用哪种ORM更好。 最佳答案 DataMapper专为多数据库使用而设计。你可以通过像DataMapper.setup(:repository_one,"mysql://localhost/my_db_name")这样的方式设置多个存储库。DataMapper随后会跟踪所有已在哈希中设置的存储库,您可以引用该哈希并将其用于范围界定:DataMapp

ruby - Sinatra 在 Ruby 1.9.2-p0 上找不到 View

我对Ruby语言还很陌生(到目前为止我是用Groovy+Grails开发的)但是因为我对它很好奇所以我想在Ruby1.9.2-p0上试用Sinatra。我有一个简单的网站,它包含在/mywebpage中并且有2个文件:#blog.rbget'/'do'HelloWorld!'endget'/impossible'dohaml:indexend和#config.rupath=File.expand_path"../",__FILE__$LOAD_PATH然后在同一个文件夹中,我有一个包含index.haml的/views/文件夹。我尝试使用rackup-p8080运行服务器,但是当我尝试

ruby - Sinatra 路由中定义的全局变量是否在请求之间共享?

假设我有:get'/'do$random=Random.rand()response.body=$randomend如果我每秒有数千个请求到达/,$random是否会被共享并“泄漏”到上下文之外,或者它会像getblock的“本地”变量一样?我想如果它是在get'/'do的上下文之外定义的,它确实会被共享,但我想知道在ruby​​中是否有我不知道的$机制。 最佳答案 ThispartoftheSinatraREADMEaboutscopeisalwayshelpfultoread但是,如果您只需要为请求保留变量,那么我认为我建议使用

ruby-on-rails - 为什么需要在 Rails 3 中重新加载代码?

我是一名前PHP开发人员,正在学习Rails和Sinatra。在PHP中,每个页面请求都会加载所有必需的文件。如果我更改了一些代码并刷新了页面,我可以确定代码是新的。在Rails3中,Controller代码在每次请求时都是最新的。但是,如果我修改/lib文件夹中的任何代码,我需要重新启动服务器以使更改生效。为什么会这样?这与Ruby的设计方式有关吗?Rails是否进行了一些优化以避免在每次请求时重新加载代码?谢谢!编辑:我最感兴趣的是幕后发生的事情。像Rails和Sinatra这样的框架是否为类做了一些特殊的缓存?如果是这样,他们做什么?Ruby中的默认行为是在每次请求时重新加载所有

ruby - Camping 和 Sinatra 之间有什么重要区别吗?

我的感觉是Camping和Sinatra之间的差异不是很大,您可以安全地选择其中任何一个并且没问题。但我想问问Ruby专家,这是不是真的。Sinatra和Camping微框架之间实际上有什么重要区别吗?您将如何决定使用哪一个? 最佳答案 我知道的唯一显着区别是Camping像Rails一样基于MVC模式,并且与ActiveRecord耦合。Sinatra更加不可知。Camping也不再维护,而Sinatra正在积极开发中。仅这一点就足以让我们先看看Sinatra。编辑:感谢Philippe的更正,很高兴听到Camping的开发正在进

ruby - 如何更改 Sinatra 中的日志级别

我正在使用此代码在我的Sinatra应用程序中启用日志记录:log_file=File.new('my_log_file.log',"a")$stdout.reopen(log_file)$stderr.reopen(log_file)$stdout.sync=true$stderr.sync=true实际的日志记录是使用:logger.debug("Startingcall.Params=#{params.inspect}")事实证明,只有INFO或更高级别的日志消息被记录,而DEBUG消息没有被记录。我正在寻找一种将日志级别设置为DEBUG的方法。 最佳

ruby - 尝试授权服务器到 ruby​​ 中的服务器类型应用程序以访问 Google 日历时无效授权

我正在尝试为自己创建一个直接连接到我的日历的应用程序……但我从不想参与重新验证。我只想编写一次身份验证代码并完成它。授权码如下:key=Google::APIClient::PKCS12.load_key(SERVICE_ACCOUNT_PKCS12_FILE_PATH,PASSWORD)asserter=Google::APIClient::JWTAsserter.new(SERVICE_ACCOUNT_EMAIL,'https://www.googleapis.com/auth/calendar',key)@client=Google::APIClient.new@client.a