亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

在Golang中使用http.FileServer返回靜態(tài)文件的操作

 更新時(shí)間:2020年12月18日 10:13:52   作者:寒江雪1719  
這篇文章主要介紹了在Golang中使用http.FileServer返回靜態(tài)文件的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

Golang中使用http.FileServer

使用http.FileServer可以管理向?yàn)g覽器返回靜態(tài)文件

http.Handle("/",http.FileServer(http.Dir("/Users/administrator/Desktop/public")))
err := http.ListenAndServe("0.0.0.0:8080",nil)
if err!=nil{
  fmt.Print(err);
}

補(bǔ)充:golang https server分析

https:

HTTPS是http安全版本的實(shí)現(xiàn),在http與tcp之間加了一層ssl/tls安全傳輸協(xié)議

為了防止請(qǐng)求被監(jiān)聽、篡改、冒充,在tls實(shí)現(xiàn)過程中引入了數(shù)字證書機(jī)制,數(shù)字證書由第三方權(quán)威機(jī)構(gòu)提供保證。

數(shù)字證書原理是采用非對(duì)稱加密生成一對(duì)公鑰、私鑰,服務(wù)端保存私鑰,下發(fā)公鑰給客戶端,由于非對(duì)稱加密計(jì)算量比較大,

所以https通信過程中,通過客戶端與服務(wù)端的握手交互產(chǎn)生三次隨機(jī)碼,從而生成一個(gè)相對(duì)安全的對(duì)稱加密密碼,密碼通過非對(duì)稱加密下發(fā)給客戶端,從而完成加密通信

https本質(zhì)上還是tcp通信,所以https的捂手是在建立tcp連接后,進(jìn)行的一系列校驗(yàn)而已,

在處理tcp conn連接的過程中,會(huì)判斷連接類型是不是tls類型,如果是會(huì)進(jìn)入tlsConn.serverHandshake()握手過程。詳細(xì)流程如下:

下面分析一下golang中如何實(shí)現(xiàn)的https握手

在建立tlsConn連接后,服務(wù)端新起一個(gè)goroutine處理,

config.serverInitOnce.Do(config.serverInit) // 產(chǎn)生一個(gè)隨機(jī)數(shù)作為通信憑證,下次通信時(shí)憑證校驗(yàn)通過后直接通信,校驗(yàn)不通過重新建立連接
msg, err := c.readHandshake() // 解析clientHello信息,此時(shí)獲取到由客戶端生成的第一個(gè)隨機(jī)數(shù)
c.vers, ok = config.mutualVersion(hs.clientHello.vers) // 檢查客戶端與服務(wù)端tls版本是否一致
_, err = io.ReadFull(config.rand(), hs.hello.random) // 服務(wù)端產(chǎn)生第二個(gè)隨機(jī)數(shù)
hs.setCipherSuite(id, supportedList, c.vers) // 確認(rèn)加密算法

設(shè)置服務(wù)器證書

hs.cert, err = config.getCertificate(&ClientHelloInfo{
CipherSuites: hs.clientHello.cipherSuites,
ServerName: hs.clientHello.serverName,
SupportedCurves: hs.clientHello.supportedCurves,
SupportedPoints: hs.clientHello.supportedPoints,
});
skx, err := keyAgreement.generateServerKeyExchange(config, hs.cert, hs.clientHello, hs.hello) // 生成服務(wù)端摘要信息
c.writeRecord(recordTypeHandshake, helloDone.marshal()) //發(fā)送helloDone信息
preMasterSecret, err := keyAgreement.processClientKeyExchange(config, hs.cert, ckx, c.vers) // 處理獲取由客戶端生成的第三個(gè)隨機(jī)數(shù)
hs.masterSecret = masterFromPreMasterSecret(c.vers, hs.suite, preMasterSecret, hs.clientHello.random, hs.hello.random) // 生成通信秘鑰
hs.finishedHash.Write() // 服務(wù)端發(fā)送最后一次確認(rèn)請(qǐng)求

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

最新評(píng)論