您好,登錄后才能下訂單哦!
Blackfriday是在Go中實現的Markdown處理器。您可以安全地輸入用戶提供的數據,速度快,支持通用擴展(表,智能標點符號替換等),并且對于所有utf-8(unicode)都是安全的輸入。
當前支持HTML輸出以及Smartypants擴展。
使用
首先當然要引入:
import github.com/russross/blackfriday
然后
output := blackfriday.MarkdownBasic(input)
這里input是[]byte類型,可以將markdown類型的字符串強轉為[]byte,即input = []byte(string)
如果想過濾不信任的內容,使用以下方法:
代碼:
package main import ( "fmt" "github.com/microcosm-cc/bluemonday" "github.com/russross/blackfriday" ) func main() { input := []byte("### 5lmh.com是個不錯的go文檔網站") unsafe := blackfriday.MarkdownCommon(input) html := bluemonday.UGCPolicy().SanitizeBytes(unsafe) fmt.Println(string(html)) }
基本上就這些操作
我的使用方法是在添加新文章時,將表單提交的數據直接通過上面的方法轉換后,將markdown和轉換后的內容都存儲到數據庫中
不過我在前端渲染時,又出現了問題,就是轉換后的內容中的html標簽會直接顯示在網頁上,為避免這種狀況,我使用了自定義模板函數
// 定義模板函數 func unescaped(x string) interface{} { return template.HTML(x)} // 注冊模板函數 t := template.New("post.html") t = t.Funcs(template.FuncMap{"unescaped": unescaped}) t, _ = t.ParseFiles("templates/post.html") t.Execute(w, post) // 使用模板函數 {{ .Content|unescaped }}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。