Grule前端表单post后端执行grule引擎规则

Grule前端表单post后端执行grule引擎规则

  • 编写前端表单和后端接口

编写test.go执行grule引擎规则

  • 示例都是 go test 执行的测试代码,所以将里面的测试代码去除
    • 由于之前 NumberExponentExample_test.go 已经验证可运行, 所以将 err 的异常处理去除
package mainimport ("log""github.com/hyperjumptech/grule-rule-engine/ast""github.com/hyperjumptech/grule-rule-engine/builder""github.com/hyperjumptech/grule-rule-engine/engine""github.com/hyperjumptech/grule-rule-engine/pkg"
)type ExponentData struct {Check float64Set   float64
}const ExponentRule = `
rule  ExponentCheck  "User Related Rule"  salience 10 {when ExponentData.Check == 6.67428e-11ThenExponentData.Set = .12345E+5;Retract("ExponentCheck");
}
`func main() {exponent := &ExponentData{Check: 6.67428e-11,Set:   0,}dataContext := ast.NewDataContext()dataContext.Add("ExponentData", exponent)lib := ast.NewKnowledgeLibrary()rb := builder.NewRuleBuilder(lib)rb.BuildRuleFromResource("TestExponent", "1.0.0", pkg.NewBytesResource([]byte(ExponentRule)))eng1 := &engine.GruleEngine{MaxCycle: 5}kb, _ := lib.NewKnowledgeBaseInstance("TestExponent", "1.0.0")eng1.Execute(dataContext, kb)log.Println(exponent)
}
  • 运行结果: 结构体 ExponentDataSet 字段被设置为了 12345
$ go run test.go 
2024/12/05 01:22:59 &{6.67428e-11 12345}

部署gin和加载模板引擎

  • gin中文文档: https://learnku.com/docs/gin-gonic/1.7
  • 下载 gin 模块
go get -u github.com/gin-gonic/gin
  • 编写 main.go , 并引入 模板引擎
package mainimport ("net/http""github.com/gin-gonic/gin"
)func main() {r := gin.Default()r.LoadHTMLGlob("templates/*")r.GET("/index", func(c *gin.Context) {c.HTML(http.StatusOK, "index.tmpl", gin.H{})})r.Run()
}
  • 创建 templates 目录, 然后添加 index.tmpl 模板
mkdir -p templates && touch templates/index.tmpl

编写前端表单

  • 编写表单, 往后端 /number/ 接口发送 post 请求
<html><form action="/number/" method="POST" ><textarea name="textarea"></textarea><input type="submit" value="Submit"></form>
</html>
  • 启动项目访问 localhost:8080/index 会看到一个文本框
go run main.go

在这里插入图片描述

编写后端接口

  • 编写 /number/ 的后端接口, 运行Grule规则
import ("github.com/hyperjumptech/grule-rule-engine/ast""github.com/hyperjumptech/grule-rule-engine/builder""github.com/hyperjumptech/grule-rule-engine/engine""github.com/hyperjumptech/grule-rule-engine/pkg"
)type ExponentData struct {Check float64Set   float64
}func main() {r.POST("/number/", func(c *gin.Context) {textareaContent := c.PostForm("textarea")exponent := &ExponentData{Check: 6.67428e-11,Set:   0,}dataContext := ast.NewDataContext()dataContext.Add("ExponentData", exponent)lib := ast.NewKnowledgeLibrary()rb := builder.NewRuleBuilder(lib)rb.BuildRuleFromResource("TestExponent", "1.0.0", pkg.NewBytesResource([]byte(textareaContent)))eng1 := &engine.GruleEngine{MaxCycle: 5}kb, _ := lib.NewKnowledgeBaseInstance("TestExponent", "1.0.0")eng1.Execute(dataContext, kb)c.JSON(http.StatusOK, gin.H{"textareaContent": exponent.Set,})})
}

验证表单传入Grule能否执行规则

  • 重启项目, 访问 localhost:8080/index , 将Grule规则放入文本框提交
rule  ExponentCheck  "User Related Rule"  salience 10 {when ExponentData.Check == 6.67428e-11ThenExponentData.Set = .12345E+5;Retract("ExponentCheck");
}

在这里插入图片描述

  • 结果能返回 exponentSet 字段值: 12345
    在这里插入图片描述

完整代码

  • main.go
