http

package
v0.3.7 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 25, 2024 License: MIT, Apache-2.0 Imports: 19 Imported by: 19

Documentation

Index

Constants

View Source
const (
	// ContentTypeJavascript header value for JSONP & Javascript data.
	ContentTypeJavascript = "text/javascript"
	// ContentTypeHtml is the  string of text/html response header's content type value.
	ContentTypeHtml = "text/html"
	ContentTypeCss  = "text/css"
	// ContentTypeText header value for Text data.
	ContentTypeText = "text/plain"
	// ContentTypeXml header value for XML data.
	ContentTypeXml = "text/xml"
	// ContentTypeMarkdown custom key/content type, the real is the text/html.
	ContentTypeMarkdown = "text/markdown"
	// ContentTypeYamlText header value for YAML plain text.
	ContentTypeYamlText = "text/yaml"

	// ContentTypeMultipart header value for post multipart form data.
	ContentTypeMultipart = "multipart/form-data"

	// ContentTypeOctetStream header value for binary data.
	ContentTypeOctetStream = "application/octet-stream"
	// ContentTypeWebassembly header value for web assembly files.
	ContentTypeWebassembly = "application/wasm"
	// ContentTypeJson header value for JSON data.
	ContentTypeJson = "application/json"
	// ContentTypeJsonProblem header value for JSON API problem error.
	// Read more at: https://tools.ietf.org/html/rfc7807
	ContentTypeJsonProblem = "application/problem+json"
	// ContentTypeXmlProblem header value for XML API problem error.
	// Read more at: https://tools.ietf.org/html/rfc7807
	ContentTypeXmlProblem           = "application/problem+xml"
	ContentTypeJavascriptUnreadable = "application/javascript"
	// ContentTypeXmlUnreadable obsolete header value for XML.
	ContentTypeXmlUnreadable = "application/xml"
	// ContentTypeYaml header value for YAML data.
	ContentTypeYaml = "application/x-yaml"
	// ContentTypeProtobuf header value for Protobuf messages data.
	ContentTypeProtobuf = "application/x-protobuf"
	// ContentTypeMsgPack header value for MsgPack data.
	ContentTypeMsgPack = "application/msgpack"
	// ContentTypeMsgPack2 alternative header value for MsgPack data.
	ContentTypeMsgPack2 = "application/x-msgpack"
	// ContentTypeForm header value for post form data.
	ContentTypeForm = "application/x-www-form-urlencoded"

	// ContentTypeGrpc Content-Type header value for gRPC.
	ContentTypeGrpc      = "application/grpc"
	ContentTypeGrpcWeb   = "application/grpc-web"
	ContentTypePdf       = "application/pdf"
	ContentTypeJsonUtf8  = "application/json;charset=utf-8"
	ContentTypeFormParam = "application/x-www-form-urlencoded;param=value"

	ContentTypeImagePng              = "image/png"
	ContentTypeImageJpeg             = "image/jpeg"
	ContentTypeImageGif              = "image/gif"
	ContentTypeImageBmp              = "image/bmp"
	ContentTypeImageWebp             = "image/webp"
	ContentTypeImageAvif             = "image/avif"
	ContentTypeImageHeif             = "image/heif"
	ContentTypeImageSvg              = "image/svg+xml"
	ContentTypeImageTiff             = "image/tiff"
	ContentTypeImageXIcon            = "image/x-icon"
	ContentTypeImageVndMicrosoftIcon = "image/vnd.microsoft.icon"

	ContentTypeCharsetUtf8 = "charset=UTF-8"
)
View Source
const (
	HeaderDeviceInfo = "Device-AuthInfo"
	HeaderLocation   = "Location"
	HeaderArea       = "Area"
)
View Source
const (
	HeaderUserAgent                   = "User-Agent"
	HeaderXForwardedFor               = "X-Forwarded-For"
	HeaderXAccelBuffering             = "X-Accel-Buffering"
	HeaderAuth                        = "HeaderAuth"
	HeaderContentType                 = "Content-Type"
	HeaderTrace                       = "Tracing"
	HeaderTraceID                     = "Tracing-ID"
	HeaderTraceBin                    = "Tracing-Bin"
	HeaderAuthorization               = "Authorization"
	HeaderCookie                      = "Cookie"
	HeaderCookieValueToken            = "token"
	HeaderCookieValueDel              = "del"
	HeaderContentDisposition          = "Content-Disposition"
	HeaderContentEncoding             = "Content-Encoding"
	HeaderReferer                     = "Referer"
	HeaderAccept                      = "Accept"
	HeaderAcceptLanguage              = "Accept-Language"
	HeaderAcceptEncoding              = "Accept-Encoding"
	HeaderCacheControl                = "Cache-Control"
	HeaderSetCookie                   = "Set-Cookie"
	HeaderTrailer                     = "Trailer"
	HeaderTransferEncoding            = "Transfer-Encoding"
	HeaderTransferEncodingChunked     = "chunked"
	HeaderInternal                    = "Internal"
	HeaderTE                          = "TE"
	HeaderLastModified                = "Last-Modified"
	HeaderContentLength               = "Content-Length"
	HeaderAccessControlRequestMethod  = "Access-Control-Request-Method"
	HeaderAccessControlRequestHeaders = "Access-Control-Request-Headers"
	HeaderOrigin                      = "Origin"
	HeaderConnection                  = "Connection"
	HeaderRange                       = "Range"
	HeaderContentRange                = "Content-Range"
	HeaderAcceptRanges                = "Accept-Ranges"
)
View Source
const (
	HeaderGrpcTraceBin = "grpc-trace-bin"
	HeaderGrpcInternal = "grpc-internal"
)
View Source
const (
	FormDataFieldTmpl = `form-data; name="%s"`
	FormDataFileTmpl  = `form-data; name="%s"; filename="%s"`
	AttachmentTmpl    = `attachment; filename="%s" `
)
View Source
const DefaultRemoteAddr = "1.2.3.4"

