使用OpenAPI提升网关安全的开源软件,诚邀小伙伴参与

news2025/8/12 12:54:53

看过我博客的人都知道,我们是一家推广OpenAPI的企业。

OpenAPI是一种用于定义API结构的规范,在Java里我们可以使用swagger进行自动生成。其他语言也可以(Golang等)。通过这种对开发人员零成本的工具,我们可以高效的获取开放API服务的业务结构、合理输入及输出等描述信息。

我们自己也做了一个在线OpenAPI编辑器,用于API的设计和手工编辑。

上周,我们发布了0.7.0版本,增强了API网关的产品能力,突然有些突发奇想,如果我们结合OpenAPI的这种业务描述信息以及实际发生的访问日志,是不是就可以有效的对恶意访问进行筛选,比如查找常见的各式扫描访问和一些违规操作的目的呢。

于是这周开始,我们做了一个开源项目:

OpenAPI Log Caticon-default.png?t=M85Bhttps://gitee.com/bjf-fhe/apicat

目前的设想是,通过传入OpenAPI定义,对nginx的访问日志进行分析。希望可以通过本项目探测以下两类非法请求

  • 非法url请求

我们经常会看到扫描服务器的人试图通过常见url漏洞进行扫描,这些url访问的通常是常见服务漏洞的url,而不是开发开放的url,他们并不在OpenAPI定义中出现。

  • url功能滥用

前后台分离架构下,我们通常会提供一系列接口以便完成前端功能,这些功能通常以页面为组成组访问,或者以用户id为主,进行同用户访问,url功能滥用通常会出现在以下的情况下:

- 本应登陆后使用的数据接口出现登陆前访问

- 某个登录接口正确相应的客户批量化调用系统其他用户的相关资料

通常通过OpenAPI对接口的描述,我们可以按定义的参数将用户请求分组,分组后形成正常用户访问的API路径指纹,从而将正常访问和不正常访问进行区分。例如一个用户在登录后,通常提交的userid都会是同一个,于是我们通过ip和userid的成组输入关系,可以清楚的判定一个登录用户的正常访问指纹。而此时,如果出现一个在指纹内的,应该只面向登录用户的接口,突发的出现横向的,同一path,但不同userid的请求,可以判定为非法探针请求。

目前我们开展了初步的研发工作,但是鉴于我们自己的需求和验证场景较少,特别希望有运维的同学可以参与到我们的项目中来,如果你觉得哎,好像挺有意思的,欢迎与我们联系,参与讨论或提交需求。

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

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

相关文章

典型的偏微分方程数值解法

马上要参加亚太杯啦,听说今年亚太杯有经典的物理题,没什么好说的,盘它! 偏微分方程的数值解十分重要 椭圆型偏微分方程(不含时) 数值解法 二维拉普拉斯方程 例 边界条件 import numpy as np import mat…

教你如何使用云服务器搭建我的世界Minecraft服务器(超级简单-10分钟完成)

一个人玩游戏没啥意思,和朋友一块联机呢,距离太远,家庭局域网宽带又没有公网ip,你的朋友没办法与你联机,然而你只需要一台服务器即可搞定了;但是很多用户没没接触过相关的内容,具体的该怎么操作…

怎样做音乐相册怎样制作?手把手教你制作

大家平时出门游玩的时候,会拍摄一些好看的照片吗?那你们会将这些照片分享在社交平台上吗?普通的照片分享,有时会显得比较枯燥单调,其实我们可以将这些照片制作成音乐相册,这样就可以丰富照片的内容&#xf…

传输层-用户数据报协议(UDP)

UDP协议概述 用户数据报协议 UDP 是 Internet 传输层协议,提供无连接、不可靠、数据报尽力传输服务。 无连接:因此在支持两个进程间通信时,没有握手过程。不可靠:当应用进程将一个报文发送近 UDP 套接字时,UDP 并不能…

python+vue+elementui固定资产管理系统django mysql

目 录 摘 要 I ABSTRACT I 目 录 III 第1章 绪论 1 1.1开发背景 1 1.2开发意义 1 1.3研究内容 1 第2章 主要技术和工具介绍 3 前端技术:nodejsvueelementui 我们最初的项目结构由五个文件组成: manage.py:使用…

为什么管理类硕士(MBA/MEM/MPA)报考会成为职场人的香饽饽?

