-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathhandler.go
More file actions
95 lines (85 loc) · 2.26 KB
/
handler.go
File metadata and controls
95 lines (85 loc) · 2.26 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
package ffcgiclient
import (
"bytes"
"log"
"net/http"
)
// Handler 实现http.Handler并提供记录logger方法
type Handler interface {
http.Handler
SetLogger(logger *log.Logger)
}
// NewHandler 返回默认的Http.Handler实现
func NewHandler(requestHandler RequestHandler, clientFactory ClientFactory) Handler {
return &defaultHandler{
requestHandler: requestHandler, // 请求处理Handler
newClient: clientFactory, // client
}
}
// defaultHandler Http.Handler的实现
type defaultHandler struct {
requestHandler RequestHandler // 请求Handler
newClient ClientFactory // client工厂方法
logger *log.Logger // 日志
}
// SetLogger 设置日志
func (h *defaultHandler) SetLogger(logger *log.Logger) {
h.logger = logger
}
// ServeHTTP 主处理逻辑,实现http.Handler接口
func (h *defaultHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
// 创建fcgi client
// 测试
// fmt.Println("【ServeHTTP】初始化")
c, err := h.newClient()
if err != nil {
// 返回502
http.Error(w, "failed to connect to FastCGI application", http.StatusBadGateway)
log.Printf("unable to connect to FastCGI application. %s",
err.Error())
return
}
// TODO 测试keepalive连接的保持/关闭情况
// 延迟关闭
defer func() {
if c == nil {
return
}
// 关闭client
if err = c.Close(); err != nil {
log.Printf("error closing client: %s",
err.Error())
}
}()
// 处理请求
// 测试
// fmt.Println("【ServeHTTP】开始处理请求")
resp, err := h.requestHandler(c, NewRequest(r))
// 测试
// fmt.Println("【ServeHTTP】处理请求完成")
if err != nil {
// 返回500
http.Error(w, "failed to process request", http.StatusInternalServerError)
log.Printf("unable to process request %s",
err.Error())
return
}
// Buffer
errBuffer := new(bytes.Buffer)
// 测试
// fmt.Println("【ServeHTTP】准备开始WriteTo")
err = resp.WriteTo(w, errBuffer)
// 测试
// fmt.Println("【ServeHTTP】完成WriteTo")
if err != nil {
// 返回500
http.Error(w, "failed to write stream", http.StatusInternalServerError)
log.Printf("Unable WriteTo: %s",
err.Error())
return
}
if errBuffer.Len() > 0 {
log.Printf("error stream from application process %s",
errBuffer.String())
}
}