介绍
这期内容当中小编将会给大家带来有关怎么在Golang中利用http.FileServer返回静态文件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
<强> Golang中使用http.FileServer 强>
使用http。服务器可以管理向浏览器返回静态文件
http.Handle (“/? http.FileServer (http.Dir(“/用户/管理员/桌面/public"))) err :=, http.ListenAndServe (“0.0.0.0:8080" nil) if 犯错!=nil { fmt.Print才能(错); }
<>强补充:golang https服务器分析强>
https:
https是http安全版本的实现,在http与tcp之间加了一层ssl/tls安全传输协议
为了防止请求被监听,篡改,冒充,在tls实现过程中引入了数字证书机制,数字证书由第三方权威机构提供保证。
数字证书原理是采用非对称加密生成一对公钥,私钥,服务端保存私钥,下发公钥给客户端,由于非对称加密计算量比较大,
所以https通信过程中,通过客户端与服务端的握手交互产生三次随机码,从而生成一个相对安全的对称加密密码,密码通过非对称加密下发给客户端,从而完成加密通信
https本质上还是tcp通信,所以https的捂手是在建立tcp连接后,进行的一系列校验而已。
在处理tcp康涅狄格州连接的过程中,会判断连接类型是不是tls类型,如果是会进入tlsConn.serverHandshake()握手过程。详细流程如下:
下面分析一下golang中如何实现的https握手
在建立tlsConn连接后,服务端新起一个goroutine处理,
config.serverInitOnce.Do (config.serverInit),//,产生一个随机数作为通信凭证,下次通信时凭证校验通过后直接通信,校验不通过重新建立连接 味精,err :=, c.readHandshake(),//,解析clientHello信息,此时获取到由客户端生成的第一个随机数 c.vers, ok =, config.mutualVersion (hs.clientHello.vers),//,检查客户端与服务端tls版本是否一致 时间=_,err io.ReadFull (config.rand (),, hs.hello.random),//,服务端产生第二个随机数 hs.setCipherSuite (id, supportedList, c.vers),//,确认加密算法
设置服务器证书
hs.cert,, err =, config.getCertificate(及ClientHelloInfo { 密码套件:hs.clientHello.cipherSuites, ServerName: hs.clientHello.serverName, SupportedCurves: hs.clientHello.supportedCurves, SupportedPoints: hs.clientHello.supportedPoints, });
skx,, err :=, keyAgreement.generateServerKeyExchange (hs.cert,配置,还以为,hs.clientHello, hs.hello),//,生成服务端摘要信息 c.writeRecord (recordTypeHandshake, helloDone.marshal()),//发送helloDone信息 preMasterSecret, err :=, keyAgreement.processClientKeyExchange (hs.cert,配置,还以为,ckx, c.vers),//,处理获取由客户端生成的第三个随机数 时间=hs.masterSecret masterFromPreMasterSecret (c.vers, hs.suite,, preMasterSecret,, hs.clientHello.random,, hs.hello.random),//,生成通信秘钥 hs.finishedHash.Write(),//,服务端发送最后一次确认请求
上述就是小编为大家分享的怎么在Golang中利用http.FileServer返回静态文件了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。