responses.go 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. package httpx
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "sync"
  6. "github.com/tal-tech/go-zero/core/logx"
  7. )
  8. var (
  9. errorHandler = defaultErrorHandler
  10. lock sync.RWMutex
  11. )
  12. func Error(w http.ResponseWriter, err error) {
  13. lock.RLock()
  14. code, body := errorHandler(err)
  15. lock.RUnlock()
  16. WriteJson(w, code, body)
  17. }
  18. func Ok(w http.ResponseWriter) {
  19. w.WriteHeader(http.StatusOK)
  20. }
  21. func OkJson(w http.ResponseWriter, v interface{}) {
  22. WriteJson(w, http.StatusOK, v)
  23. }
  24. func SetErrorHandler(handler func(error) (int, interface{})) {
  25. lock.Lock()
  26. defer lock.Unlock()
  27. errorHandler = handler
  28. }
  29. func WriteJson(w http.ResponseWriter, code int, v interface{}) {
  30. w.Header().Set(ContentType, ApplicationJson)
  31. w.WriteHeader(code)
  32. if bs, err := json.Marshal(v); err != nil {
  33. http.Error(w, err.Error(), http.StatusInternalServerError)
  34. } else if n, err := w.Write(bs); err != nil {
  35. // http.ErrHandlerTimeout has been handled by http.TimeoutHandler,
  36. // so it's ignored here.
  37. if err != http.ErrHandlerTimeout {
  38. logx.Errorf("write response failed, error: %s", err)
  39. }
  40. } else if n < len(bs) {
  41. logx.Errorf("actual bytes: %d, written bytes: %d", len(bs), n)
  42. }
  43. }
  44. func defaultErrorHandler(err error) (int, interface{}) {
  45. return http.StatusBadRequest, err
  46. }