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

不用担心,GOFrame框架当然已经充分考虑到这点,并且为开发者提供了比较灵活的配置参数来控制是否默认转义变量输出的HTML内容。该特性可以通过AutoEncode配置项,或者SetAutoEncode方法来开启/关闭。
需要注意的是,该特性并不会影响include模板的内置函数。
使用示例:
1、配置文件
[viewer]
delimiters = ["${", "}"]
autoencode = true2、示例代码
package main
import (
"context"
"fmt"
"github.com/gogf/gf/v2/frame/g"
)
func main() {
result, _ := g.View().ParseContent(context.TODO(), "姓名: ${.name}", g.Map{
"name": "",
})
fmt.Println(result)
}3、执行输出
姓名: <script>alert('john');</script> 分享文章:创新互联GoFrame教程:GoFrame模板引擎-XSS处理
转载来源:http://www.jxjierui.cn/article/dhichso.html


咨询
建站咨询
