首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >rails如何安全地从rails命令运行系统命令

rails如何安全地从rails命令运行系统命令
EN

Stack Overflow用户
提问于 2017-04-15 19:00:52
回答 1查看 151关注 0票数 10

我有一个触发系统脚本运行的ActiveJob:

代码语言:javascript
复制
 `grunt custom-job --src=files --dest="file" --vars='#{user_input_vars_from_json}'`

重点是

代码语言:javascript
复制
user_input_vars_from_json

是一个json配置,它是来自控制器的用户输入参数。

EN

回答 1

Stack Overflow用户

发布于 2017-04-28 04:05:35

我只想以:任何用户输入都应该被视为危险的。我不建议使用用户提供的输入执行任何命令。

你要做的第一件事就是尽可能地锁定输入。考虑限制user_input_vars_from_json的长度以防止缓冲区溢出和DoS攻击。我还建议找出一种方法来验证和限制您试图在user_input_vars_from_json JSON中设置的"vars“,以过滤掉任何不需要的键/值。

清理输入后,您可以结合使用Kernel#systemShellwords,以便在作业中执行命令时尽可能接近安全:

代码语言:javascript
复制
require 'shellwords'
system("grunt", "custom-job", "--src=files", '--dest="file"', "--vars=\"#{Shellwords.escape(user_input_vars_from_json)}\""
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43425223

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档