下载站

展开
精品推荐
Tyk API Gateway下载-开源API网关 v2.9.5

Tyk API Gateway下载-开源API网关 v2.9.5

程序源码大小:537.80MB语言: / 简体中文 类别:其他软件系统: / WinAll 提供:
应用介绍

软件介绍

TykAPIGateway是一个绿色安全、免费开源的轻量级API网关软件,为开发人员门户和API管理仪表板提供完整生命周期API管理平台,使用这款网关软件用户能够完全控制你的API,可以自由设置API访问权限,从而保证网络的安全性;TykAPIGateway功能强大、专业实用,使用这款软件用户可以创建多个API,可应用于多个密钥的安全策略,创建密钥可以将配额和速率限制应用于API或者可以从安全策略继承设置,通过该API网关软件可以有效控制和保护网络的访问安全,有需要的朋友可以下载使用。

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

软件功能

使用任何协议:REST,SOAP,GraphQL,gRPC和TCP。

行业标准身份验证:OIDC,JWT,承载令牌,基本身份验证,客户端证书等。

开放的API标准:将您的Swagger和OAS2/3文档导入Tyk中的脚手架API。

超高性能:低延迟和仅单个CPU即可实现数千rp的水平和垂直扩展。

内容中介:转换所有内容,从请求或响应标头到在SOAP和GraphQL之间转换。

可扩展的插件体系结构:通过以您选择的语言(从Python到Javascript到Go或任何支持gRPC的语言)编写插件来定制Tyk的中间件链。

速率限制和配额:保护您的上游免受过载和/或对每个消费者施加限制。

API版本控制-可以在特定时间和日期轻松设置和弃用API版本。

粒度访问控制-在每个版本和操作的基础上授予对一个或多个API的访问权限。

阻止列表/允许列表/被忽略的端点访问-逐个版本对访问点实施严格的安全模型。

Analytics日志记录-记录有关谁在使用您的API的详细使用情况数据(仅原始数据)

CORS-为某些API启用CORS,以便用户可以进行基于浏览器的请求

Webhooks-针对诸如配额违反和身份验证失败之类的事件触发Webhooks

IP允许列表-阻止对非信任IP地址的访问,以实现更安全的交互

重载-可以动态更改Tyk配置,并重新启动服务,而不会影响任何活动请求

Kubernetes本机声明性API:使用开源Tyk运算符(更多信息参见OSS部分)

软件特色

RESTFulAPI

众多访问协议开箱即用。

费率限制

配额的执行

粒度访问控制

钥匙到期日

API版本管理

黑名单/白名单/忽略端点访问。

分析和监测

网络钩

IP白名单

零停机时间重启

通知和活动

向后兼容性

官方教程

Tyk测试指南

对于测试,主要问题之一是如何在表达性,可扩展性,可重复性和性能之间保持平衡。关于是否应该编写集成或单元测试,是否应该进行模拟,是否应该先编写测试,之后还是之后编写测试等问题,有无数的讨论。由于永远找不到正确的答案,在不断增长的代码基础上,许多人开始介绍自己的方法和独特的测试助手。即使查看我们很小的代码库,您也可以找到3-4种编写相同测试的方法。

本文档介绍了Tyk测试框架和有关编写测试的统一准则。

测试框架的要点是:

所有测试都通过完整的HTTP堆栈运行HTTP请求,与用户执行的操作相同

测试定义逻辑与测试运行程序分开。

仪表板,RPC和Bundler的官方模拟

位于“github.com/TykTechnologies/tyk/test”包中的框架。参见其API文档https://godoc.org/github.com/TykTechnologies/tyk/test

让我们通过示例学习:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

直接Github链接

现在,将其与以前的Go风格方法进行比较:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

直接Github链接

请注意,在最后一种“经典”方式中,我们仅定义了一个测试用例,而在我们的新框架中,我们定义了6个,所有这些都是可重复的,并且共享框架提供的相同断言和测试运行器逻辑。

现在,让我们逐一检查使用新框架编写的测试。

初始化测试服务器

核心思想之一是,测试应尽可能接近真实用户。为了实现它,框架为您提供了一种使用tykTestServer对象以编程方式启动和停止完整的GatewayHTTP堆栈的方法,如下所示:

ts:=newTykTestServer()

推迟ts。关闭()

创建新服务器时,它会初始化网关本身,在随机端口上启动侦听器,设置所需的全局变量等。这与启动网关进程时发生的情况非常相似,但是在这种情况下,您可以按需启动和停止它。

您可以使用很少的变量来配置服务器行为,例如通过提供tykTestServerConfigobjectnewTykTestServer作为参数来在单独的端口上设置控件API。这是所有可能参数的列表:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

要关闭服务器,只需调用tykTestServer#Closemethod即可,这将确保所有侦听器都将被正确关闭。

加载和配置API

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

您具有默认的最低限度的最低API定义(可以使用生成器功能进行配置)以设置测试所需的状态的基本思想。然后,API将被加载到网关中,并准备在测试中使用。

如果需要同时加载多个API,请buildAndLoadAPI支持可变数量的参数:buildAndLoadAPI(,,...)

您也可以完全不带参数地调用它,在这种情况下,它将加载默认的API定义:buildAndLoadAPI()

实际上,此函数是2个较低级函数的混搭:buildAPI和loadAPI,都返回[]*APISpec数组。在某些情况下,您可能需要构建API模板,并进行一些较小的修改即可根据需要在不同的测试中加载它。因此它看起来像:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

