Categories: GoFrame 教程

GoFrame 模板引擎-XSS处理

默认情况下,模板引擎对所有的变量输出并没有使用​HTML​转码处理,也就是说,如果开发者处理不好,可能会存在​XSS​漏洞。

不用担心,​GoFrame​框架当然已经充分考虑到这点,并且为开发者提供了比较灵活的配置参数来控制是否默认转义变量输出的​HTML​内容。该特性可以通过​AutoEncode​配置项,或者​SetAutoEncode​方法来开启/关闭。

需要注意的是,该特性并不会影响​include​模板的内置函数。

使用示例:

1、配置文件

[viewer]
    delimiters  =  ["${", "}"]
    autoencode  =  true

2、示例代码

package main

import (
 "context"
 "fmt"
 "github.com/gogf/gf/v2/frame/g"
)

func main() {
 result, _ := g.View().ParseContent(context.TODO(), "姓名: ${.name}", g.Map{
  "name": "<script>alert(john);</script>",
 })
 fmt.Println(result)
}

3、执行输出

姓名: &lt;script&gt;alert(&#39;john&#39;);&lt;/script&gt;

terry

这个人很懒,什么都没有留下~

Share
Published by
terry

Recent Posts

聊聊vue3中的defineProps

在Vue 3中,defineP…

1 周 ago

在 Chrome 中删除、允许和管理 Cookie

您可以选择删除现有 Cooki…

2 周 ago

自定义指令:聊聊vue中的自定义指令应用法则

今天我们来聊聊vue中的自定义…

3 周 ago

聊聊Vue中@click.stop和@click.prevent

一起来学下聊聊Vue中@cli…

4 周 ago

Nginx 基本操作:启动、停止、重启命令。

我们来学习Nginx基础操作:…

1 月 ago

Vue3:手动清理keep-alive组件缓存的方法

Vue3中手动清理keep-a…

1 月 ago