kong api网关hmac-auth认证插件的使用

2023-11-10 19:10

本文主要是介绍kong api网关hmac-auth认证插件的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、安装hmac-auth插件

我这里使用的kong管理界面为konga,在插件中选择hmac-auth插件

接下来我们对hmac-auth插件进行配置

下一步就是如何请求使用hmac-auth插件的网关了,我这里语言使用的是java,加密算法使用的是hmac-sha256,不多说,直接上代码

package com.kong.demo.test;import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;
import java.security.InvalidKeyException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Base64;
import java.util.Date;
import java.util.Locale;
import java.util.TimeZone;/*** @author ningchengrenjia* @date 2020/7/30 10:13**/
public class Simple {//请求体private static final String BODY="{\"test\":\"test\"}";//用户生成的hmac auth secretprivate static final String SECRET="12345";private static final String URL="";public static void main(String[] args){/*** 请求体加密,若在配置hmac-auth插件选择validate request body为true则需要对请求体进行加密*/String digest = encryptPassword(BODY);//GMT格式时间Date date=new Date();DateFormat format=new SimpleDateFormat("EEE, dd MMM yyyy HH:mm:ss z", Locale.US);format.setTimeZone(TimeZone.getTimeZone("GMT"));String hdate = format.format(date);/*** 生成签名的内容content* 若在配置hmac-auth插件时选择validate request body为true的情况下,content为:* String content=stb.append("date: ").append(hdate).append("\n").append("digest: SHA-256=").append(digest).toString();* 若在配置hmac-auth插件时选择validate request body为false的情况下,content为:* String content=stb.append("date: ").append(hdate).toString();** content中的内容都需要添加到请求头中,具体请看httpClient方法*/StringBuilder stb = new StringBuilder();String content=stb.append("date: ").append(hdate).append("\n").append("digest: SHA-256=").append(digest).toString();System.out.println(content);String signature = null;try {signature = new String(Base64.getEncoder().encode(signatureReturnBytes(content, SECRET)), "US-ASCII");System.out.println(signature);} catch (Exception e) {e.printStackTrace();}httpClient(digest,URL,hdate,signature,BODY);}/*** http请求时需要在请求头中添加认证相关信息* Authorization: hmac username="test", algorithm="hmac-sha256", headers="date digest", signature={}"* headers="date digest"中的内容为signature加密的内容,headers中列出的内容要添加到请求头中,如下面请求示例* 如 main 方法中content = stb.append("date: ").append(hdate).toString();* 那么headers="date"*/public static void httpClient(String digest, String url,String date,String signature,String body){CloseableHttpClient httpClient = HttpClients.createDefault();try{HttpPost httpPost = new HttpPost(url);httpPost.setHeader("Content-Type","application/json");httpPost.setHeader("Authorization","hmac username=\"test\", algorithm=\"hmac-sha256\", headers=\"date digest\", signature="+"\""+signature+"\"");httpPost.setHeader("date ",date);httpPost.setHeader("Digest ","SHA-256="+digest);StringEntity stringEntity = new StringEntity(body, "UTF-8");httpPost.setEntity(stringEntity);HttpResponse response = httpClient.execute(httpPost);}catch (Exception e){e.printStackTrace();}}public static byte[] signatureReturnBytes(String data, String key) throws NoSuchAlgorithmException, InvalidKeyException {SecretKeySpec signingKey = new SecretKeySpec(key.getBytes(), "HmacSHA256");Mac mac = Mac.getInstance("HmacSHA256");mac.init(signingKey);return mac.doFinal(data.getBytes());}public static String encryptPassword(String password){byte[] hashBytes = sha(password);return Base64.getEncoder().encodeToString(hashBytes);}public static byte[] sha(final String strText) {if (strText != null && strText.length() > 0) {try {MessageDigest messageDigest = MessageDigest.getInstance("SHA-256");messageDigest.update(strText.getBytes());return messageDigest.digest();} catch (NoSuchAlgorithmException e) {return null;}}else{return null;}}
}

 

这篇关于kong api网关hmac-auth认证插件的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/384688

相关文章

Go语言使用slices包轻松实现排序功能

《Go语言使用slices包轻松实现排序功能》在Go语言开发中,对数据进行排序是常见的需求,Go1.18版本引入的slices包提供了简洁高效的排序解决方案,支持内置类型和用户自定义类型的排序操作,本... 目录一、内置类型排序:字符串与整数的应用1. 字符串切片排序2. 整数切片排序二、检查切片排序状态:

MyBatis分页插件PageHelper深度解析与实践指南

《MyBatis分页插件PageHelper深度解析与实践指南》在数据库操作中,分页查询是最常见的需求之一,传统的分页方式通常有两种内存分页和SQL分页,MyBatis作为优秀的ORM框架,本身并未提... 目录1. 为什么需要分页插件?2. PageHelper简介3. PageHelper集成与配置3.

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Python文件操作与IO流的使用方式

《Python文件操作与IO流的使用方式》:本文主要介绍Python文件操作与IO流的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python文件操作基础1. 打开文件2. 关闭文件二、文件读写操作1.www.chinasem.cn 读取文件2. 写

PyQt6中QMainWindow组件的使用详解

《PyQt6中QMainWindow组件的使用详解》QMainWindow是PyQt6中用于构建桌面应用程序的基础组件,本文主要介绍了PyQt6中QMainWindow组件的使用,具有一定的参考价值,... 目录1. QMainWindow 组php件概述2. 使用 QMainWindow3. QMainW

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到