在API版本内更新变量可能很棘手,因为API版本对象位于Versionsmap内,并且禁止使用map值进行直接操作。为了简化此过程,有一个特殊的helperupdateAPIVersion,可以像这样使用:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

在某些情况下,通过Go结构更新API定义可能会有些复杂,您可能需要直接通过JSON解封更新API定义:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

运行测试

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

使用新的test程序包TestCase结构定义测试,该程序包结构允许您定义http请求详细信息和响应断言。例如,使用指定的标头{Method:"GET",Path:"/",Headers:validPassword,Code:200}告诉对路径的GET请求/。发出请求后,它将声明具有给定值的响应状态代码。

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

tykTestServer提供了一个测试运行程序,该运行程序根据规范生成HTTP请求并进行断言。大多数情况下,您将要使用tykTestServer#Run(t*testing.T,test.TestCase...)(*http.Response,error)功能。请注意,它使用可变数量的参数,因此,如果您需要传递多个测试用例,请像上面的示例一样传递它:[]test.TestCase{,}...,最后加3个点。

此外,还有RunEx具有完全相同定义的函数,但是在内部它使用overrideDefaults和hotReload选项的不同组合多次运行测试用例(现在为4)。如果您需要测试紧密依赖于热重载功能的功能(例如重载API,加载插件包或侦听器本身),这可能会很方便。

无论Run和RunEx也返回最后一个测试用例响应和错误,在情况下,如果你需要它。

更改配置变量

在许多情况下,测试取决于各种配置变量。您可以直接在config.Global对象上更新它们,并使用resetTestConfig函数恢复默认配置。

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

上游测试服务器

您可能会注意到默认API已经针对一些为测试目的而创建的上游模拟。上游保留testHttpAny变量的URL,但是在大多数情况下,您不需要它,因为默认情况下创建的API已经嵌入了它。默认情况下,此上游模拟将成功响应任何url,并且响应将以以下格式包含请求的详细信息:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

请注意,它包含最终请求的详细信息,因此,例如,如果您需要测试URL重写功能,原始请求的URL将不同于上游模拟的URL,则可以使用以下内容进行断言:BodyMatch:“Url”:“”。还要注意我们如何使用简单的BodyMatch字符串断言来验证JSON响应。

也有一些具有特定行为的特殊URL:

/get仅接受GET请求

/post仅接受POST请求

/jwk.json用于从upsteram下载JWK令牌的情况

/ws用于测试WebSockets

/bundles内置插件包网络服务器,下面有更多详细信息

协同处理插件测试

如果要使用Python,Lua或GRPC插件,则需要将捆绑清单文件和脚本打包到ZIP文件,将它们上传到外部文件Web服务器上的某个位置,然后将Gateway指向捆绑位置。

我们的测试框架包括内置的捆绑文件服务器,为简单起见,您仅提供捆绑文件的内容,它将自动将其作为ZIP文件进行服务器处理。

创建map[string]string具有文件内容的对象,其中键为文件名

呼叫registerBundle("",)将返回唯一的捆绑ID。

创建API时,将其设置spec.CustomMiddlewareBundle为由返回的包IDregisterBundle

加载pythonauth插件的示例:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

创建用户会话

您可以通过调用createSession函数来创建类似于API的用户会话:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

如果您可以使用默认设置,也可以不带参数调用它createSession()

如果您需要创建会话对象而不将其添加到数据库中,例如,如果您需要通过API显式创建密钥,则可以使用createStandardSession()函数,该函数返回*user.SessionState对象。

自定义上游模拟

如果您需要创建自定义的上游测试服务器,例如,如果您需要自定义的TLS设置来进行相互TLS测试,则最简单的方法是使用标准的Gonet/http/httptest程序包并覆盖spec.Proxy.TargetURLAPIURL来测试服务器。

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

模拟仪表板

还没有任何特定对象可以模拟仪表板,但由于Dashboard是标准的HTTP服务器,因此您可以使用类似于“自定义上游模拟”部分中所述的方法:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

模拟RPC(混合)

当Gateway在Hybrid模式下工作时,它将使用gorpc库通过RPC通道与MDCB实例进行通信。您可以使用startRPCMock和stopRPCMock函数来模拟RPC服务器。startRPCMock在内部设置所需的配置变量以启用RPC模式。

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

DNS模拟

在内部测试中,我们将覆盖默认的网络解析器,以使用自定义DNS服务器模拟,并使用强大的github.com/miekg/dns库进行创建。域-通过映射helpers_test.go文件内部设置的IP映射。默认情况下,您可以访问域:localhost,host1.local,host2.local和host3.local。访问所有未知域将引起恐慌。

使用DNS模拟意味着您可以在多个域上使用API创建测试,而无需修改计算机/etc/hosts文件。

测试框架

上述框架的使用不受TykGateway的限制,并且可在各种Tyk项目中使用。主要构建块是测试运行程序。

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

通过覆盖其变量,您可以调整跑步者的行为。例如,http运行程序可以如下所示:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

http处理程序的单元测试可以是:

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

该软件包已经导出了上述情况的功能:

funcTestHttpServer(ttesting.TB,baseURLstring,testCases...TestCase)

funcTestHttpHandler(ttesting.TB,handlehttp.HandlerFunc,testCases...TestCase)

Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

Tags:Tyk API Gateway下载,开源API网关,网络安全,程序源码,源码相关

应用推荐查看更多
热门下载查看更多
精选应用
点击查看更多
专题合集查看更多
热门专题查看更多
友情链接0投诉联系:ichaoinc@gmail.com