改进ghttp接口

This commit is contained in:
John
2017-12-07 17:34:51 +08:00
parent 42cf55eee8
commit 44e3877a71
6 changed files with 124 additions and 24 deletions

View File

@ -17,6 +17,7 @@ type Server struct {
server http.Server // 底层http server对象
config ServerConfig // 配置对象
handlerMap HandlerMap // 回调函数
status int8 // 当前服务器状态(0未启动1运行中)
}
// http回调函数
@ -25,15 +26,25 @@ type HandlerFunc func(*ClientRequest, *ServerResponse)
// uri与回调函数的绑定记录表
type HandlerMap map[string]HandlerFunc
// ServerMap互斥锁
var smu sync.RWMutex
// Server表用以存储和检索多个Server对象
var smap map[string]*Server = make(map[string]*Server)
// 创建一个默认配置的HTTP Server(默认监听端口是80)
func NewServer() (*Server) {
server := Server{}
server.SetConfig(defaultServerConfig)
return &server
func GetServer(name string) (*Server) {
smu.Lock()
defer smu.Unlock()
if s, ok := smap[name]; ok {
return s
}
smap[name] = &Server{}
smap[name].SetConfig(defaultServerConfig)
return smap[name]
}
// 执行
func (s *Server)Run() error {
func (s *Server) Run() error {
// 底层http server配置
if s.config.Handler == nil {
s.config.Handler = http.HandlerFunc(s.defaultHttpHandle)
@ -51,12 +62,16 @@ func (s *Server)Run() error {
if err := s.server.ListenAndServe(); err != nil {
return err
}
s.status = 1
return nil
}
// http server setting设置
// 注意使用该方法进行http server配置时需要配置所有的配置项否则没有配置的属性将会默认变量为空
func (s *Server)SetConfig(c ServerConfig) {
func (s *Server)SetConfig(c ServerConfig) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
if c.Handler == nil {
c.Handler = http.HandlerFunc(s.defaultHttpHandle)
}
@ -72,74 +87,128 @@ func (s *Server)SetConfig(c ServerConfig) {
if s.config.ServerAgent == "" {
s.SetServerAgent(defaultServerConfig.ServerAgent)
}
return nil
}
// 设置http server参数 - Addr
func (s *Server)SetAddr(addr string) {
func (s *Server)SetAddr(addr string) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.Addr = addr
return nil
}
// 设置http server参数 - Handler
func (s *Server)SetHandler(handler http.Handler) {
func (s *Server)SetHandler(handler http.Handler) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.Handler = handler
return nil
}
// 设置http server参数 - TLSConfig
func (s *Server)SetTLSConfig(tls *tls.Config) {
func (s *Server)SetTLSConfig(tls *tls.Config) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.TLSConfig = tls
return nil
}
// 设置http server参数 - ReadTimeout
func (s *Server)SetReadTimeout(t time.Duration) {
func (s *Server)SetReadTimeout(t time.Duration) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.ReadTimeout = t
return nil
}
// 设置http server参数 - WriteTimeout
func (s *Server)SetWriteTimeout(t time.Duration) {
func (s *Server)SetWriteTimeout(t time.Duration) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.WriteTimeout = t
return nil
}
// 设置http server参数 - IdleTimeout
func (s *Server)SetIdleTimeout(t time.Duration) {
func (s *Server)SetIdleTimeout(t time.Duration) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.IdleTimeout = t
return nil
}
// 设置http server参数 - MaxHeaderBytes
func (s *Server)SetMaxHeaderBytes(b int) {
func (s *Server)SetMaxHeaderBytes(b int) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.MaxHeaderBytes = b
return nil
}
// 设置http server参数 - ErrorLog
func (s *Server)SetErrorLog(logger *log.Logger) {
func (s *Server)SetErrorLog(logger *log.Logger) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.ErrorLog = logger
return nil
}
// 设置http server参数 - IndexFiles
func (s *Server)SetIndexFiles(index []string) {
func (s *Server)SetIndexFiles(index []string) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.IndexFiles = index
return nil
}
// 设置http server参数 - IndexFolder
func (s *Server)SetIndexFolder(index bool) {
func (s *Server)SetIndexFolder(index bool) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.IndexFolder = index
return nil
}
// 设置http server参数 - ServerAgent
func (s *Server)SetServerAgent(agent string) {
func (s *Server)SetServerAgent(agent string) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.ServerAgent = agent
return nil
}
// 设置http server参数 - ServerRoot
func (s *Server)SetServerRoot(root string) {
func (s *Server)SetServerRoot(root string) error {
if s.status == 1 {
return errors.New("server config cannot be changed while running")
}
s.config.ServerRoot = strings.TrimRight(root, string(filepath.Separator))
return nil
}
// 绑定URI到操作函数/方法
// pattern的格式形如/user/list, put:/user, delete:/user
// 支持RESTful的请求格式具体业务逻辑由绑定的处理方法来执行
func (s *Server)BindHandle(pattern string, handler HandlerFunc) error {
if s.status == 1 {
return errors.New("server handlers cannot be changed while running")
}
s.hmu.Lock()
defer s.hmu.Unlock()
if s.handlerMap == nil {
s.handlerMap = make(HandlerMap)
}
@ -166,7 +235,7 @@ func (s *Server)BindHandleByMap(m HandlerMap) {
}
// 绑定控制器控制器需要继承gmvc.ControllerBase对象并实现需要的REST方法
func (s *Server)BindController(uri string, c ControllerRest) {
func (s *Server)BindControllerRest(uri string, c ControllerRest) {
s.BindHandleByMap(HandlerMap{
"GET:" + uri : c.Get,
"PUT:" + uri : c.Put,

View File

@ -93,7 +93,8 @@ func (s *Server)listDir(w http.ResponseWriter, f http.File) {
if d.IsDir() {
name += "/"
}
fmt.Fprintf(w, "<a href=\"%s\">%s</a>\n", url.URL{Path: name}.String(), ghtml.SpecialChars(name))
u := url.URL{Path: name}
fmt.Fprintf(w, "<a href=\"%s\">%s</a>\n", u.String(), ghtml.SpecialChars(name))
}
fmt.Fprintf(w, "</pre>\n")
}
@ -103,7 +104,7 @@ func (s *Server)ResponseStatus(w http.ResponseWriter, code int) {
w.Header().Set("Content-Type", "text/plain; charset=utf-8")
w.Header().Set("X-Content-Type-Options", "nosniff")
w.WriteHeader(code)
fmt.Fprintln(w, http.StatusText(code))
w.Write([]byte(http.StatusText(code)))
}
// 404

View File

@ -19,11 +19,11 @@ type ResponseJson struct {
}
// 返回信息
func (r *ServerResponse) Response(content []byte) {
func (r *ServerResponse) Write(content []byte) {
if r.Header().Get("Content-Type") == "" {
r.Header().Set("Content-Type", "text/plain; charset=utf-8")
}
r.Write(content)
r.ResponseWriter.Write(content)
}
// 返回固定格式的json

View File

@ -0,0 +1,19 @@
package controller
import (
"gitee.com/johng/gf/g/net/ghttp"
)
type Controller_User struct {
ghttp.Controller
}
func (cu *Controller_User) Hello(r *ghttp.ClientRequest, w *ghttp.ServerResponse) {
w.Write([]byte("Hello"))
}
func init() {
user := &Controller_User{}
ghttp.GetServer("johng.cn").BindHandle("/hello", user.Hello)
}

View File

@ -0,0 +1,11 @@
package main
import (
_ "gitee.com/johng/gf/geg/net/controller/controller"
"gitee.com/johng/gf/g/net/ghttp"
)
func main() {
ghttp.GetServer("johng.cn").SetAddr(":8199")
ghttp.GetServer("johng.cn").Run()
}

View File

@ -13,7 +13,7 @@ func HelloServer2(w http.ResponseWriter, r *http.Request) {
io.WriteString(w, "hello2\n")
}
func main() {
s := ghttp.New()
s := ghttp.NewServer()
s.SetAddr(":8199")
s.SetIndexFolder(true)
s.SetServerRoot("/home/john/Workspace/")