带有嵌入式Ruby的Javascript:如何安全地将ruby值分配给JavaScript变量
时间:2020-03-06 14:28:19 来源:igfitidea点击:
我在页面的javascript块中有以下行:
res = foo('<%= @ruby_var %>');
处理" @ruby_var"中包含单引号的情况的最佳方法是什么?否则,它将破坏JavaScript代码。
解决方案
@ruby_var.gsub(/[']/, '\\\'')
这样可以用单引号将单引号引起来,从而确保Javascript安全!
另外,如果我们使用的是Rails,则有很多Java特定于工具的工具。
我想我会在@ruby_var上使用ruby JSON库来获取字符串的正确js语法并摆脱'',fex .:
res = foo(<%= @ruby_var.to_json %>)
(在需要" json"之后,不完全确定如何在页面中执行此操作,或者上述语法是否正确,因为我没有使用过该模板语言)
(另一方面,如果JSON曾经更改为与要中断的js不兼容,但是由于相当数量的代码使用eval()来评估json,我怀疑这种情况是否会很快发生)
我们可以将字符串放在双引号中吗?
res = foo("<%= @ruby_var %>");
我对嵌入式Ruby的使用不太多。但是如何使用" p"(调用"检查")代替" <%=",后者可能正在执行诸如"打印"或者"放置"之类的操作。 p总是打印字符串,就好像它是用双引号引起来的代码一样:
>> p "String ' \" String" "String ' \" String" # => nil >> p 'alpha " \' alpha' "alpha \" ' alpha" # => nil
我们也可以使用inspect假设我们知道它是单引号:
res = foo(<%= @ruby_var.inspect %>);