package mainimport ("net/http""github.com/gin-gonic/gin""github.com/hyperjumptech/grule-rule-engine/ast""github.com/hyperjumptech/grule-rule-engine/builder""github.com/hyperjumptech/grule-rule-engine/engine""github.com/hyperjumptech/grule-rule-engine/pkg"
)type ExponentData struct {Check float64Set   float64
}func main() {r := gin.Default()r.GET("/ping", func(c *gin.Context) {c.JSON(200, gin.H{"message": "pong",})})r.LoadHTMLGlob("templates/*")r.GET("/index", func(c *gin.Context) {c.HTML(http.StatusOK, "index.tmpl", gin.H{})})r.POST("/number/", func(c *gin.Context) {textareaContent := c.PostForm("textarea")exponent := &ExponentData{Check: 6.67428e-11,Set:   0,}dataContext := ast.NewDataContext()dataContext.Add("ExponentData", exponent)lib := ast.NewKnowledgeLibrary()rb := builder.NewRuleBuilder(lib)rb.BuildRuleFromResource("TestExponent", "1.0.0", pkg.NewBytesResource([]byte(textareaContent)))eng1 := &engine.GruleEngine{MaxCycle: 5}kb, _ := lib.NewKnowledgeBaseInstance("TestExponent", "1.0.0")eng1.Execute(dataContext, kb)c.JSON(http.StatusOK, gin.H{"textareaContent": exponent.Set,})})r.Run()
}

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32串口接收与发送(关于为什么接收不需要中断而发生需要以及HAL_UART_Transmit和HAL_UART_Transmit_IT的区别)

一、HAL_UART_Transmit和HAL_UART_Transmit_IT的区别 1. HAL_UART_Transmit_IT&#xff08;非阻塞模式&#xff09;&#xff1a; HAL_UART_Transmit_IT 是非阻塞的传输函数&#xff0c;也就是说&#xff0c;当你调用 HAL_UART_Transmit_IT 时&#xff0c;它不会等到数据完全发…

使用R语言优雅的获取任意区域的POI,道路,河流等数据

POI是“Polnt of Information”的缩写&#xff0c;中文可以翻译为“信息点”。是地图上任何非地理意义的有意义的点&#xff0c;如商店&#xff0c;酒吧&#xff0c;加油站&#xff0c;医院&#xff0c;车站等。POI&#xff0c;道路网&#xff0c;河流等是我们日常研究中经常需…

七、docker registry

七、docker registry 7.1 了解Docker Registry 7.1.1 介绍 registry 用于保存docker 镜像&#xff0c;包括镜像的层次结构和元数据。启动容器时&#xff0c;docker daemon会试图从本地获取相关的镜像&#xff1b;本地镜像不存在时&#xff0c;其将从registry中下载该镜像并保…

目标跟踪算法:SORT、卡尔曼滤波、匈牙利算法

目录 1 目标检测 2 卡尔曼滤波 3《从放弃到精通&#xff01;卡尔曼滤波从理论到实践》视频简单学习笔记 3.1 入门 3.2 进阶 3.2.1 状态空间表达式 3.2.2 高斯分布 3.3 放弃 3.4 精通 4 匈牙利算法 5 《【运筹学】-指派问题&#xff08;匈牙利算法&#xff09;》视…

OpenCV-图像阈值

简单阈值法 此方法是直截了当的。如果像素值大于阈值&#xff0c;则会被赋为一个值&#xff08;可能为白色&#xff09;&#xff0c;否则会赋为另一个值&#xff08;可能为黑色&#xff09;。使用的函数是 cv.threshold。第一个参数是源图像&#xff0c;它应该是灰度图像。第二…

【HarmonyOS NEXT】实现Tabs组件的TabBar从左到右依次排列

一、背景 系统提供的Tabs目前只能居中展示&#xff0c;暂不支持居左显示&#xff0c;现有的需求是需要Tabs从左往右排列显示&#xff0c;考虑通过Scroll和Row组件来实现 二、实现思路 通过Scroll和Row组件用来实现一个页签&#xff0c;在onclick事件中通过修改索引值和Tabs组…

16-03、JVM系列之:内存与垃圾回收篇(三)

JVM系列之&#xff1a;内存与垃圾回收篇(三) ##本篇内容概述&#xff1a; 1、执行引擎 2、StringTable 3、垃圾回收一、执行引擎 ##一、执行引擎概述 如果想让一个java程序运行起来&#xff0c;执行引擎的任务就是将字节码指令解释/编译为对应平台上的本地机器指令才可以。 简…

FPGA工作原理、架构及底层资源

FPGA工作原理、架构及底层资源 文章目录 FPGA工作原理、架构及底层资源前言一、FPGA工作原理二、FPGA架构及底层资源 1.FPGA架构2.FPGA底层资源 2.1可编程输入/输出单元简称&#xff08;IOB&#xff09;2.2可配置逻辑块2.3丰富的布线资源2.4数字时钟管理模块(DCM)2.5嵌入式块 …

【JVM】JVM基础教程(一)

目录 初识JVM JVM是什么&#xff1f; JVM的功能 解释、即时编译和运行 内存管理 常见的JVM JVM虚拟机规范 HotSpot的发展历程 JVM的组成 字节码文件详解 应用场景 以正确姿势打开字节码文件 ​编辑字节码文件的组成 基本信息 Magic魔数 主副版本号 常量池 接口…

