Go Web编程实战(8)----创建HTTP与HTTPS服务器端

简介: Go Web编程实战(8)----创建HTTP与HTTPS服务器端

创建一个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相关证书是不被互联网认可的,但创建的过程就是这样。

相关文章
|
13天前
|
前端开发 JavaScript 安全
前端性能调优:HTTP/2与HTTPS在Web加速中的应用
【10月更文挑战第27天】本文介绍了HTTP/2和HTTPS在前端性能调优中的应用。通过多路复用、服务器推送和头部压缩等特性,HTTP/2显著提升了Web性能。同时,HTTPS确保了数据传输的安全性。文章提供了示例代码,展示了如何使用Node.js创建一个HTTP/2服务器。
27 3
|
18天前
|
移动开发 开发者 HTML5
构建响应式Web界面:Flexbox与Grid的实战应用
【10月更文挑战第22天】随着互联网的普及,用户对Web界面的要求越来越高,不仅需要美观,还要具备良好的响应性和兼容性。为了满足这些需求,Web开发者需要掌握一些高级的布局技术。Flexbox和Grid是现代Web布局的两大法宝,它们分别由CSS3和HTML5引入,能够帮助开发者构建出更加灵活和易于维护的响应式Web界面。本文将深入探讨Flexbox和Grid的实战应用,并通过具体实例来展示它们在构建响应式Web界面中的强大能力。
32 3
|
13天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
96 44
|
1天前
|
缓存 安全 网络安全
HTTP/2与HTTPS在Web加速中的应用
HTTP/2与HTTPS在Web加速中的应用
|
5天前
|
数据采集 监控 Java
go语言编程学习
【11月更文挑战第3天】
21 7
|
11天前
|
Unix Linux Go
go进阶编程:Golang中的文件与文件夹操作指南
本文详细介绍了Golang中文件与文件夹的基本操作,包括读取、写入、创建、删除和遍历等。通过示例代码展示了如何使用`os`和`io/ioutil`包进行文件操作,并强调了错误处理、权限控制和路径问题的重要性。适合初学者和有经验的开发者参考。
|
9天前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
21 1
|
11天前
|
SQL 负载均衡 安全
安全至上:Web应用防火墙技术深度剖析与实战
【10月更文挑战第29天】在数字化时代,Web应用防火墙(WAF)成为保护Web应用免受攻击的关键技术。本文深入解析WAF的工作原理和核心组件,如Envoy和Coraza,并提供实战指南,涵盖动态加载规则、集成威胁情报、高可用性配置等内容,帮助开发者和安全专家构建更安全的Web环境。
29 1
|
14天前
|
前端开发 安全 应用服务中间件
前端性能调优:HTTP/2与HTTPS在Web加速中的应用
【10月更文挑战第26天】随着互联网的快速发展,前端性能调优成为开发者的重要任务。本文探讨了HTTP/2与HTTPS在前端性能优化中的应用,介绍了二进制分帧、多路复用和服务器推送等特性,并通过Nginx配置示例展示了如何启用HTTP/2和HTTPS,以提升Web应用的性能和安全性。
16 3
|
14天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
28 2

热门文章

最新文章