我在我的模型中使用这个正则表达式来验证用户提交的URL。我不想强制用户输入http部分,但如果它不存在,我想自己添加。validates:url,:format=>{:with=>/^((http|https):\/\/)?[a-z0-9]+([-.]{1}[a-z0-9]+).[a-z]{2,5}(:[0-9]{1,5})?(\/.)?$/ix,:message=>"isnotvalid"}知道我该怎么做吗?我对验证和正则表达式的经验很少.. 最佳答案 如果它不存在,使用前置过滤器添加它:before_validation:sma
推送到Heroku的一个不好的方面是我必须在运行我的数据库迁移之前推送代码(并且服务器会自动重启)。这显然会导致用户在没有新表/属性的情况下浏览具有新代码的网站时出现大约500个错误:Heroku提出的解决方案是使用维护模式,但我想要一种没有缺点的方法让我的webapp运行每次!有办法吗?例如Capistrano:我准备将代码部署到新目录我运行(向后)迁移,旧代码继续完美运行我将mongrel实例切换到新目录并重新启动服务器...而且我没有停机时间! 最佳答案 您可以设置第二个Heroku应用程序,它指向与主要生产应用程序相同的数据
正如标题所说,Google没有提供任何与此相关的有用信息。如何为Sinatra应用设置和配置HTTPS/SSL?如何创建HTTPS路由?我以前从未在我的应用程序中使用过HTTPS,也没有调整Rack或其他任何东西的经验,所以我很感谢详细的答案。 最佳答案 这似乎适合我:require'sinatra/base'require'webrick'require'webrick/https'require'openssl'CERT_PATH='/opt/myCA/server/'webrick_options={:Port=>8443,:
一台服务器nginx绑定多个域名,多个域名规则写一个配置文件里,也可又分别建立多个域名配置文件,为了管理方便,每个域名建一个文件,有些同类域名也可又写在一个总的配置文件里。 一: 每个域名一个文件的写法 首先打开nginx域名配置文件存放目录:/usr/local/nginx/conf/servers,如要绑定域名www.itblood.com则在此目录建一个文件:www.itblood.com.conf然后在此文件中写规则,如: server{ listen80; server_namewww.itblood.com;#绑定域名 indexindex.htmindex.ht
我有一个Rails3.0.9应用程序,一旦部署,就会遇到一堆ActiveModel::MissingAttributeErrors,这些错误会突然出现并导致500秒。错误相当随机地发生,有时页面会加载,有时不会,但属性都是数据库中的现有属性,应该可以找到。奇怪的是,一段时间后,错误消失了。突然之间,它们不再引起问题。我已经搜索过这个问题的解决方案,但这个错误主要发生在有人完成Model.all(:select=>'column_x,column_y')并调用column_z或者当他们使用cache_money时。这些我都没有做。有人能帮忙吗? 最佳答案
我正在尝试构建一个Rails项目,因为我正在使用的主机无法访问Internet的git://协议(protocol)(端口9418),我收到如下错误Fetchinggit://github.com/pivotal/jasmine.gitfatal:unabletoconnecttogithub.com:github.com[0:192.30.252.130]:errno=Connectionrefused运行bundleinstall时。GemFile中的相关行没有指定git://作为协议(protocol),它只是指向GitHub作为gem的源gem'jasmine',:github
我的sshkey绝对设置正确,因为在使用ssh时我从未被提示输入密码。但是capistrano在使用capdeploy部署时仍然要求输入密码。但是,奇怪的是,当我使用capdeploy:setup进行设置时,它并不要求输入密码。如果没有密码提示,这将使部署周期更加顺畅。细节:我正在将Sinatra应用程序部署到Dreamhost共享帐户(使用Passenger)。很久以前我就按照教程做了,当时效果很好。从那以后有些东西坏了。我正在使用capistrano(2.5.9)和git版本1.6.1.1。这是我的Capfile:load'deploy'ifrespond_to?(:namespa
这是我第一次尝试使用XMLRPC::Client库与远程API交互,但我不断收到此错误:warning:peercertificatewon'tbeverifiedinthisSSLsession环顾四周,我发现很多人都遇到了这个错误。通常它带有自签名证书,他们只是想让它消失,所以他们做了一些肮脏的事情,比如XMLRPC::Client打开它的httpsession的方式。我首先假设这只是客户端不关心证书是否有效,所以我继续搜索并遇到了thisgem.它只是强制验证所有SSL证书,如果它也无法验证,则会抛出一个硬错误。这正是我想要的。我包含它,再次运行代码,现在我得到了这个:OpenS
在服务器端使用带有streamblock的Sinatra。get'/stream',:provides=>'text/event-stream'dostream:keep_opendo|out|connections在客户端:vares=newEventSource('/stream');es.onmessage=function(e){$('#chat').append(e.data+"\n")};当我通过http://localhost:9292/直接使用应用程序时,一切正常。连接是持久的,所有消息都传递给所有客户端。但是,当它通过Nginx时,http://chat.dev,连接
我正在尝试使用Thin应用服务器,有一个问题。当nginxproxies使用proxy_passhttp://my_app_upstream;对Thin(或Unicorn)的请求应用程序接收nginx发送的修改后的URL(http://my_app_upstream)。我想要的是不加修改地传递原始URL和来自客户端的原始请求,因为应用严重依赖它。nginx'doc说:IfitisnecessarytotransmitURIintheunprocessedformthendirectiveproxy_passshouldbeusedwithoutURIpart.但我不明白如何配置它,因为