没个硕士学位,将来出门可能真的都不好意思打招呼了。近些天传言2023年考研人数达到接近550万的信息满天飞,无论真假,从目前已公布报考人数的院校来看,在去年的457万基础上再涨一波的几率是很大的。这其中,报考管理类、…

电科大离散数学-2-命题逻辑-1

目录 2.1 什么是命题 2.1.1 命题的定义 2.1.2 复合命题 2.2 命题联结词 2.2.1 否定联结词 2.2.2 合取联结词 2.2.3 析取联结词 2.2.4 蕴涵联结词 2.2.5 等价联结词 2.3 命题符号化及应用 2.3.1 命题连接词总结 2.3.2 命题联结词的优先级 2.3.3 命题联接词与开关电…

scala

Scala 概述 Scala是一门以Java虚拟机(JVM)为运行环境并将面向对象和函数式编程的最佳特性结合在一起的 静态类型编程语言(静态语言需要提前编译的如:Java、c、c等,动态语言如:js)。 Scala是一…

4-20mA转RS-485,Modbus数据采集模块 YL121

特点: ● 模拟信号采集,隔离转换 RS-485输出 ● 采用12位AD转换器,测量精度优于0.1% ● 通过RS-485接口可以程控校准模块精度 ● 信号输入 / 输出之间隔离耐压1000VDC ● 宽电源供电范围:8 ~ 32VDC ● 可靠性高,…

equals与==判断相等

一、 判断相等,判断的是物理地址相等。 二、equals 判断相等 equals 与hashCode 都是Object的方法。 所有的类都继承于Object,如果不重写equals。equals判断相等,底层也是使用来判断物理地址相等。 public boolean equals(Object obj) {re…

影响MySQL索引B+树高度的是什么?

提到MySQL,想必大多后端同学都不会陌生,提到B树,想必还是有很大部分都知道InnoDB引擎的索引实现,利用了B树的数据结构。 那InnoDB 的一棵B树可以存放多少行数据?它又有多高呢? 到底是哪些因素会对此造成影…

【软件测试】测试人的职责,我就是不当背锅侠......

目录:导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜)前言 测试的目的&#xf…

基于机器视觉的移动消防机器人(四)--实验验证

本文素材来源于北方民族大学 机电工程学院 作者:牟义达、黄瑞翔、李涛 指导老师:田国禾、张春涛 1. 自主行走功能验证 实验目的:让机器人小车行驶500ms后停500ms,循环重复。 实验器材:计算机、消防机器人小车。 实…

ACM MM ECCV 2022 | 美团视觉8篇论文揭秘内容领域的智能科技

人工智能技术正在成为内容领域的中台力量,其中视觉AI已经渗透到内容生产、内容审核、内容分发、用户互动、商业化变现等各个环节。美团视觉智能部以场景化的内容产品、智能化的内容工具助力产业,在内容的创作、内容分发等环节应用广泛。 前不久&#xff…

开源项目让你也可以尝试玩转工业物联网以及智慧工厂(智能制造),IOT开源网关、SCADA取数开源、PLC数据采集

物联网进入与传统产业深度融合发展的崭新阶段。未来10年内,全球物联网将创造10多万亿美元的价值,约占全球经济的1/10,并与城市管理、生产制造、汽车驾驶、能源环保等形成数个千亿级规模以上的细分市场。 随着物联网技术的快速发展&#xff0c…

win10怎么录屏?windows自带录屏功能怎么用

​相信很多小伙伴家里的电脑都是win10系统的,想要录制电脑上的画面,那么就需要用到了windows自带的录屏功能。win10怎么录屏?windows自带的录屏功能怎么用?别担心,今天小编就来教教大家如何在win10系统上录制电脑屏幕。…

Python程序员:代码写的好,丝滑的壁纸少不了

人生苦短,我用Python序言python批量下载最后序言 不知道大家的电脑桌面一般用的什么类型的壁纸? 早上来上班,打开电脑,被漂亮的桌面壁纸所吸引,年底将近,这又是哪个地方的节日? 才晓得&#x…

[附源码]java毕业设计美妆销售系统

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

[附源码]java毕业设计农产品网络销售系统

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

论文阅读笔记 | 三维目标检测——F-PointNet算法

如有错误,恳请指出。 文章目录1. 背景2. 网络结构2.1 Frustum Proposal2.2 3D Instance Segmentation2.3 3D Box Estimation3. 实验结果paper:《Frustum PointNets for 3D Object Detection from RGB-D Data》1. 背景 基与鸟瞰图投影的方法(…