无监督学习笔记 - A Cookbook of Self-Supervised Learning

无监督学习笔记 参考资料&#xff1a; 无监督学习Cookbook 几乎总结了所有的自监督学习方法,阅读过程中&#xff0c;根据参考文献索&#xff0c;进一步深入阅读每个方法具体得细节&#xff0c;掌握该论文&#xff0c;基本上就掌握了所有自监督学习的方法与基础。 统计学习方法…

Trimble X9三维激光扫描仪高效应对化工厂复杂管道扫描测绘挑战【沪敖3D】

化工安全关系到国计民生&#xff0c;近年来随着化工厂数字化改革不断推进&#xff0c;数字工厂逐步成为工厂安全管理的重要手段。而化工管道作为工厂设施的重要组成部分&#xff0c;由于其数量多、种类繁杂&#xff0c;一直是企业管理的重点和难点。 传统的化工管廊往往缺乏详…

synchronized的特性

1.互斥 对于synchronized修饰的方法及代码块不同线程想同时进行访问就会互斥。 就比如synchronized修饰代码块时&#xff0c;一个线程进入该代码块就会进行“加锁”。 退出代码块时会进行“解锁”。 当其他线程想要访问被加锁的代码块时&#xff0c;就会阻塞等待。 阻塞等待…

【vue3 for beginner】Pinia基本用法:存储user的信息

&#x1f308;Don’t worry , just coding! 内耗与overthinking只会削弱你的精力&#xff0c;虚度你的光阴&#xff0c;每天迈出一小步&#xff0c;回头时发现已经走了很远。 &#x1f4d7;概念 Pinia 简介 Pinia 是一个用于 Vue.js 应用的状态管理库&#xff0c;是 Vuex 的…

动态规划(二) ---斐波那契型深度解析

一、使用最小花费爬楼梯 题目链接&#xff1a;746. 使用最小花费爬楼梯 - 力扣&#xff08;LeetCode&#xff09; 题目&#xff1a;给你一个整数数组 cost &#xff0c;其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用&#xff0c;即可选择向上爬一…

记录一下,解决js内存溢出npm ERR! code ELIFECYCLEnpm ERR! errno 134 以及 errno 9009

项目是个老项目&#xff0c;依赖包也比较大&#xff0c;咱就按正常流程走一遍来详细解决这个问题&#xff0c;先看一下node版本&#xff0c;我用的是nvm管理的&#xff0c;详细可以看我的其他文章 友情提醒&#xff1a;如果项目比较老&#xff0c;包又大&#xff0c;又有一些需…

Luma 视频生成 API 对接说明

Luma 视频生成 API 对接说明 随着 AI 的应用变广&#xff0c;各类 AI 程序已逐渐普及。AI 已逐渐深入到人们的工作生活方方面面。而 AI 涉及的行业也越来越多&#xff0c;从最初的写作&#xff0c;到医疗教育&#xff0c;再到现在的视频。 Luma 是一个专业高质量的视频生成平…

三维扫描检测在汽车制造中的应用

三维扫描&#xff0c;通过先进三维扫描技术获取产品和物体的形面三维数据&#xff0c;建立实物的三维图档&#xff0c;满足各种实物3D模型数据获取、三维数字化展示、3D多媒体开发、三维数字化存档、逆向设计、产品开发、直接3D打印制造或辅助加工制造等一系列的应用。 三维扫描…

应用案例 | 船舶海洋: 水下无人航行器数字样机功能模型构建

水下无人航行器数字样机功能模型构建 一、项目背景 为响应水下装备系统研制数字化转型及装备系统数字样机建设的需要&#xff0c;以某型号水下无人航行器&#xff08;Underwater Unmanned Vehicle&#xff0c;UUV&#xff09;为例&#xff0c;构建UUV数字样机1.0功能模型。针对…

【unity小技巧】分享vscode如何开启unity断点调试模式,并进行unity断点调试(2024年最新的方法,实测有效)

文章目录 前言一、前置条件1、已安装Visual Studio Code&#xff0c;并且unity首选项>外部工具>外部脚本编辑器选择为Visual Studio Code [版本号]&#xff0c;2、在Visual Studio Code扩展中搜索Unity&#xff0c;并安装3、同时注意这个插件下面的描述&#xff0c;需要根…

P4645 [COCI2006-2007#3] BICIKLI(Tarjan+topsort求到某点的方案数)

P4645 [COCI2006-2007#3] BICIKLI - 洛谷 | 计算机科学教育新生态 思路&#xff1a; 我们考虑输出inf的情况&#xff0c;可以发现当从1出发到2经过的任意一个点处于一个环内时&#xff0c;路径条数是无穷多的。 有向图上从s到t的经过点&#xff0c;就是从s出发所能经过的所有…