创建一个HTTP服务端
其实Go语言创建一个简单的HTTP服务器程序,与Java Web的servlet差不多。比如,我们这里创建一个简单打印“Hello World”的程序。代码如下:
package main
import (
"fmt"
"net/http"
)
func helloworld(w http.ResponseWriter,r *http.Request) {
fmt.Fprintf(w,"Hello World")
}
func main() {
server :=&http.Server{
Addr: "127.0.0.1:80",
}
http.HandleFunc("/",helloworld)
server.ListenAndServe()
}
运行之后,在浏览器的网页输入框中输入127.0.0.1就会出现“Hello World”的简单网页。
这里,我们可以发现,如果需要通过Go语言创建一个服务器,就需要了解net/http包的内部逻辑。我们只看main()函数中的代码,会发现其调用了HandleFunc()函数以及ListenAndServe()函数。
ListenAndServe()
在Go语言中,ListenAndServe()函数有2个参数,第一个为监听的端口号,第二个为事件处理器handler。而handler接口的定义如下:
type Handler interface{
ServerHTTP(ResponseWriter,*Request)
}
只要实现了这个接口,就可以实现自己的handler处理器。其具体的实现方式如下:
type HandlerFunc func(ResponseWriter,*Request)
func (f HandlerFunc)ServerHTTP(w ResponseWriter,r *Request){
f(w,r)
}
handler处理器类似于Java SpringMVC框架中的Interceptor,是一个拦截器。它发生在http.HandlerFunc()函数处理逻辑之前。
ServeHTTP()方法的使用示例
假如我们需要实现在HTTP发送请求时,只有带上指定的refer参数,该请求才能调用成功,否则返回403状态。示例如下:
定义Refer结构体
type Refer struct {
handler http.Handler
refer string
}
这里可以看到,作者定义了2个对象,handler与自定义的refer。
实现ServeHTTP()方法
完整代码如下:
package main
import (
"fmt"
"net/http"
)
type Refer struct {
handler http.Handler
refer string
}
func (this *Refer) ServeHTTP(w http.ResponseWriter,r *http.Request) {
if r.Referer()==this.refer{
this.handler.ServeHTTP(w,r)
}else{
w.WriteHeader(403)
}
}
func myHandler(w http.ResponseWriter,r *http.Request) {
w.Write([]byte("这是handler"))
}
func helloworld(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "Hello World")
}
func main() {
referer :=&Refer{
handler: http.HandlerFunc(myHandler),
refer: "www.liyuanjing.com",
}
http.HandleFunc("/hello", helloworld)
http.ListenAndServe(":80",referer)
}
这个时候,如果运行后,你直接输入127.0.0.1,网页会显示拒绝访问。
创建一个HTTPS服务端
在Go语言中,net/http包中提供了创建HTTPS服务的方法,其定义如下:
func (srv *Server)ListenAndServeTLS(certFile,keyFile string) error
通过上面的方法,我们可以知道,HTTPS服务的创建只需要2个参数即可。其中,第一个参数为证书文件的路径,第二个参数为私钥文件的路径。
而我们需要先创建这2个文件,方能创建HTTPS服务。不过,一般能在互联网流通的证书都是付费的,虽然有些能免费,但比较麻烦。所以,这里博主仅做个示例,也就自己用用。
创建证书与私钥
首先,你需要保证电脑下载,并正确配置了openssl。如果已经下载配置,可以直接使用如下命令行进行证书与私钥的创建。
openssl req -newkey rsa:2048 -nodes -keyout server.key -x509 -days 365 -out server.crt
执行该命令后,命令行的输出内容如下。这里,读者可以随便输入。
执行完这些命令后,该目录下会自动生成2个文件server.crt与server.key。下面,我们就可以使用这2个文件来创建自己的HTTPS服务器了。
创建HTTPS服务端
话不多说,这里直接上代码,示例如下:
package main
import (
"net/http"
)
func handle(w http.ResponseWriter, r *http.Request) {
w.Write([]byte("Hello World HTTPS"))
}
func main() {
server := &http.Server{Addr: ":80", Handler: http.HandlerFunc(handle)}
server.ListenAndServeTLS("server.crt", "server.key")
}
运行之后,网页不会输出Hello World HTTPS,那是因为这么创建的HTTPS相关证书是不被互联网认可的,但创建的过程就是这样。
|