当前位置: 首页 > news >正文

基于.net6的一款开源的低代码、权限、工作流、动态接口平台-动态接口篇

概述

动态接口允许用户在运行时创建和修改API端点,而无需重新部署应用程序。这对于需要频繁更改API结构的应用程序特别有用。

通过动态接口,开发人员可以根据业务需求快速调整API,提升开发效率和响应速度。

功能特点

动态创建和修改API端点:用户可以在运行时添加、更新或删除API端点。

支持JSON数据格式:动态接口支持JSON数据交换格式。

配置说明

新增一个动态脚本

在管理后台导航到“接口管理”-“脚本管理”模块。

点击左侧文件树上方的菜单“+”按钮,新增一个动态脚本文件。

修改脚本名称和内容。

点击运行按钮,测试脚本是否正常。

保存脚本。

例如

using System;

using System.Threading.Tasks;

using Newtonsoft.Json;

using System;

using JESAI.Core.Aspects;

using JESAI.Platform.Domain.Admin.Repositories;

using Jesai.DynamicDataSource.Sqlsugar.DynamicDatasources;

public class Program

{

public string Handle(string param){

//查询数据库

var provider = ServiceLocator.Instance.GetService<IDbProvider>();

var db=provider.GetConnection("Test").Result;

var data=db.Ado.SqlQuery<dynamic>("select * from mlt_sys_dynamic_datasource");

// 创建包含多个匿名对象的数组

var tableData = new[]

{

new { Id = 1, TableName = "用户表", TableCode = "user", TableDesc = "用户信息表", IsValid = 1, CreateTime = "2023-10-01 12:00:00" },

new { Id = 2, TableName = "订单表", TableCode = "order", TableDesc = "订单信息表", IsValid = 1, CreateTime = "2023-10-02 12:00:00" },

new { Id = 3, TableName = "产品表", TableCode = "product", TableDesc = "产品信息表", IsValid = 0, CreateTime = "2023-10-03 12:00:00" }

};

var result=new {ErrorCode="000000",Message="操作成功!",CurrentPage=1,Total=3,Data=new {tableData=tableData,DBData=data}};

var str=JsonConvert.SerializeObject(result);

return str;

}

public static async Task Main()

{

var p= new Program();

var result=p.Handle(null);

Console.WriteLine(result);

}

}

注意:接口的入口方法必须是public string Handle(string param),其中param是JSON格式的字符串,返回值也是JSON格式的字符串。可以自己修改为动态的方法名。

如图所示,新增一个动态脚本。

微信图片_2025-11-24_101504_700

运行测试,如图所示,输出结果正常。

微信图片_2025-11-24_103039_727

2. 通过动态脚本创建API端点

- 在管理后台导航到“接口管理”-“接口定义”模块。

- 点击“新增”按钮,新增一个接口定义。

- 填写接口名称、路径、方法、脚本名称等信息。

- 点击“保存”按钮,保存接口定义。

如图所示,打开接口定义模块。

微信图片_2025-11-24_104529_387

如图所示,新增一个接口定义。

微信图片_2025-11-24_105204_858

测试调用

打开swagger,查看一下调用接口。

微信图片_2025-11-24_105513_546

使用JWT认证调用接口

Postman测试调用接口,传入参数,查看返回结果。

微信图片_2025-11-24_111346_110

使用API密钥授权‌或‌签名认证授权‌调用接口

先从系统查询AppID和AppSecret。(直接从数据库查询,管理模块暂时还没做)

微信图片_2025-11-28_134918_788

计算签名Token,计算方法如下:

取当前系统时间戳,使用AppSecret对齐进行加密,得到Token。

例如:当前时间戳为1699424000000,AppSecret为TWM8uRwhTNzOCU7PDXAN47fewMMnF9GP,使用Aes加密,得到Token为:

+74ZCFZHXe3z0in4RomdqA==

long currentTimeStamp = DateTimeOffset.UtcNow.ToUnixTimeMilliseconds();

var token= AesEncryptor.Instance.Encrypt(currentTimeStamp.ToString(), "TWM8uRwhTNzOCU7PDXAN47fewMMnF9GP");

Console.WriteLine(token);

调用接口时,在请求头或者参数中添加AppKey和Token。

微信图片_2025-11-28_141235_180

微信图片_2025-11-28_141258_105

注意:

- 前端调用,一般使用JWT,通过${baseUrl}/api/v1/UniformPlatform/Get/TestDynamicApi?param=1 调用。需要在请求头中添加Authorization,值为Bearer

j

w

t

T

o

k

e

n

<

/

s

p

a

n

>

<

s

p

a

n

s

t

y

l

e

="

c

o

l

o

r

:

r

e

d

;

f

o

n

t

w

e

i

g

h

t

:

b

o

l

d

;

">

A

P

I

{baseUrl}/api/v1/UniformApp/Get/TestDynamicApi?param=1 调用。需要在请求头中添加AppKey,Token。

http://www.cnnetsun.cn/news/111756.html

相关文章:

  • 企业级多语言构建革命:Bazel如何重塑你的开发流程?
  • 【量子电路可视化终极指南】:手把手教你用VSCode打造高效渲染工作流
  • 快速掌握pandapower:电力系统建模与分析的终极指南 [特殊字符]
  • 突破性姿态识别引擎:打造智能动作分析新标杆
  • 5个让用户爱不释手的图片预览技巧:从基础到高级画廊
  • 数据恢复神器TestDisk:如何用3个关键步骤找回你丢失的所有文件?
  • 语音识别终极指南:解锁智能语音交互新体验
  • 毕业论文AI生成网站推荐:7大免费替代工具
  • 如何在最后30天实现计算机408分数质的飞跃?高效备考突破技巧全解析
  • 告别YouTube追踪:Invidious隐私保护生态完整搭建指南
  • 2025零代码AE动画:Lottie-Web让Web动效轻松实现
  • 架构:不仅仅是建模,而是一种思维
  • Book118文档下载神器:Java工具帮你免费获取学习资料
  • PLabel图像标注工具极速上手指南
  • 10分钟掌握FunASR:流式语音识别从入门到部署的完整实战指南
  • 教师考评新方式:线上系统让评分变得更简单
  • Biotin-PEG-NH2/NHS/N3:结构、反应特性与应用场景的全面对比
  • DTLN噪声抑制实战指南:从原理到部署的全流程解析
  • 深入libgit2:从零开始构建跨平台Git库的完整指南
  • AI选岗工具提升求职效率200%
  • ReadCat跨平台阅读器:打造专属数字书房的全新体验
  • Zotero阅读进度管理终极指南:告别文献混乱的完整解决方案
  • WAN2.2AllInOne V5:重新定义AI视频生成的“极速创作时代“
  • 开源项目商业化实战:Continue如何构建技术价值与商业回报的完美闭环
  • Yuzu模拟器终极配置指南:从零到60帧的完整优化方案
  • 终极SonarQube代码质量报告自动化解决方案:企业级数据驱动决策指南
  • 开展性能测试步骤
  • Coze工作流实战:从踩坑到精通
  • JSON性能革命:RapidJSON如何用SIMD技术改写C++数据处理格局
  • ImageOptim跨版本兼容性全面解析:从macOS 10.13到最新系统的实战指南