本文整理匯總了Golang中net/http.ServeMux類的典型用法代碼示例。如果您正苦於以下問題:Golang ServeMux類的具體用法?Golang ServeMux怎麽用?Golang ServeMux使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了ServeMux類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: HTTPTransport
// HTTPTransport creates an ingress bridge from the outside world to the passed
// server, by installing handlers for all the necessary RPCs to the passed mux.
func HTTPTransport(mux *http.ServeMux, s *Server) {
mux.HandleFunc(IDPath, idHandler(s))
mux.HandleFunc(AppendEntriesPath, appendEntriesHandler(s))
mux.HandleFunc(RequestVotePath, requestVoteHandler(s))
mux.HandleFunc(CommandPath, commandHandler(s))
mux.HandleFunc(SetConfigurationPath, setConfigurationHandler(s))
}
示例2: handleItems
func handleItems(mux *http.ServeMux) {
mux.HandleFunc("/api/v2/items", func(w http.ResponseWriter, r *http.Request) {
switch r.Method {
case "POST":
defer r.Body.Close()
b, err := ioutil.ReadAll(r.Body)
if err != nil {
testutil.ResponseError(w, 500, err)
return
}
if len(b) == 0 {
testutil.ResponseAPIError(w, 500, api.ResponseError{
Type: "fatal",
Message: "empty body",
})
return
}
type Options struct {
Tweet *bool `json:"tweet"`
Gist *bool `json:"gist"`
}
var options Options
err = json.Unmarshal(b, &options)
if err != nil {
testutil.ResponseError(w, 500, err)
return
}
if options.Tweet == nil || options.Gist == nil {
testutil.ResponseError(w, 500, errors.New("tweet or gist is required"))
return
}
var post model.Post
err = json.Unmarshal(b, &post)
if err != nil {
testutil.ResponseError(w, 500, err)
return
}
post.ID = "4bd431809afb1bb99e4f"
post.URL = "https://qiita.com/yaotti/items/4bd431809afb1bb99e4f"
post.CreatedAt = model.Time{Time: time.Date(2016, 2, 1, 12, 51, 42, 0, time.UTC)}
post.UpdatedAt = post.CreatedAt
b, err = json.Marshal(post)
if err != nil {
testutil.ResponseError(w, 500, err)
return
}
_, err = w.Write(b)
if err != nil {
testutil.ResponseError(w, 500, err)
return
}
default:
w.WriteHeader(405)
}
})
}
示例3: RegesterHandlers
func (s *Service) RegesterHandlers(mux *http.ServeMux) error {
mux.HandleFunc("/file/", func(w http.ResponseWriter, req *http.Request) {
s.file(w, req)
})
mux.HandleFunc("/get/", func(w http.ResponseWriter, req *http.Request) {
// o, _ := httputil.DumpRequest(req, false)
// log.Println(string(o))
if !s.auth.Auth(w, req) {
log.Println("401 Unauthorized")
return
}
s.get(w, req)
})
mux.HandleFunc("/upload/", func(w http.ResponseWriter, req *http.Request) {
s.upload(w, req)
})
mux.HandleFunc("/put-auth", func(w http.ResponseWriter, req *http.Request) {
if !s.auth.Auth(w, req) {
log.Println("401 Unauthorized")
return
}
s.putAuth(w, req)
})
mux.HandleFunc("/delete/", func(w http.ResponseWriter, req *http.Request) {
if !s.auth.Auth(w, req) {
log.Println("401 Unauthorized")
return
}
s.delete(w, req)
})
return nil
}
示例4: InitHTTPFlv
func InitHTTPFlv(mux *http.ServeMux, app string, sources *source.SourceManage, cb callback.FlvCallback) {
prefix := path.Join("/", app) + "/"
mux.HandleFunc(prefix, func(w http.ResponseWriter, r *http.Request) {
glog.Infof("http: get an request: %v", r.RequestURI)
if r.Method != "GET" {
return
}
r.ParseForm()
// access check.
if !cb.FlvAccessCheck(r.RemoteAddr, r.RequestURI, r.URL.Path, r.Form, r.Cookies()) {
w.WriteHeader(http.StatusForbidden)
return
}
// get path.
_, file := path.Split(r.URL.Path)
var key string
key = file[:strings.Index(file, ".flv")]
// get live source.
consumer, err := source.NewConsumer(sources, key)
if err != nil {
glog.Info("can not get source", err)
return
}
glog.Info("get source")
defer consumer.Close()
// set flv live stream http head.
// TODO: let browser not cache sources.
w.Header().Add("Content-Type", "video/x-flv")
if err := consumer.Live(w); err != nil {
glog.Info("Live get an client error:", err)
}
})
}
示例5: newMethodRouter
// newMethodRouter takes the server mux that will dispatch to this router based on the matched path.
func newMethodRouter(mux *http.ServeMux, path string) *methodRouter {
mr := &methodRouter{
handlers: map[string]http.Handler{},
}
mux.Handle(path, mr)
return mr
}
示例6: handleAuth
func handleAuth(mux *http.ServeMux, sh *authHandler) {
mux.HandleFunc(authPrefix+"/roles", capabilityHandler(authCapability, sh.baseRoles))
mux.HandleFunc(authPrefix+"/roles/", capabilityHandler(authCapability, sh.handleRoles))
mux.HandleFunc(authPrefix+"/users", capabilityHandler(authCapability, sh.baseUsers))
mux.HandleFunc(authPrefix+"/users/", capabilityHandler(authCapability, sh.handleUsers))
mux.HandleFunc(authPrefix+"/enable", capabilityHandler(authCapability, sh.enableDisable))
}
示例7: handleSecurity
func handleSecurity(mux *http.ServeMux, sh *securityHandler) {
mux.HandleFunc(securityPrefix+"/roles", sh.baseRoles)
mux.HandleFunc(securityPrefix+"/roles/", sh.handleRoles)
mux.HandleFunc(securityPrefix+"/users", sh.baseUsers)
mux.HandleFunc(securityPrefix+"/users/", sh.handleUsers)
mux.HandleFunc(securityPrefix+"/enable", sh.enableDisable)
}
示例8: setMux
func setMux(t *testing.T, mux *http.ServeMux, path string, thing interface{}) {
mux.HandleFunc(path, func(w http.ResponseWriter, r *http.Request) {
var data []byte
var err error
switch thing := thing.(type) {
default:
t.Errorf("Unexpected object type in SetMux: %v", thing)
case *github.Issue:
data, err = json.Marshal(thing)
case *github.PullRequest:
data, err = json.Marshal(thing)
case []github.IssueEvent:
data, err = json.Marshal(thing)
case []github.RepositoryCommit:
data, err = json.Marshal(thing)
case github.RepositoryCommit:
data, err = json.Marshal(thing)
case *github.CombinedStatus:
data, err = json.Marshal(thing)
case []github.User:
data, err = json.Marshal(thing)
}
if err != nil {
t.Errorf("%v", err)
}
if r.Method != "GET" {
t.Errorf("Unexpected method: expected: GET got: %s", r.Method)
}
w.WriteHeader(http.StatusOK)
w.Write(data)
})
}
示例9: staticDirHandler
func staticDirHandler(mux *http.ServeMux, prefix string, staticDir string) {
mux.HandleFunc(prefix, func(w http.ResponseWriter, r *http.Request) {
file := staticDir + r.URL.Path[len(prefix)-1:]
fmt.Println(file)
http.ServeFile(w, r, file)
})
}
示例10: setupPlugin
func setupPlugin(t *testing.T, name string, mux *http.ServeMux) func() {
if err := os.MkdirAll("/etc/docker/plugins", 0755); err != nil {
t.Fatal(err)
}
server := httptest.NewServer(mux)
if server == nil {
t.Fatal("Failed to start an HTTP Server")
}
if err := ioutil.WriteFile(fmt.Sprintf("/etc/docker/plugins/%s.spec", name), []byte(server.URL), 0644); err != nil {
t.Fatal(err)
}
mux.HandleFunc("/Plugin.Activate", func(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "application/vnd.docker.plugins.v1+json")
fmt.Fprintf(w, `{"Implements": ["%s"]}`, driverapi.NetworkPluginEndpointType)
})
return func() {
if err := os.RemoveAll("/etc/docker/plugins"); err != nil {
t.Fatal(err)
}
server.Close()
}
}
示例11: startSecureServing
func startSecureServing(opt *options.HeapsterRunOptions, handler http.Handler, promHandler http.Handler,
mux *http.ServeMux, address string) {
if len(opt.TLSClientCAFile) > 0 {
authPprofHandler, err := newAuthHandler(opt, handler)
if err != nil {
glog.Fatalf("Failed to create authorized pprof handler: %v", err)
}
handler = authPprofHandler
authPromHandler, err := newAuthHandler(opt, promHandler)
if err != nil {
glog.Fatalf("Failed to create authorized prometheus handler: %v", err)
}
promHandler = authPromHandler
}
mux.Handle("/", handler)
mux.Handle("/metrics", promHandler)
// If allowed users is set, then we need to enable Client Authentication
if len(opt.AllowedUsers) > 0 {
server := &http.Server{
Addr: address,
Handler: mux,
TLSConfig: &tls.Config{ClientAuth: tls.RequestClientCert},
}
glog.Fatal(server.ListenAndServeTLS(opt.TLSCertFile, opt.TLSKeyFile))
} else {
glog.Fatal(http.ListenAndServeTLS(address, opt.TLSCertFile, opt.TLSKeyFile, mux))
}
}
示例12: InstallDebugHandlers
//TODO(jdef) we use a Locker to guard against concurrent task state changes, but it would be
//really, really nice to avoid doing this. Maybe someday the registry won't return data ptrs
//but plain structs instead.
func InstallDebugHandlers(reg Registry, mux *http.ServeMux) {
mux.HandleFunc("/debug/registry/tasks", func(w http.ResponseWriter, r *http.Request) {
//TODO(jdef) support filtering tasks based on status
alltasks := reg.List(nil)
io.WriteString(w, fmt.Sprintf("task_count=%d\n", len(alltasks)))
for _, task := range alltasks {
if err := func() (err error) {
podName := task.Pod.Name
podNamespace := task.Pod.Namespace
offerId := ""
if task.Offer != nil {
offerId = task.Offer.Id()
}
_, err = io.WriteString(w, fmt.Sprintf("%v\t%v/%v\t%v\t%v\n", task.ID, podNamespace, podName, task.State, offerId))
return
}(); err != nil {
log.Warningf("aborting debug handler: %v", err)
break // stop listing on I/O errors
}
}
if flusher, ok := w.(http.Flusher); ok {
flusher.Flush()
}
})
}
示例13: HandleFuncLoginOptional
func HandleFuncLoginOptional(
mux *http.ServeMux, path string, s *Sessions, f HandlerFuncWithUser) {
wrapped := func(w http.ResponseWriter, r *http.Request) {
f(w, r, s.GetUser(r))
}
mux.HandleFunc(path, wrapped)
}
示例14: HandleFunc
// HandleFunc registers a handler at the given path. It's
// http.HandleFunc(), but with a wrapper around the handler that
// provides some generic per-request functionality:
//
// * Set a Replay-Nonce header.
//
// * Respond to OPTIONS requests, including CORS preflight requests.
//
// * Set a no cache header
//
// * Respond http.StatusMethodNotAllowed for HTTP methods other than
// those listed.
//
// * Set CORS headers when responding to CORS "actual" requests.
//
// * Never send a body in response to a HEAD request. Anything
// written by the handler will be discarded if the method is HEAD.
// Also, all handlers that accept GET automatically accept HEAD.
func (wfe *WebFrontEndImpl) HandleFunc(mux *http.ServeMux, pattern string, h wfeHandlerFunc, methods ...string) {
methodsMap := make(map[string]bool)
for _, m := range methods {
methodsMap[m] = true
}
if methodsMap["GET"] && !methodsMap["HEAD"] {
// Allow HEAD for any resource that allows GET
methods = append(methods, "HEAD")
methodsMap["HEAD"] = true
}
methodsStr := strings.Join(methods, ", ")
handler := http.StripPrefix(pattern, &topHandler{
log: wfe.log,
clk: clock.Default(),
wfe: wfeHandlerFunc(func(ctx context.Context, logEvent *requestEvent, response http.ResponseWriter, request *http.Request) {
// We do not propagate errors here, because (1) they should be
// transient, and (2) they fail closed.
nonce, err := wfe.nonceService.Nonce()
if err == nil {
response.Header().Set("Replay-Nonce", nonce)
logEvent.ResponseNonce = nonce
} else {
logEvent.AddError("unable to make nonce: %s", err)
}
switch request.Method {
case "HEAD":
// Go's net/http (and httptest) servers will strip out the body
// of responses for us. This keeps the Content-Length for HEAD
// requests as the same as GET requests per the spec.
case "OPTIONS":
wfe.Options(response, request, methodsStr, methodsMap)
return
}
// No cache header is set for all requests, succeed or fail.
addNoCacheHeader(response)
if !methodsMap[request.Method] {
response.Header().Set("Allow", methodsStr)
wfe.sendError(response, logEvent, probs.MethodNotAllowed(), nil)
return
}
wfe.setCORSHeaders(response, request, "")
timeout := wfe.RequestTimeout
if timeout == 0 {
timeout = 5 * time.Minute
}
ctx, cancel := context.WithTimeout(ctx, timeout)
// TODO(riking): add request context using WithValue
// Call the wrapped handler.
h(ctx, logEvent, response, request)
cancel()
}),
})
mux.Handle(pattern, handler)
}
示例15: Handler
func Handler(mux *http.ServeMux) {
mux.HandleFunc("/debug", debug)
mux.HandleFunc("/archive", archiveHandler)
mux.HandleFunc("/delete", deleteHandler)
mux.HandleFunc("/star", starHandler)
mux.HandleFunc("/", serve)
}