Go打造REST Server【二】:用路由的三方库来实现

前言

在之前的文章中,我们用Go的标准库来实现了服务器,JSON渲染重构为辅助函数,使特定的路由处理程序相当简洁。
我们剩下的问题是路径路由逻辑,这是所有编写无依赖HTTP服务器的人都会遇到的问题,除非服务器只处理一到两个路由,否则组织路由器代码是冗长和困难的。

高级路由

首先的想法是抽象路由,可能使用一组函数或带有方法的数据类型,有许多有趣的临时方法可以做到这一点,Go生态系统中有许多功能强大且使用良好的三方路由包可以为做这件事。
我们再回顾一下设计的服务器路由:

POST   /page/              :  create a page, returns ID
GET    /page/<pageid>      :  returns a single page by ID
GET    /page/              :  returns all pages
DELETE /page/<pageid>      :  delete a page by ID
PUT    /page/<pageid>      :  update a page by ID
GET    /tag/<tagname>      :  returns list of pages with this tag
GET    /due/<yy>/<mm>/<dd> :  returns list of pages due by this date

我们可以做几件事来使路由更符合观感:

  • 添加一种方法来为同一路由上的不同方法设置单独的处理程序。例如,/page/的POST应该转到一个处理程序,GET /page/到另一个处理程序,等等。
  • 添加一种“更深”匹配的方法;例如,我们应该可以说/page/进入一个处理程序,而 /page/使用数字ID进入另一个处理程序。
  • 当我们这样做时,匹配器应该只从/page/中提取数字ID并以某种方便的方式将其传递给处理程序。

由于HTTP处理程序的可组合性,在Go中编写自定义路由器非常简单,例如最流行的第三方方路由包之一:gorilla/mux。

gorilla/mux实现的服务器

gorilla/mux是最久的流行Go HTTP路由器之一,根据文档,名称mux代表“HTTP请求多路复用器”(与标准库中的含义相同)。
因为它是一个目标明确的包,所以它的使用相当简单,以下是路由的定义方式:

router := mux.NewRouter()
router.StrictSlash(true)
server := NewPageServer()router.HandleFunc("/page/", server.createPageHandler).Methods("POST")
router.HandleFunc("/page/", server.getAllPagesHandler).Methods("GET")
router.HandleFunc("/page/", server.deleteAllPagesHandler).Methods("DELETE")
router.HandleFunc("/page/", server.updatePageHandler).Methods("PUT")
router.HandleFunc("/page/{id:[0-9]+}/", server.getPageHandler).Methods("GET")
router.HandleFunc("/page/{id:[0-9]+}/", server.deletePageHandler).Methods("DELETE")
router.HandleFunc("/tag/", server.tagHandler).Methods("GET")
router.HandleFunc("/due/", server.dueHandler).Methods("GET")

通过将方法调用附加到路由上,我们可以轻松地将同一路径上的不同方法定向到不同的处理程序。路径中的模式匹配(使用正则表达式语法)让我们可以轻松地区分顶级路由定义中的/page/和/page/。

我们来看看getPageHandler:

func (p *PageServer) getPageHandler(w http.ResponseWriter, r *http.Request) {log.Printf("handling get page at %s\n", r.URL.Path)// Here and elsewhere, not checking error of Atoi because the router only// matches the [0-9]+ regex.id, _ := strconv.Atoi(mux.Vars(r)["id"])ret, err := p.store.GetPage(id)if err != nil {http.Error(w, err.Error(), http.StatusNotFound)return}renderJSON(w, ret)
}

在路由定义中,路由/page/{id:[0-9]+}/定义了解析路径的正则表达式,但也将标识符部分分配给“id”。这个“变量”可以通过在请求上调用mux.Vars来访问。

方法对比

为了理解GET /page/路由在我们的原始服务器中是如何处理的,必须采用以下代码阅读路径:
在这里插入图片描述
而这是使用gorilla/mux时的路径:
在这里插入图片描述
除了可以跳过的步骤更少之外,要阅读的代码也大大减少了,从代码可读性的角度来看,使用gorilla/mux的路径定义简短明了,阅读者很清楚这是如何工作的。另一个优势是,我们现在可以在一个地方一目了然地轻松查看所有路由。事实上,路由配置代码现在看起来与我们非正式的REST API定义非常相似。
像gorilla/mux这样的包,因为它们是一个精密工具,他们只做一件事,而且做得很好,而且他们不会“感染”整个程序,使他们以后难以删除或替换。如果我们检查这部分的服务器代码,我们会注意到使用gorilla/mux的部分仅限于相对较少的代码行。如果我们在项目生命周期的后期发现这个包有一个致命的限制,用另一个路由包(或手动版本)替换它应该是相当简单的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/779181.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis桌面客户端

