草庐IT

out_param

全部标签

ruby-on-rails - 为什么对 params 哈希进行切片会对批量分配造成安全问题?

通过批量分配防止安全风险的官方方法是使用attr_accessible.然而,一些程序员认为这不是模型的工作(或者至少不是仅模型的工作)。在Controller中执行此操作的最简单方法是对params哈希进行切片:@user=User.update_attributes(params[:user].slice(:name))但是文档指出:NotethatusingHash#exceptorHash#sliceinplaceofattr_accessibletosanitizeattributeswon’tprovidesufficientprotection.这是为什么呢?为什么par

ruby-on-rails - rails : Opposite of Hash#to_param

如果我将哈希值转换为查询字符串,我该如何将其再次转换回来?{:filters=>{:colour=>['Red','Blue'],:size=>'Medium'}}.to_param=>"filters[colour][]=Red&filters[colour][]=Blue&filters[size]=Medium"Rails似乎在填充params散列时自动执行此操作,但是否可以直接调用此方法?谢谢。 最佳答案 您正在寻找Rack::Utils.parse_nested_query(query),它将把它转换回Hash。您可以使用

ruby-on-rails - Ruby on Rails - 设计用户/sign_out 不工作

我正在使用设计sign_in和sign_up网址有效但是,当我尝试url时:http://localhost:3000/users/sign_out它产生路由错误Noroutematches[GET]"/users/sign_out"我该如何解决这个问题?rake路rakeroutesnew_user_sessionGET/users/sign_in(.:format){:action=>"new",:controller=>"devise/sessions"}user_sessionPOST/users/sign_in(.:format){:action=>"create",:con

ruby-on-rails - Rails 路线 : GET without param :id

我正在开发基于Rails的RESTAPI。要使用此API,您必须登录。关于这一点,我想在我的用户Controller中创建一个方法me,它将返回已登录用户信息的JSON。因此,我不需要在URL中传递:id。我只想调用http://example.com/api/users/me所以我尝试了这个:namespace:api,defaults:{format:'json'}doscopemodule::v1,constraints:ApiConstraints.new(version:1,default:true)doresources:tokens,:only=>[:create,:de

ruby - 就地修改 ruby 散列(rails strong params)

这可能更像是一个ruby​​问题,然后是rails问题,但我很确定我能够在vanillaruby​​应用程序中做到这一点。我定义了强参数。deftrip_paramsparams.require(:trip).permit(:name,:date)end现在我在Controller方法中获取这些参数。我想这样做。defsavetrip_params[:name]='Modifyingnameinplace'#trip_params[:name]stillequalsoriginalvaluepassedend这永远行不通。名字永远不会改变。顺便说一句:trip_params的类型是Ac

ruby-on-rails - Ruby 语法 : break out from 'each.. do..' block

我正在开发一个RubyonRails应用程序。我的问题更多是关于Ruby语法。我有一个带有类方法self.check的模型类:classCars我想在eachblock一旦result为true(即如果car.name与name参数相同一次,则打破eachblock并返回car导致true结果。如何在Ruby代码中打出? 最佳答案 您可以使用break关键字中断。例如[1,2,3].eachdo|i|putsibreakend将输出1。或者如果你想直接返回值,使用return。由于您更新了问题,这里是代码:classCar尽管您也可

javascript - JsDoc、ES6 和@param {Constructor}

我正在尝试使用JsDoc来记录es6类。无法相信您不能将类作为参数传递(类类型,而不是实例类型)。我一直在尝试一些事情,但无法让这个简单的代码正常工作,因此JsDoc不会向我抛出一些警告。除非我为我的每个类创建一个@typedef,然后手动将所有自己的和继承的成员添加到它,否则我无法让它工作。甚至不能做mixin!有没有人成功传递构造函数/类参数?让JsDoc处于静态上下文中,而不是实例上下文中?/***@classA*/classA{/***@static*/statichelloFromClassA(){}}/***@classB*@extendsA*/classBextendsA

javascript - 由于函数排序导致 JSLint "out of scope"错误?

JSLint似乎对函数排序很挑剔。这很好:functiona(){'usestrict';return1;}functionb(){'usestrict';a();}虽然这给出了'a'isoutofscope错误消息:functionb(){'usestrict';a();}functiona(){'usestrict';return1;}这是设计使然吗?我应该关心吗?如何在更大(更复杂)的情况下避免这种情况,因为在这种情况下可能无法始终为函数提供明确的顺序? 最佳答案 JSLint/JSHint希望您在引用函数之前先定义它们。然而

javascript - Rails + 图表.js : How to fill out the Javascript array with value from database?

我想使用Google可视化图表将信息显示为图表。将值设置到图中的javascript函数如下所示:functiondrawLineChart(chartType){if(chartType==undefined){chartType='data1';}vardata={data1:[['Year','Sales','Expenses'],['2004',1000,400],['2005',1170,460],['2006',660,1120],['2007',1030,540]]};...}我的问题是,我不知道如何用数据库中的值填充这样的数组-有什么提示吗?非常感谢

javascript - 嵌套路由器中的 ExpressJS req.params 为空

我使用的路由设置使用我的“api”文件夹的目录结构来直观地设置路由。但是,在我使用文件夹名称表示路由参数的情况下,req.params在Controller中未定义。有问题的路由是:GET/api/google/accounts/:account_id/analytics/profiles/这是我的路线加载器。它基本上在api文件夹上执行glob查找名为routes.js的文件,并在适当的路径上执行app.use(由文件夹结构确定)。//loadroutersfiles=glob.sync("api/**/routes.js");console.log(files);//['api/c