0
|
1 /*
|
|
2 server.go : server-program.
|
|
3 Version : 1.0
|
3
|
4 Last Change: 2018-10-03 水 10:22:04.
|
0
|
5
|
|
6 install to: server_root/
|
|
7
|
|
8 server_root/server
|
|
9 + db/
|
|
10 + release/
|
|
11 + images/
|
|
12 */
|
|
13 package main
|
|
14
|
|
15 import(
|
|
16 "path/filepath"
|
|
17 "fmt"
|
|
18 "io"
|
|
19 "log"
|
|
20 "net"
|
|
21 "net/http"
|
|
22 "os"
|
3
|
23 "time"
|
0
|
24 )
|
|
25
|
3
|
26 var server string
|
|
27 var port string
|
|
28 var server_root string
|
|
29
|
|
30 func init() {
|
|
31 port = ":3910"
|
|
32 server_root = filepath.Dir( os.Args[0] )
|
|
33 }
|
|
34
|
0
|
35 func main() {
|
|
36
|
3
|
37 // setting IP-Address & Port
|
0
|
38 addrs, err := net.InterfaceAddrs()
|
|
39 if err != nil {
|
|
40 log.Fatal( err )
|
|
41 }
|
|
42 for _, a := range addrs {
|
|
43 if ipnet, ok := a.( *net.IPNet ); ok && !ipnet.IP.IsLoopback() {
|
|
44 if ipnet.IP.To4() != nil {
|
|
45 server = ipnet.IP.String() + port
|
|
46 }
|
|
47 }
|
|
48 }
|
|
49
|
3
|
50 // start Web-server
|
0
|
51 fmt.Println( "server start [", server, "]" )
|
3
|
52 http.HandleFunc( "/", handler )
|
0
|
53 log.Fatal( http.ListenAndServe( server, nil ) )
|
|
54 }
|
|
55
|
3
|
56 func handler( w http.ResponseWriter, r *http.Request ) {
|
|
57 file := filepath.Join( server_root, filepath.FromSlash( r.URL.Path ) )
|
|
58 fmt.Println( "[access]", r.RemoteAddr, "|", time.Now().Format( "2006-01-02 15:04" ), "|", file )
|
|
59 f, err := os.Open( file )
|
|
60 if err != nil {
|
|
61 http.NotFound( w, r )
|
|
62 return
|
|
63 }
|
|
64 defer f.Close()
|
|
65 io.Copy( w, f )
|
|
66 }
|