3.4.Redis桌面客户端 安装完成Redis&#xff0c;我们就可以操作Redis&#xff0c;实现数据的CRUD了。这需要用到Redis客户端&#xff0c;包括&#xff1a; 命令行客户端图形化桌面客户端编程客户端 3.4.1.Redis命令行客户端 Redis安装完成后就自带了命令行客户端&#xff1…

描述堆数据结构及其用途

描述堆数据结构及其用途 堆数据结构是一种特殊的树形数据结构&#xff0c;它通常被实现为完全二叉树。堆具有两个重要的特性&#xff1a;堆序性和完全二叉树的结构性。堆序性指的是堆中任意节点的值都满足一定的条件&#xff0c;通常分为最大堆和最小堆两种。在最大堆中&#x…

面向对象特征一:封装性

9.1 为什么需要封装&#xff1f; 我要用洗衣机&#xff0c;只需要按一下开关和洗涤模式就可以了。有必要了解洗衣机内部的结构吗&#xff1f;有必要 碰电动机吗&#xff1f; 我要开车&#xff0c;我不需要懂离合、油门、制动等原理和维修也可以驾驶。 客观世界里每一个事物…

乐维更改IP地址

1.1 系统IP调整 vim /etc/sysconfig/network-scripts/ifcfg-ens1921.2 Web相关服务IP变更 1.2.1 编辑/itops/nginx/html/lwjkapp/.env文件,更改ZABBIXSERVER、ZABBIXRPCURL、DB_HOST中的IP 1.2.2 进入/itops/nginx/html/lwjk_app/目录下,执行php bin/manager process-conso…

(免费分享)基于微信小程序电影院购票系统带论文

基于小程序的电影院购票管理系统【含报告】&#xff1a;前端 vue、elementui、小程序&#xff0c;后端 maven、springboot、springmvc、spring、mybatis&#xff0c;角色分为管理员、用户&#xff1b;集成小程序浏览电影&#xff0c;购票等功能于一体的系统。 目录 摘要 I Ab…

AtCoder Regular Contest 140 C - ABS Permutation (LIS ver.)

C - ABS Permutation (LIS ver.) 目录 题意&#xff1a; 思路&#xff1a; 我没做出来的原因&#xff1a; 代码&#xff1a; 题意&#xff1a; p数组是permutation&#xff0c;n个数&#xff0c;所有连续两数之差的绝对值可以构成a数组。问a数组**严格**递增的最长长度是多…

关于Devc++调试的问题以及解决STL变量无法查看

目前Devc的调试主要有以下几点&#xff1a; 1.调试不能直接查看stl变量&#xff0c;会卡死不动 2.目前单步进入只能用鼠标键按 3.若想按下一步进入函数体内&#xff0c;要在函数体内打上断点才行 4.调试到return 0 ;上一句就停了&#xff0c;不会结束程序 5.目前F2跳至断点…

elasticsearch 8.12+kibana 8.12

准备工作&#xff1a;1.下载相关的安装包放到/usr/local/ES下面 elasticsearch下载地址:Download Elasticsearch | Elastic elasticsearch-head-master下载地址:https://github.com/mobz/elasticsearch-head/archive/master.zip node下载地址:Index of /dist/ kibana地址:Downl…

nacos的各种类型的配置文件 yml 、json、 Properties、 text 等文件类型 发生变化怎么热更新,实现实时监听nacos配置文件变化

本文用的是 Nacos作为配置中心注册监听器方法 实现热更新 nacos 配置文件 从而不用重启项目 依赖、工具类 这边就不写了 因为项目用的是 Json 类型的配置文件 所以下文 主要是对json文件进行实现 别的文件大同小异 先说扯淡的东西 在nacos 的配置文件中 dataId 这两种声明 是…

华为流量整形配置

