草庐IT

javascript - 在 session 中维护 Facebook 用户 ID

全部标签

ruby-on-rails - Rails 最终用户模板引擎 : Liquid vs Mustache vs. 其他?

我正在创建一项服务,我想在其中允许最终用户编辑网页的HTML模板,允许访问特定“变量”以包含在模板中。我知道liquid正是为此目的而设计的,它是安全的(至少相对而言),并且在大量生产中使用。但是,我发现与Mustache之类的语言相比,这种语言对于最终用户来说相当复杂。Mustache听起来不错,但我担心安全问题……它是否曾经用于最终用户模板?基本上我正在寻找一个模板引擎,我可以使用w/Rails为最终用户提供:安全-不允许用户执行代码……至少不允许在服务器上执行。用户将被允许插入客户端javascript。功能强大-允许最终用户使用提供的“变量”并在#1的上下文中创建他们可以想象的

ruby-on-rails - 如何自动找到用户的位置?

我目前正在制作一个节目列表网站。我将按位置显示以各种不同方式为用户排序的节目信息。我知道我可以在用户第一次登录网站时询问他们所在的位置,但我注意到许多网站都内置了自动检测位置的功能(例如,请参阅Last.fm“事件:您所在地区的音乐会列表”)。他们是怎么做到的?我目前正在使用RubyonRails构建我的网站。 最佳答案 这是相关GoogleMapsAPI文档的链接:http://code.google.com/apis/ajax/documentation/#ClientLocation它显示了如何使用它的示例:/***Setth

ruby - 在 Ruby/Sinatra 中解码 Facebook 的签名请求

由于Facebook弃用新的FBML,我正在寻找一种创建“显示”选项卡(向粉丝显示一个版本而向非粉丝显示另一个版本的页面选项卡)的新方法。Facebook已将数据添加到signed_request:Whenauserselectsyourappintheleft-handmenu,theappwillreceivethesigned_requestparameterwithoneadditionalparameter,page,aJSONarraywhichcontainsthe‘id’oftheFacebookPageyourTabishostedwithin,aboolean(‘l

ruby - 从 Cucumber/Capybara 测试中执行 JavaScript

似乎Selenium有一个名为JavascriptExecutor的功能,它可以直接在页面上执行JavaScript。然而,我的Cucumber/Capybara测试似乎没有这样的东西。如何从我的Cucumber测试中执行任意JavaScript? 最佳答案 Capybara有两种执行javascript的方法#execute_script和#evaluate_script。两者都可以在以下位置找到:http://rubydoc.info/github/jnicklas/capybara/master/Capybara/Seleni

ruby-on-rails - Rails Devise - 当前用户为零

出于某种原因,current_user在我的无模型Controller(订阅)中返回了nil。我在Internet上找不到任何可以证明这种行为的理由...classSubscriptionsController我有一个csrf元标记:我可以提供更多代码,但我不确定哪些代码会有用。更新感谢评论/回答,我已将问题确定为一个特定的操作:create。如果我将@user=current_user添加到new,我可以在我的newView中显示当前用户的电子邮件。但是,在我的createController中,current_user返回nil。我通过表单(提交)访问了create操作。在提交表单

ruby - 如何像在 Javascript 中一样在 Ruby 中动态创建对象及其方法?

我最近发现在Ruby中动态创建对象和方法是一件很费力的事情,这可能是因为我有Javascript背景经验。在Javascript中,您可以动态创建对象及其方法,如下所示:functionsomewhere_inside_my_code(){foo={};foo.bar=function(){/**dosomething**/};};如何在Ruby中完成上述语句(与在Javascript中一样简单)? 最佳答案 您可以使用单例方法实现此目的。请注意,您可以对所有对象执行此操作,例如:str="Ilikecookies!"defstr.

ruby-on-rails - 使用 Rails Assets 管道在 JavaScript 文件中编码问题

我正在使用Rails3.1和Assets管道(ruby1.9.2)。在尝试提供具有utf-8编码字符串的javascriptjs.erb文件时出现以下错误invalidbytesequenceinUS-ASCII我在我的environment.rb文件中设置了Encoding.default_external="UTF-8"。我如何让Assets管道以不同的编码提供服务?编辑仅当我在文件外部生成utf-8字符时才会出现该错误(在本例中是通过从数据库查询)。如果我添加,错误就会消失到文件的顶部。我猜这里会进行某种编码猜测,但如果没有那种骇人听闻的解决方案,我该如何避免呢?

ruby-on-rails - 将用户输入转换为整数

所以我有一个用户可以输入价格的表单。我正在尝试制作一个before_validation来规范化数据,如果用户输入它,则剪掉$。before_validationdounlessself.price.blank?thenself.price=self.price.to_s.gsub(/\D/,'').to_iendend如果用户输入$50此代码给我0。如果用户输入50$此代码给我50。我认为由于数据类型是整数,所以Rails在我的before_validation之前运行.to_i并在$之后剪切所有内容。如果数据类型是字符串,同样的代码也能正常工作。有人有解决方案可以让我保留整数数据类

ruby - 未设置的 Sinatra 和 session 变量

出于某种原因,我的应用程序中未设置session变量。我正在使用Sinatra1.2.1。这是一段代码:moduleGitWikiclassApp"utf-8"@user=session[:user]endget"/login/?"doerb:loginendpost"/login"douser=User.getifuser.authenticate(params[:username],params[:password])session[:user]=params[:username]psession#=>{:user=>"root"}else#AZIZ!LIGHT!endredire

ruby-on-rails - 从 HTML 页面中删除所有 JavaScript

我试过使用Sanitizegem清理包含网站HTML的字符串。它只删除了标记,而不是脚本标记内的JavaScript。我可以使用什么从页面中删除JavaScript? 最佳答案 require'open-uri'#includedwithRuby;onlyneededtoloadHTMLfromaURLrequire'nokogiri'#geminstallnokogirireadmoreathttp://nokogiri.orghtml=open('http://stackoverflow.com')#GettheHTMLsour