本篇內(nèi)容介紹了“ web框架字符轉(zhuǎn)義設(shè)計(jì)方法是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿(mǎn)足客戶(hù)于互聯(lián)網(wǎng)時(shí)代的鎮(zhèn)巴網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
特殊字符的轉(zhuǎn)義(escaping)對(duì)于網(wǎng)頁(yè)安全和用戶(hù)體驗(yàn)至關(guān)重要,由于在 HTML 的不同位置,需要對(duì)不同的字符進(jìn)行不同的轉(zhuǎn)義,各種框架/腳本語(yǔ)言提供了若干個(gè)不同的函數(shù),但是,這里要介紹的是 Go 的自帶 Web 框架,它能夠識(shí)別 HTML,自動(dòng)的選擇轉(zhuǎn)義含糊進(jìn)行正確的轉(zhuǎn)義。
Go 語(yǔ)言是 Google 發(fā)起的開(kāi)源項(xiàng)目,現(xiàn)在已經(jīng)有大量的外部人員參與到開(kāi)發(fā)當(dāng)中,其中不乏中國(guó)的程序員。由于是一門(mén)新興的語(yǔ)言,因此設(shè)計(jì)不少之前編程語(yǔ)言的經(jīng)驗(yàn)與教訓(xùn)。為了適應(yīng)當(dāng)前開(kāi)發(fā)的需要,Go 自帶了 Web 框架:template。
template 的一個(gè)***的特點(diǎn)就是會(huì)解析模板中的 HTML 語(yǔ)法,從而知道所要替換的變量在網(wǎng)頁(yè)中的位置,從而正確的進(jìn)行轉(zhuǎn)義,下面看一段例子程序(邊邊角角省掉了,template 需使用 “html/template”):
t, _ := template.New("foo").Parse(
`{{.}}` +
``)
t.ExecuteTemplate(os.Stdout, "foo", "#Hello? I'm David=")
一共就兩條語(yǔ)句:
編譯一個(gè)模板,模板中包含了 HTML 框架,其中含有一些變量。這里就是四個(gè) {{.}}
執(zhí)行模板,給出變量的值,這里四個(gè)變量的值都是 ”#Hello? I’m David=”,這個(gè)古怪的字符串包含和很多需要轉(zhuǎn)義的字符。轉(zhuǎn)換完的結(jié)果直接輸出到標(biāo)準(zhǔn)輸出了。
下面是輸出結(jié)果:
#Hello? I'm David=
我把四個(gè)變量轉(zhuǎn)換的結(jié)果用紅色粗體字標(biāo)了出來(lái)??梢园l(fā)現(xiàn),雖然調(diào)用的時(shí)候給的是同一個(gè)值,轉(zhuǎn)換之后卻是不同的,下面列成一個(gè)表格方便比較:
位置取值
HTML正文 #Hello? I'm David=
屬性取值 #Hello? I'm David=
URL Path #Hello?%20I%27m%20David=
URL Query 取值 %23Hello%3f%20I%27m%20David%3d
Javascript 字符串 #Hello? I\x27m David=
“ web框架字符轉(zhuǎn)義設(shè)計(jì)方法是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!