成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

最聰明的 web 框架字符轉義設計

開發 前端
特殊字符的轉義(escaping)對于網頁安全和用戶體驗至關重要,由于在 HTML 的不同位置,需要對不同的字符進行不同的轉義,各種框架/腳本語言提供了若干個不同的函數,但是,這里要介紹的是 Go 的自帶 Web 框架,它能夠識別 HTML,自動的選擇轉義含糊進行正確的轉義。

特殊字符的轉義(escaping)對于網頁安全和用戶體驗至關重要,由于在 HTML 的不同位置,需要對不同的字符進行不同的轉義,各種框架/腳本語言提供了若干個不同的函數,但是,這里要介紹的是 Go 的自帶 Web 框架,它能夠識別 HTML,自動的選擇轉義含糊進行正確的轉義。

Go 語言是 Google 發起的開源項目,現在已經有大量的外部人員參與到開發當中,其中不乏中國的程序員。由于是一門新興的語言,因此設計不少之前編程語言的經驗與教訓。為了適應當前開發的需要,Go 自帶了 Web 框架:template。

template 的一個***的特點就是會解析模板中的 HTML 語法,從而知道所要替換的變量在網頁中的位置,從而正確的進行轉義,下面看一段例子程序(邊邊角角省掉了,template 需使用 “html/template”):

t, _ := template.New("foo").Parse(  

  `<a title="{{.}}" href="http://example.com/{{.}}/hello?q={{.}}">{{.}}</a>` +

  `<script>var s = '#Hello? I\x27m David='</script>`)  

t.ExecuteTemplate(os.Stdout, "foo", "#Hello? I'm David=")

​一共就兩條語句:
  1. 編譯一個模板,模板中包含了 HTML 框架,其中含有一些變量。這里就是四個 {{.}}
  2. 執行模板,給出變量的值,這里四個變量的值都是 ”#Hello? I’m David=”,這個古怪的字符串包含和很多需要轉義的字符。轉換完的結果直接輸出到標準輸出了。

下面是輸出結果:

  1. <a title="#Hello? I&#39;m David=" href="http://example.com/#Hello?%20I%27m%20David=/hello?q=%23Hello%3f%20I%27m%20David%3d">#Hello? I&#39;m David=</a><script>var s = '#Hello? I\x27m David='</script> 

我把四個變量轉換的結果用紅色粗體字標了出來。可以發現,雖然調用的時候給的是同一個值,轉換之后卻是不同的,下面列成一個表格方便比較:

位置取值

HTML正文 #Hello? I&#39;m David=

屬性取值 #Hello? I&#39;m David=

URL Path #Hello?%20I%27m%20David=

URL Query 取值 %23Hello%3f%20I%27m%20David%3d

Javascript 字符串 #Hello? I\x27m David=

具體的轉換規則是按照 HTML/Javascript 的標準進行的,這里不細說了。

這樣的方式,***限度防止了書寫模板的時候忘記進行轉換或者選錯轉換函數,因為可以不用顯示的轉換了。

作者未必熟悉所有的 web 框架,歡迎留言參加討論。

原文鏈接:http://techblog.youdao.com/

責任編輯:陳四芳 來源: youdao.com
相關推薦

2024-07-12 05:00:00

2010-05-25 15:12:59

Web

2009-11-10 09:39:00

Web設計

2013-07-09 10:11:41

程序設計大賽程序員

2025-06-16 09:40:48

2013-03-18 10:19:41

程序設計語言

2010-05-24 09:57:08

2012-01-04 09:49:30

2011-01-04 18:04:49

PHP

2013-09-25 15:28:42

Storm流式處理框架框架

2011-03-21 13:01:10

2009-12-14 15:54:34

Ruby轉義字符

2010-07-14 15:32:21

Perl轉義字符

2009-08-17 17:04:29

C#轉義字符

2010-02-07 10:00:46

嵌入式設計專家

2019-10-09 11:26:01

JavaXMLSQL

2011-11-23 09:59:56

Web

2014-02-25 10:47:22

web設計設計趨勢

2015-06-09 14:23:43

CSS收藏CSS框架

2017-06-27 14:02:09

前端框架Bootstrap
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美午夜精品理论片a级按摩 | 免费一级毛片 | 黄在线免费观看 | 欧美一级欧美一级在线播放 | 色婷婷av久久久久久久 | 亚洲精品影院 | 91精品久久久久久久久中文字幕 | av日韩一区| 欧美视频一区二区三区 | 欧美日韩一区二区三区在线观看 | 日韩三级在线 | 国产一区999| 97国产一区二区 | 亚洲v区 | 日本小电影在线 | 日韩精品人成在线播放 | 久久99精品久久久久久国产越南 | 国产视频一区二区 | 国产精品一区一区三区 | 亚洲精品一区二区三区四区高清 | 国产美女一区二区 | 亚洲狠狠 | 国产中的精品av涩差av | 欧美中文一区 | 99热国产精品 | 欧美综合色 | 91精品国产综合久久婷婷香蕉 | 国产伦精品 | 午夜欧美一区二区三区在线播放 | 国产一区二区三区免费观看在线 | 免费观看的黄色网址 | 亚洲人成人一区二区在线观看 | 三级黄片毛片 | 国产欧美一区二区精品久导航 | 亚洲精品大片 | 九九九色 | 99re国产精品| 亚洲日本激情 | 亚洲性在线 | 熟女毛片 | 91av视频在线|