DefaultRemoteAddr is the default remote address to return in RemoteAddr if an explicit DefaultRemoteAddr isn't set on ResponseRecorder.

Variables

View Source
var ResponseOk = json.RawMessage(`{"code":0}`)
View Source
var ResponseSysErr = json.RawMessage(`{"code":-1,"msg":"system error"}`)

Functions

func BasicAuth added in v0.1.9

func BasicAuth(username, password string) string

func CopyHttpHeader

func CopyHttpHeader(dst, src http.Header)

func FormatRange added in v0.1.11

func FormatRange(start, end, total int64) string

func GetToken

func GetToken(r *http.Request) string

func HandlerWrap added in v0.3.0

func HandlerWrap[REQ, RES any](service Service[*REQ, *RES]) http.Handler

func HandlerWrapCompatibleGRPC added in v0.3.0

func HandlerWrapCompatibleGRPC[REQ, RES any](method types.GrpcServiceMethod[*REQ, *RES]) http.Handler

func NewNoCloseRequest

func NewNoCloseRequest(req *http.Request, s []byte)

func NewNoCloseStrRequest

func NewNoCloseStrRequest(req *http.Request, s string)

func ParseDisposition added in v0.1.9

func ParseDisposition(disposition string) (mediatype string, params map[string]string, err error)

func ParseRange added in v0.1.9

func ParseRange(rangeHeader string) (start int64, end int64, total int64, err error)

func RespErrRep

func RespErrRep(w http.ResponseWriter, rep *errcode.ErrRep) (int, error)

func RespErrcode

func RespErrcode(w http.ResponseWriter, code errcode.ErrCode)

func RespError added in v0.1.9

func RespError(w http.ResponseWriter, code errcode.ErrCode, msg string)

func RespSuccess added in v0.0.28

func RespSuccess[T any](w http.ResponseWriter, msg string, data T) (int, error)

func RespSuccessData added in v0.0.28

func RespSuccessData(w http.ResponseWriter, data any) (int, error)

func RespSuccessMsg added in v0.0.28

func RespSuccessMsg(w http.ResponseWriter, msg string) (int, error)

func Response

func Response[T any](w http.ResponseWriter, code errcode.ErrCode, msg string, data T) (int, error)

func ResponseStreamWrite added in v0.3.7

func ResponseStreamWrite(w http.ResponseWriter, writer func(w io.Writer) bool)

func ResponseWrite added in v0.3.7

func ResponseWrite(w http.ResponseWriter, httpres IHttpResponse) (int, error)

func SetBasicAuth added in v0.1.9

func SetBasicAuth(header http.Header, username, password string)

func UnWarpContext added in v0.3.7

func UnWarpContext(ctx context.Context) any

func WarpContext added in v0.3.7

func WarpContext(v any) context.Context

Types

type Body

type Body map[string]any

type HandlerFuncs

type HandlerFuncs []http.HandlerFunc

func (*HandlerFuncs) Add

func (hs *HandlerFuncs) Add(handler http.HandlerFunc)

func (HandlerFuncs) HandlerFunc

func (hs HandlerFuncs) HandlerFunc() http.HandlerFunc

func (HandlerFuncs) ServeHTTP

func (hs HandlerFuncs) ServeHTTP(w http.ResponseWriter, r *http.Request)

type Handlers

type Handlers []http.Handler

