mirror of
https://github.com/golang/go
synced 2024-11-22 11:34:47 -07:00
net/http: couple more triv.go modernizations
R=golang-dev, rsc CC=golang-dev https://golang.org/cl/5834049
This commit is contained in:
parent
aec01c3627
commit
a4e6197b91
@ -17,6 +17,7 @@ import (
|
|||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
"sync"
|
||||||
)
|
)
|
||||||
|
|
||||||
// hello world, the web server
|
// hello world, the web server
|
||||||
@ -29,14 +30,21 @@ func HelloServer(w http.ResponseWriter, req *http.Request) {
|
|||||||
|
|
||||||
// Simple counter server. POSTing to it will set the value.
|
// Simple counter server. POSTing to it will set the value.
|
||||||
type Counter struct {
|
type Counter struct {
|
||||||
|
mu sync.Mutex // protects n
|
||||||
n int
|
n int
|
||||||
}
|
}
|
||||||
|
|
||||||
// This makes Counter satisfy the expvar.Var interface, so we can export
|
// This makes Counter satisfy the expvar.Var interface, so we can export
|
||||||
// it directly.
|
// it directly.
|
||||||
func (ctr *Counter) String() string { return fmt.Sprintf("%d", ctr.n) }
|
func (ctr *Counter) String() string {
|
||||||
|
ctr.mu.Lock()
|
||||||
|
defer ctr.mu.Unlock()
|
||||||
|
return fmt.Sprintf("%d", ctr.n)
|
||||||
|
}
|
||||||
|
|
||||||
func (ctr *Counter) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
func (ctr *Counter) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
||||||
|
ctr.mu.Lock()
|
||||||
|
defer ctr.mu.Unlock()
|
||||||
switch req.Method {
|
switch req.Method {
|
||||||
case "GET":
|
case "GET":
|
||||||
ctr.n++
|
ctr.n++
|
||||||
@ -110,23 +118,22 @@ func Logger(w http.ResponseWriter, req *http.Request) {
|
|||||||
http.Error(w, "oops", 404)
|
http.Error(w, "oops", 404)
|
||||||
}
|
}
|
||||||
|
|
||||||
var webroot = flag.String("root", "/home/rsc", "web root directory")
|
var webroot = flag.String("root", os.Getenv("HOME"), "web root directory")
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
// The counter is published as a variable directly.
|
// The counter is published as a variable directly.
|
||||||
ctr := new(Counter)
|
ctr := new(Counter)
|
||||||
http.Handle("/counter", ctr)
|
|
||||||
expvar.Publish("counter", ctr)
|
expvar.Publish("counter", ctr)
|
||||||
|
http.Handle("/counter", ctr)
|
||||||
http.Handle("/", http.HandlerFunc(Logger))
|
http.Handle("/", http.HandlerFunc(Logger))
|
||||||
http.Handle("/go/", http.StripPrefix("/go/", http.FileServer(http.Dir(*webroot))))
|
http.Handle("/go/", http.StripPrefix("/go/", http.FileServer(http.Dir(*webroot))))
|
||||||
http.Handle("/flags", http.HandlerFunc(FlagServer))
|
|
||||||
http.Handle("/args", http.HandlerFunc(ArgServer))
|
|
||||||
http.Handle("/go/hello", http.HandlerFunc(HelloServer))
|
|
||||||
http.Handle("/chan", ChanCreate())
|
http.Handle("/chan", ChanCreate())
|
||||||
http.Handle("/date", http.HandlerFunc(DateServer))
|
http.HandleFunc("/flags", FlagServer)
|
||||||
|
http.HandleFunc("/args", ArgServer)
|
||||||
|
http.HandleFunc("/go/hello", HelloServer)
|
||||||
|
http.HandleFunc("/date", DateServer)
|
||||||
err := http.ListenAndServe(":12345", nil)
|
err := http.ListenAndServe(":12345", nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Panicln("ListenAndServe:", err)
|
log.Panicln("ListenAndServe:", err)
|
||||||
|
Loading…
Reference in New Issue
Block a user