组网需求 如图1所示&#xff0c;企业网内部LAN侧的语音、视频和数据业务通过Switch连接到RouterA的Eth2/0/0上&#xff0c;并通过RouterA的GE3/0/0连接到WAN侧网络。 不同业务的报文在LAN侧使用802.1p优先级进行标识&#xff0c;在RouterA上根据报文的802.1p优先级入队列&…

c++初阶篇----string的底层模拟

string类的模拟 目录 string类的模拟功能介绍各功能的实现类的构造函数&#xff0c;拷贝构造函数&#xff0c;析构函数迭代器的实现string的内部容量访问成员函数string的修改成员函数string类的相关联函数string类的输入输出友元 汇总string功能的实现汇总测试代码 功能介绍 …

2024.3.29每日一题

LeetCode 元素和最小的山形三元组 I 题目链接&#xff1a; 题目描述 给你一个下标从 0 开始的整数数组 nums 。 如果下标三元组 (i, j, k) 满足下述全部条件&#xff0c;则认为它是一个 山形三元组 &#xff1a; i < j < knums[i] < nums[j] 且 nums[k] < nu…

Backend - python 连接 操作 PostgreSQL DB(数据库)

目录 一、基础环境 &#xff08;一&#xff09;建立虚拟环境 &#xff08;二&#xff09;安装依赖 二、连接数据库 三、操作数据库 &#xff08;一&#xff09;查询 &#xff08;二&#xff09;单笔更新/插入 &#xff08;三&#xff09;批量更新/插入 &#xff08;四…

Containerd 介绍、安装和使用

Containerd介绍、安装和使用 文章目录 Containerd介绍、安装和使用1.containerd是什么&#xff1f;2.Containerd安装2.1 主机初始化2.1.1 设置ip地址2.1.2 配置镜像源2.1.3 关闭防火墙2.1.4 禁用SELinux2.1.5 禁用swap2.1.6 设置时区 2.2 安装 containerd2.2.1 内核参数调整2.2…

成都某公司笔试题sql

– 1.某公司需要将项目管理清单导入数据库&#xff0c;请建表&#xff0c;清单字段如下:项目编码&#xff0c;项目名称&#xff0c;项目开始时间&#xff0c;项目结束时间&#xff0c;周期(月)&#xff0c;项目金额&#xff0c;客户名称&#xff0c;客户地址&#xff0c;备注。…

【八大排序】一篇文章搞定所有排序

文章目录 1.排序的概念2.常见排序算法的实现2.1 插入排序2.1.1直接插入排序2.1.2希尔排序 2.2选择排序2.2.1直接选择排序:2.2.2堆排序 2.3交换排序2.3.1冒泡排序2.3.2快速排序Hoare法前后指针法挖坑法非递归版本 2.4归并排序递归版本非递归版本 2.5计数排序3.排序的比较 1.排序…

2024年EDM邮件营销群发平台怎么选?

在2024年选择适合的EDM&#xff08;电子邮件直接营销&#xff09;邮件营销群发平台时&#xff0c;需要考虑以下几个关键要素来评估云衔科技以及其他供应商的产品或服务是否符合您的需求&#xff1a; 一、功能完备性&#xff1a; 1、智能自动化&#xff1a;确保云衔科技提供的…

用DataGrip连接hive时报错:User: root is not allowed to impersonate plck5,解决方法

你可以尝试关闭主机校验 修改hive安装目录下conf/hive-site.xml,将hive.server2.enable.doAs设置成false <property><name>hive.server2.enable.doAs</name><value>false</value><description>Setting this property to true will have H…

Gitea 的简单介绍

Gitea 是一个基于 Go 语言开发的自助 Git 服务程序。它是一个轻量级的代码托管系统&#xff0c;类似于 GitHub 或 GitLab&#xff0c;可以让你搭建自己的私有 Git 仓库。通过 Gitea&#xff0c;用户可以创建和管理 Git 仓库、进行代码托管、问题追踪、团队协作等操作。Gitea 支…

JQuery基础

JQuery就是封装了js的常用代码 用起来更加简洁方便 使用jQuery前可去官网下载载入js文件 编写第一个jq代码 $(document).ready(function (){ console.log("Hellw,jQuery!") })ready方法与js中的onload事件类似 不过还是有区别的 js的onload事件是在等待页面所有的…