func (Handlers) ServeHTTP

func (hs Handlers) ServeHTTP(w http.ResponseWriter, r *http.Request)
type Header interface {
	IntoHttpHeader(header http.Header)
}

type HttpResponse

type HttpResponse struct {
	Status int               `json:"status,omitempty"`
	Header map[string]string `json:"header,omitempty"`
	Body   io.ReadCloser     `json:"body,omitempty"`
}

func (*HttpResponse) Close added in v0.3.7

func (res *HttpResponse) Close() error

func (*HttpResponse) Flush added in v0.3.7

func (res *HttpResponse) Flush() error

func (*HttpResponse) RespHeader added in v0.3.7

func (res *HttpResponse) RespHeader() map[string]string

func (*HttpResponse) Response added in v0.3.7

func (res *HttpResponse) Response(w http.ResponseWriter) (int, error)

func (*HttpResponse) StatusCode

func (res *HttpResponse) StatusCode() int

func (*HttpResponse) WriteTo added in v0.3.7

func (res *HttpResponse) WriteTo(writer io.Writer) (int64, error)

type HttpResponseRawBody added in v0.3.7

type HttpResponseRawBody struct {
	Status int               `json:"status,omitempty"`
	Header map[string]string `json:"header,omitempty"`
	Body   []byte            `json:"body,omitempty"`
}

func (*HttpResponseRawBody) Close added in v0.3.7

func (res *HttpResponseRawBody) Close() error

func (*HttpResponseRawBody) RespHeader added in v0.3.7

func (res *HttpResponseRawBody) RespHeader() map[string]string

func (*HttpResponseRawBody) Response added in v0.3.7

func (res *HttpResponseRawBody) Response(w http.ResponseWriter) (int, error)

func (*HttpResponseRawBody) StatusCode added in v0.3.7

func (res *HttpResponseRawBody) StatusCode() int

func (*HttpResponseRawBody) WriteTo added in v0.3.7

func (res *HttpResponseRawBody) WriteTo(writer io.Writer) (int64, error)

type IHttpResponse

type IHttpResponse interface {
	StatusCode() int
	RespHeader() map[string]string
	io.WriterTo
	io.Closer
}

type IHttpResponseWriteTo added in v0.3.7

type IHttpResponseWriteTo interface {
	Response(w http.ResponseWriter) (int, error)
}

type MapHeader added in v0.1.13

type MapHeader map[string]string

func (MapHeader) IntoHttpHeader added in v0.1.13

func (m MapHeader) IntoHttpHeader(header http.Header)

type NoCloseBody

type NoCloseBody struct {
	// contains filtered or unexported fields
}

func NewNoCloseBody

func NewNoCloseBody(s []byte) *NoCloseBody

适用于轮询

func (*NoCloseBody) Close

func (r *NoCloseBody) Close() error

func (*NoCloseBody) Len

func (r *NoCloseBody) Len() int

func (*NoCloseBody) Read

func (r *NoCloseBody) Read(b []byte) (n int, err error)

func (*NoCloseBody) Size

func (r *NoCloseBody) Size() int64

type NoCloseStrBody

type NoCloseStrBody struct {
	// contains filtered or unexported fields
}

func NewNoCloseStrBody

func NewNoCloseStrBody(s string) *NoCloseStrBody

适用于轮询

func (*NoCloseStrBody) Close

func (r *NoCloseStrBody) Close() error

func (*NoCloseStrBody) Len

func (r *NoCloseStrBody) Len() int

func (*NoCloseStrBody) Read

func (r *NoCloseStrBody) Read(b []byte) (n int, err error)

func (*NoCloseStrBody) Size

func (r *NoCloseStrBody) Size() int64

type ReceiveData

type ReceiveData = ResData[json.RawMessage]

func NewReceiveData added in v0.0.8

func NewReceiveData(code errcode.ErrCode, msg string, data any) *ReceiveData

type ReqResp added in v0.3.0

type ReqResp struct {
	*http.Request
	http.ResponseWriter
}

type RequestAt

type RequestAt struct {
	Time       time.Time
	TimeStamp  int64
	TimeString string
}

func NewRequestAt

func NewRequestAt() *RequestAt

func NewRequestAtFromTime

func NewRequestAtFromTime(t time.Time) *RequestAt

func (*RequestAt) String

func (r *RequestAt) String() string

type ResAnyData

type ResAnyData = ResData[any]

func NewErrorResData added in v0.1.11

func NewErrorResData(code errcode.ErrCode, msg string) *ResAnyData

func NewResAnyData added in v0.0.8

func NewResAnyData(code errcode.ErrCode, msg string, data any) *ResAnyData

