xweb.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. // Package web is a lightweight web framework for Go. It's ideal for
  2. // writing simple, performant backend web services.
  3. package xweb
  4. import (
  5. "crypto/tls"
  6. "fmt"
  7. "io"
  8. "net/http"
  9. "os"
  10. "path/filepath"
  11. "app.yhyue.com/moapp/jybase/go-xweb/log"
  12. )
  13. const (
  14. Version = "0.2.1"
  15. )
  16. func redirect(w http.ResponseWriter, url string, status ...int) error {
  17. s := 302
  18. if len(status) > 0 {
  19. s = status[0]
  20. }
  21. w.Header().Set("Location", url)
  22. w.WriteHeader(s)
  23. _, err := w.Write([]byte("Redirecting to: " + url))
  24. return err
  25. }
  26. func Download(w http.ResponseWriter, fpath string) error {
  27. f, err := os.Open(fpath)
  28. if err != nil {
  29. return err
  30. }
  31. defer f.Close()
  32. fName := filepath.Base(fpath)
  33. w.Header().Set("Content-Disposition", fmt.Sprintf("attachment; filename=\"%v\"", fName))
  34. _, err = io.Copy(w, f)
  35. return err
  36. }
  37. const (
  38. defaultErrorTmpl = `<!DOCTYPE html>
  39. <html lang="en">
  40. <meta charset="UTF-8" />
  41. <title>%d - %s</title>
  42. <style type="text/css">
  43. body{border:0;margin:0;padding:0;background:#eee url('') right bottom;}
  44. .error{width:600px;border:1px solid #ccc;margin:100px auto;border-radius:5px;box-shadow:0 0 10px #ccc;background:#fff url('') no-repeat right bottom;}
  45. .error-body,.error-foot{margin:0 10px 10px 10px;}
  46. .error-body{margin-top:10px;min-height:180px}
  47. .error-head h1{padding:10px 10px 0 10px;margin:0 2px;vertical-align:middle;border-bottom:1px solid #eee;}
  48. .framework{color:#eee;font-size:11px}
  49. </style>
  50. <body>
  51. <div class="error">
  52. <div class="error-head">
  53. <h1>%d - %s</h1>
  54. </div>
  55. <div class="error-body">%s</div>
  56. <div class="error-foot">
  57. <input type="button" title="Back" value="返回" onclick="history.go(-1)"/>
  58. <em class="framework">(xweb v%s)</em>
  59. </div>
  60. </div>
  61. </body>
  62. </html>`
  63. )
  64. var errorTmpl string = ""
  65. func Error(w http.ResponseWriter, status int, content string) error {
  66. return mainServer.error(w, status, content)
  67. }
  68. // Process invokes the main server's routing system.
  69. func Process(c http.ResponseWriter, req *http.Request) {
  70. mainServer.Process(c, req)
  71. }
  72. // Run starts the web application and serves HTTP requests for the main server.
  73. func Run(addr string) {
  74. mainServer.Run(addr)
  75. }
  76. func RunBase(addr string, mux *http.ServeMux) {
  77. mainServer.RunBase(addr, mux)
  78. }
  79. func SimpleTLSConfig(certFile, keyFile string) (*tls.Config, error) {
  80. config := &tls.Config{}
  81. if config.NextProtos == nil {
  82. config.NextProtos = []string{"http/1.1"}
  83. }
  84. var err error
  85. config.Certificates = make([]tls.Certificate, 1)
  86. config.Certificates[0], err = tls.LoadX509KeyPair(certFile, keyFile)
  87. if err != nil {
  88. return nil, err
  89. }
  90. return config, nil
  91. }
  92. // RunTLS starts the web application and serves HTTPS requests for the main server.
  93. func RunTLS(addr string, config *tls.Config) {
  94. mainServer.RunTLS(addr, config)
  95. }
  96. // RunScgi starts the web application and serves SCGI requests for the main server.
  97. func RunScgi(addr string) {
  98. mainServer.RunScgi(addr)
  99. }
  100. // RunFcgi starts the web application and serves FastCGI requests for the main server.
  101. func RunFcgi(addr string) {
  102. mainServer.RunFcgi(addr)
  103. }
  104. // Close stops the main server.
  105. func Close() {
  106. mainServer.Close()
  107. }
  108. func AutoAction(c ...interface{}) {
  109. mainServer.AutoAction(c...)
  110. }
  111. func AddAction(c ...interface{}) {
  112. mainServer.AddAction(c...)
  113. }
  114. func AddTmplVar(name string, varOrFun interface{}) {
  115. mainServer.AddTmplVar(name, varOrFun)
  116. }
  117. func AddTmplVars(t *T) {
  118. mainServer.AddTmplVars(t)
  119. }
  120. func AddRouter(url string, c interface{}) {
  121. mainServer.AddRouter(url, c)
  122. }
  123. func AddFilter(filter Filter) {
  124. mainServer.AddFilter(filter)
  125. }
  126. func AddApp(a *App) {
  127. mainServer.AddApp(a)
  128. }
  129. func AddConfig(name string, value interface{}) {
  130. mainServer.AddConfig(name, value)
  131. }
  132. func AddHook(name string, fns ...interface{}) {
  133. XHook.Bind(name, fns...)
  134. }
  135. func SetTemplateDir(dir string) {
  136. mainServer.SetTemplateDir(dir)
  137. }
  138. func SetStaticDir(dir string) {
  139. mainServer.SetStaticDir(dir)
  140. }
  141. // SetLogger sets the logger for the main server.
  142. func SetLogger(logger *log.Logger) {
  143. mainServer.SetLogger(logger)
  144. }
  145. func MainServer() *Server {
  146. return mainServer
  147. }
  148. func RootApp() *App {
  149. return mainServer.RootApp
  150. }
  151. func Serv(name string) *Server {
  152. server, ok := Servers[name]
  153. if ok {
  154. return server
  155. }
  156. return nil
  157. }
  158. // Config is the configuration of the main server.
  159. var (
  160. Config *ServerConfig = &ServerConfig{
  161. RecoverPanic: true,
  162. EnableGzip: true,
  163. //Profiler: true,
  164. StaticExtensionsToGzip: []string{".css", ".js"},
  165. }
  166. Servers map[string]*Server = make(map[string]*Server) //[SWH|+]
  167. mainServer *Server = NewServer("main")
  168. )