Secure middleware for Gin framework.
DefaultConfig returns a Configuration with strict security settings
func DefaultConfig() Config { return Config{ SSLRedirect: true, IsDevelopment: false, STSSeconds: 315360000, STSIncludeSubdomains: true, FrameDeny: true, ContentTypeNosniff: true, BrowserXssFilter: true, ContentSecurityPolicy: "default-src 'self'", IENoOpen: true, SSLProxyHeaders: map[string]string{"X-Forwarded-Proto": "https"}, } }
package main import ( "log" "github.com/gin-contrib/secure" "github.com/gin-gonic/gin" ) func main() { router := gin.Default() router.Use(secure.New(secure.Config{ AllowedHosts: []string{"example.com", "ssl.example.com"}, SSLRedirect: true, SSLHost: "ssl.example.com", STSSeconds: 315360000, STSIncludeSubdomains: true, FrameDeny: true, ContentTypeNosniff: true, BrowserXssFilter: true, ContentSecurityPolicy: "default-src 'self'", IENoOpen: true, ReferrerPolicy: "strict-origin-when-cross-origin", SSLProxyHeaders: map[string]string{"X-Forwarded-Proto": "https"}, })) router.GET("/ping", func(c *gin.Context) { c.String(200, "pong") }) // Listen and Server in 0.0.0.0:8080 if err := router.Run(); err != nil { log.Fatal(err) } }
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4