func NewSuccessResData added in v0.1.11

func NewSuccessResData(data any) *ResAnyData

type ResData

type ResData[T any] struct {
	Code errcode.ErrCode `json:"code"`
	Msg  string          `json:"msg,omitempty"`
	//验证码
	Data T `json:"data,omitempty"`
}

ResData 主要用来接收返回,发送请使用ResAnyData

func NewResData

func NewResData[T any](code errcode.ErrCode, msg string, data T) *ResData[T]

func (*ResData[T]) Response

func (res *ResData[T]) Response(w http.ResponseWriter, statusCode int) (int, error)

type ResError added in v0.3.7

type ResError errcode.ErrRep

func ResErrorFromError added in v0.3.7

func ResErrorFromError(err error) *ResError

func (*ResError) Response added in v0.3.7

func (res *ResError) Response(w http.ResponseWriter, statusCode int) (int, error)

type ResponseRecorder

type ResponseRecorder struct {
	// Code is the HTTP response code set by WriteHeader.
	//
	// Note that if a Handler never calls WriteHeader or Write,
	// this might end up being 0, rather than the implicit
	// http.StatusOK. To get the implicit value, use the Result
	// method.
	Code int

	HeaderMap http.Header

	// Body is the buffer to which the Handler's Write calls are sent.
	// If nil, the Writes are silently discarded.
	Body *bytes.Buffer

	// Flushed is whether the Handler called Flush.
	Flushed bool
	// contains filtered or unexported fields
}

ResponseRecorder is an implementation of http.ResponseWriter that records its mutations for later inspection in tests.

func NewRecorder

func NewRecorder(header http.Header) *ResponseRecorder

NewRecorder returns an initialized ResponseRecorder.

func (*ResponseRecorder) Flush

func (rw *ResponseRecorder) Flush()

Flush implements http.Flusher. To test whether Flush was called, see rw.Flushed.

func (*ResponseRecorder) Header

func (rw *ResponseRecorder) Header() http.Header

Header implements http.ResponseWriter. It returns the response headers to mutate within a handler. To test the headers that were written after a handler completes, use the Result method and see the returned Response value's Header.

func (*ResponseRecorder) Reset

func (rw *ResponseRecorder) Reset()

func (*ResponseRecorder) Result

func (rw *ResponseRecorder) Result() *http.Response

Result returns the response generated by the handler.

The returned Response will have at least its StatusCode, Header, Body, and optionally Trailer populated. More fields may be populated in the future, so callers should not DeepEqual the result in tests.

The Response.Header is a snapshot of the headers at the time of the first write call, or at the time of this call, if the handler never did a write.

The Response.Body is guaranteed to be non-nil and Body.Read call is guaranteed to not return any error other than io.EOF.

Result must only be called after the handler has finished running.

func (*ResponseRecorder) Write

func (rw *ResponseRecorder) Write(buf []byte) (int, error)

Write implements http.ResponseWriter. The data in buf is written to rw.Body, if not nil.

func (*ResponseRecorder) WriteHeader

func (rw *ResponseRecorder) WriteHeader(code int)

WriteHeader implements http.ResponseWriter.

func (*ResponseRecorder) WriteString

func (rw *ResponseRecorder) WriteString(str string) (int, error)

WriteString implements io.StringWriter. The data in str is written to rw.Body, if not nil.

type Service added in v0.3.0

type Service[REQ, RES any] func(ctx ReqResp, req REQ) (RES, *ResError)

type SliceHeader added in v0.1.13

type SliceHeader []string

func NewHeader

func NewHeader() *SliceHeader

func (*SliceHeader) Add added in v0.1.13

func (h *SliceHeader) Add(k, v string) *SliceHeader

func (SliceHeader) Clone added in v0.1.13

func (h SliceHeader) Clone() SliceHeader

func (SliceHeader) IntoHttpHeader added in v0.1.13

func (h SliceHeader) IntoHttpHeader(header http.Header)

func (*SliceHeader) Set added in v0.1.13

func (h *SliceHeader) Set(k, v string) *SliceHeader

type StreamWriter

type StreamWriter interface {
	Write(io.Writer) (n int, err error)
	Flush() error
}

type WriteToCloser added in v0.3.7

type WriteToCloser interface {
	io.WriterTo
	io.Closer
}

Directories

Path Synopsis
v2
fs
gin
web
`grpcweb` implements the gRPC-Web spec as a wrapper around a gRPC-Go Server.
`grpcweb` implements the gRPC-Web spec as a wrapper around a gRPC-Go Server.
Package httprouter is a trie based high performance HTTP request router.
Package httprouter is a trie based high performance HTTP request router.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL