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

相关文章

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Qt中QUndoView控件的具体使用

《Qt中QUndoView控件的具体使用》QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的... 目录引言一、QUndoView 的用途二、工作原理三、 如何与 QUnDOStack 配合使用四、自

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关