本文實例講述了Go語言RPC Authorization進行簡單ip安全驗證的方法。分享給大家供大家參考。具體分析如下:
前言:寫網絡服務,總要考慮安全機制,對ip和網段進行判斷是最簡單的一個驗證機制。之后想做一個類似注冊式的安全驗證機制,既可以減少配置文件的麻煩,又可以很好的進行安全管理。
直接上代碼:
復制代碼 代碼如下:
package main
import(
"net"
"fmt"
"time"
"strings"
)
func main(){
IP_ARRAY := "192.168.1.234,192.168.1.47,192.168.2.0/28"
servPort:=":7272"
l,err := net.Listen( "tcp",servPort )
if err != nil {
fmt.Printf( "Listen is error" )
return
}
allowList :=strings.Split( IP_ARRAY,"," )
for{
conn,err:=l.Accept()
if err != nil {
fmt.Printf( "start connect is error" )
return
}
ipAddr:=conn.RemoteAddr()
Addr := strings.Split( ipAddr.String(), ":")
rAddr := net.ParseIP( Addr[0] )
var authorized bool = false
for v := range allowList{
_,ipNet,err := net.ParseCIDR( allowList[v] )
if err != nil{
fmt.Printf( "parse ip net error" )
ipHost := net.ParseIP( allowList[v])
if ipHost != nil{
if ipHost.Equal( rAddr ) {
authorized =true
}
}else{
fmt.Printf( "ip list error" )
}
}else{
fmt.Printf( "Contains ip " )
if ipNet.Contains( rAddr ) {
authorized =true
}
}
}
if authorized == true{
curTime:=time.Now()
fmt.Printf( curTime.Format( "2006-01-02 15:04:05" ) )
conn.Write( []byte(curTime.Format( "2006-01-02 15:04:05" ) ) )
time.Sleep( 10)
}else{
conn.Close()
}
}
}
希望本文所述對大家的Go語言程序設計有所幫助。
您可能感興趣的文章:- Go語言中函數的參數傳遞與調用的基本方法
- Go語言調用其它程序并獲得程序輸出的方法
- go和python調用其它程序并得到程序輸出
- golang簡單讀寫文件示例
- golang實現通過smtp發送電子郵件的方法
- golang基于websocket實現的簡易聊天室程序
- golang使用sort接口實現排序示例
- golang守護進程用法示例
- golang模板template自定義函數用法示例
- golang兩種調用rpc的方法