首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Ruby,如何防止Redcarpet在输出中呈现HTML代码?

Ruby,如何防止Redcarpet在输出中呈现HTML代码?
EN

Stack Overflow用户
提问于 2021-06-23 11:31:57
回答 1查看 133关注 0票数 0

我正在使用Redcarpet在一个由用户介绍的网页数据中呈现。

我发现用户很容易引入恶意HTML代码。

我正在尝试不同的Redcarpet初始化选项,以防止在输出中呈现任何可能的恶意代码,但没有任何操作:

尝试filter_html

代码语言:javascript
复制
markdown =
  Redcarpet::Markdown.new(
    Redcarpet::Render::HTML,
    filter_html: true
  )

markdown.render("<style>style</style> <script>alert()</script>")

# => "<p><style>style</style> <script>alert()</script></p>\n"

尝试scape_html

代码语言:javascript
复制
markdown =
  Redcarpet::Markdown.new(
    Redcarpet::Render::HTML,
    escape_html: true
  )

markdown.render("<style>style</style> <script>alert()</script>")

# => "<p><style>style</style> <script>alert()</script></p>\n"
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-06-23 13:53:24

这些选项是呈现器的选项,而不是解析器的选项,因此需要将它们传递给呈现器,然后将配置的呈现器传递给解析器,例如:

代码语言:javascript
复制
markdown =
  Redcarpet::Markdown.new(
    Redcarpet::Render::HTML.new(escape_html: true),
    # other parser options here, e.g.
    autolink: true
  )
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68099005

复制
相关文章

相似问题

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