百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

如何在 40 秒内创建一个.Net Core Web API?

liuian 2025-02-20 16:45 23 浏览

为什么我们需要自己写代码?为什么计算机无法自动为我们生成这些代码呢?很显然,我们应该可以利用这些共同点,从一个给定的数据库自动化构建系统——这就是“我”创建Magic的初衷。

作者 | Thomas Hansen

译者 | 弯月,责编 | 郭芮

出品 | CSDN(ID:CSDNnews)

以下为译文:

作为一名C#开发人员,我坦白虽然我很喜欢C#,喜欢它的强类型、编译器、泛型、LINQ等等,但有时我也会嫉妒PHP和Python开发人员。Python和PHP在本质上更为动态,而且还可以实现C#几乎不可能完成的任务。大约在一年前,我的一位朋友向我展示了Django,我羞愧地承认.NET没有类似的功能。因此,我决定通过自己的努力创造奇迹,于是我创建了Magic。

CRUD、HTTP和SQL

在软件开发人员眼中,很多问题都可以归结为将JSON从客户端传输到后端。这个问题是如此普遍,所以我们总结出了一个缩写CRUD:创建(Create)、读取(Read)、更新(Update)和删除(Delete)。HTTP请求的类型有post、put、delete和get。SQL拥有insert、update、delete和select。可以说,所有这些操作都基于相同的概念,即CRUD。

因此,很显然我们应该可以利用这些共同点,从一个给定的数据库自动化构建系统。为什么我们需要自己写代码?为什么计算机无法自动为我们生成这些代码呢?

Magic

我创建的Magic能够从数据库架构中读取元信息,并利用这些信息来创建HTTP REST端点的脚手架代码,并对数据库中的每个CRUD操作提供封装。我们的目的是在控制器端点和数据库之间建立一层薄薄的“ Hyperlambda”,你只需轻轻点击一个按钮,就可以创建和公开数据库上所有的CRUD操作。

Hyperlambda是一种动态编程语言,也是一种DSL,它不需要编译,但是它能够快速处理这些类型的操作,因为每个Hyperlambda关键字只不过是C#中的类的封装。

因此,我们很容易创建Hyperlambda“关键字”,并通过这些关键字对客户端进行身份验证和授权、将记录插入到我们的数据库中、读取记录等,所有的操作只需几行代码即可实现。它的语法非常容易理解,而且计算机也很容易理解,这样用户可以通过对关键字的排列来创建代码的脚手架。

演示过程:
https://youtu.be/ncH4QRpKvx0

在这段视频中,Magic首先会读取数据库中每个表的数据库架构。然后,创建四个Hyperlambda文件,每个CRUD操作一个文件。这些Hyperlambda文件的路径取决于数据库对象的名称,因此,假设数据库名为“ foo”,表名为“ bar”,那么HTTP GET的路径为“
/files/magic/foo/bar.get.hl”,指向包含Hyperlambda文件的磁盘物理路径。

接下来,我通过一个动态路由控制器接受“/magic”下面的“任何” URL。该路由负责解析我的Hyperlambda文件,并根据给出的URL,执行相应的HTTP动词。

那么,现在我可以在运行时自动创建Hyperlambda代码了,这些代码可以封装现有的数据库,却不会中断应用程序的正常使用。此外,我还通过一个路由机制将HTTP请求动态路由到服务器中的文件和文件夹(之前创建的文件)。

对于小规模的简单应用程序来说,整个后端的Web API就这么多,下一步你可以立即开始创建Angular或React的前端了。而复杂的应用程序可能需要上面没有提供的其他功能,但是至少你的后端已有了基本的雏形,接下来你可以随意编写C#代码和.Net控制器。

Magic基本上就相当于“面向.Net Core和C# 的Django”。即使你的应用根本不需要CRUD,但如果你使用MySQL或微软的SQL Server,它仍然可以作为一个出色数据库管理系统,帮助你在生产和开发环境中管理数据库。从这个角度来说,它相当于“面向.Net Core的PHPMyAdmin”。

功能简介

Magic可以自动处理身份验证和授权。例如,可以为每个HTTP端点分配一个“角色”列表(以逗号分隔),客户端必须经过身份验证才能执行端点的代码。这个实现采用了JWT令牌,它会在调用“身份验证” HTTP端点时生成并返回给客户端。

由于Magic本身可以兼容所有的数据库,因此仍需要在这些方面进行一些手工操作。但实际上只是复制/粘贴的工作,你可以根据需要在生产中进行。顺便说一句,有人可能对密码存储感兴趣,我在这里说明一下:密码的存储采用了BlowFish散列(“慢散列”),还支持独立的加盐算法。

你还可以通过Magic通知脚手架代码的生成过程,要求将各个端点上的HTTP请求写入日志。默认情况下,Magic使用log4net,但你可以创建自己的日志接口并替换,然后通过依赖注入提供给Magic。实际上,Magic中的所有内容都是基于IoC和依赖注入的。

另外,你可以声明希望它提供支持的CRUD操作。例如,某些数据库表可能是“只读”,在这种情况下你根本不需要删除或更新端点。你只需修改生成脚手架代码过程中的一个简单的复选框。

Magic超级快。首先,每个Hyperlambda文件的大小都很小——大约只有10-20行代码。因此,与执行和处理针对某些数据库的SQL命令的昂贵过程相比,解析和评估Hyperlambda文件几乎没有成本。

因此,这种“微小的Hyperlambda层”几乎没有额外的成本。此外,Hyperlambda的评估过程也已经优化到了极致。Hyperlambda本质上是百分百“异步”,这意味着它在评估Hyperlambda文件时也会使用C#和CLR的异步功能。因此,可以带来巨大的“吞吐量”,并提供了可扩展性功能,以方便应用到任何“纯” C#或.NET的应用程序中。如果你问我的看法,那么我会告诉你一行代码都不用写,难道不够伟大吗?

通过你自己的关键字扩展Hyperlambda就像创建一个简单的C#类一样容易。下面是一个真实的示例,我使用了自己的一个关键字[strings.starts-with],如果某个字符串以其他字符串开头则返回true。

namespace magic.lambda.strings
{
[Slot(Name = "strings.starts-with")]
public class StartsWith : ISlot
{
public void Signal(ISignaler signaler, Node input)
{
// Sanity checking.
if (input.Children.Count != 1)
throw new ApplicationException("[strings.starts-with] must be given exactly one argument that contains value to look for");
signaler.Signal("eval", input);
input.Value = input.GetEx
.StartsWith(input.Children.First.GetEx, StringComparison.InvariantCulture);
}
}
}

创建自己的关键字就像向类添加属性和接口一样简单,而且你还有一个新的“ Hyperlambda关键字”。这个功能为编程语言提供了一些极端的“DSL功能”。由此产生的Hyperlambda更方便人类的阅读和理解。

然而,你无需了解Hyperlambda即可使用Magic,因为你的计算机明白如何创建和维护Hyperlambda。因此,Hyperlambda与Magic的关系就相当于CLR代码与C#。

如下示例演示了一个Hyperlambda HTTP端点。请注意,由于Hyperlambda是我自己创建的,因此在DZone甚至在Visual Studio Code中都没有办法高亮显示Hyperlambda,据我所知,Hyperlambda在全球范围内只有不到5个用户。

但是,我有一个基于JavaScript的Hyperlambda编辑器,它是Magic不可或缺的部分,它可以在你的代码中高亮显示Hyperlambda语法,而且也可以自动补齐。

/*
* Declaration of arguments the endpoint can accept.
*/
.arguments
limit:long
offset:long
order:string
direction:string
id:long
name:string

/*
* Appending arguments in [slots.signal] below.
*/
add:x:./*/slots.signal/*/args
get-nodes:x:@.arguments/*

/*
* Invoking [slots.signal] with "magic.db.mysql.read".
*/
slots.signal:magic.db.mysql.read
database:magic_auth
table:roles
args
columns
id
name

/*
* Returning the results to caller.
* This will transform the result to JSON,
* and return to the client as the HTTP response.
*/
slots.return-nodes:x:@slots.signal/*

注意:Magic是一个全新的项目,可能包含一些bug。它还未能在GitHub上赢得一百万颗星,而且据我所知,目前没有任何纳斯达克上市公司在使用它。因此,如果你想对其进行评估,请耐心等待。我会全力以赴提高代码的质量,并且修改所有发现的bug。将来我会持续维护该项目,但有时可能会出现一些测试版中常见的问题。

你可以通过我的GitHub代码库(https://github.com/polterguy/magic)汇报bug或请求功能。即便你没有可以汇报的bug,我也希望你对该项目提出建议或给予鼓励。

总结

总的来说,Magic可以减轻你一半的工作量,让计算机来承担无聊的工作,而你则可以专注于有趣的工作。这不正是我们发明计算机的初衷吗?希望你能找到Magic带来的快乐。

有关Magic的详细信息如下:

  • 主页:
    https://polterguy.github.io/

  • GitHub项目网站:https://github.com/polterguy/magic

  • 支持系统:https://github.com/polterguy/magic/issues

原文:https://dzone.com
/articles/creating-a-net-core-web-api-in-40-seconds

本文为 CSDN 翻译,转载请注明来源出处。

【END】

相关推荐

总结下SpringData JPA 的常用语法

SpringDataJPA常用有两种写法,一个是用Jpa自带方法进行CRUD,适合简单查询场景、例如查询全部数据、根据某个字段查询,根据某字段排序等等。另一种是使用注解方式,@Query、@Modi...

解决JPA在多线程中事务无法生效的问题

在使用SpringBoot2.x和JPA的过程中,如果在多线程环境下发现查询方法(如@Query或findAll)以及事务(如@Transactional)无法生效,通常是由于S...

PostgreSQL系列(一):数据类型和基本类型转换

自从厂子里出来后,数据库的主力就从Oracle变成MySQL了。有一说一哈,贵确实是有贵的道理,不是开源能比的。后面的工作里面基本上就是主MySQL,辅MongoDB、ES等NoSQL。最近想写一点跟...

基于MCP实现text2sql

目的:基于MCP实现text2sql能力参考:https://blog.csdn.net/hacker_Lees/article/details/146426392服务端#选用开源的MySQLMCP...

ORACLE 错误代码及解决办法

ORA-00001:违反唯一约束条件(.)错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。ORA-00017:请求会话以设置跟踪事件ORA-00018:超出最大会话数ORA-00...

从 SQLite 到 DuckDB:查询快 5 倍,存储减少 80%

作者丨Trace译者丨明知山策划丨李冬梅Trace从一开始就使用SQLite将所有数据存储在用户设备上。这是一个非常不错的选择——SQLite高度可靠,并且多种编程语言都提供了广泛支持...

010:通过 MCP PostgreSQL 安全访问数据

项目简介提供对PostgreSQL数据库的只读访问功能。该服务器允许大型语言模型(LLMs)检查数据库的模式结构,并执行只读查询操作。核心功能提供对PostgreSQL数据库的只读访问允许L...

发现了一个好用且免费的SQL数据库工具(DBeaver)

缘起最近Ai不是大火么,想着自己也弄一些开源的框架来捣腾一下。手上用着Mac,但Mac都没有显卡的,对于学习Ai训练模型不方便,所以最近新购入了一台4090的拯救者,打算用来好好学习一下Ai(呸,以上...

微软发布.NET 10首个预览版:JIT编译器再进化、跨平台开发更流畅

IT之家2月26日消息,微软.NET团队昨日(2月25日)发布博文,宣布推出.NET10首个预览版更新,重点改进.NETRuntime、SDK、libraries、C#、AS...

数据库管理工具Navicat Premium最新版发布啦

管理多个数据库要么需要使用多个客户端应用程序,要么找到一个可以容纳你使用的所有数据库的应用程序。其中一个工具是NavicatPremium。它不仅支持大多数主要的数据库管理系统(DBMS),而且它...

50+AI新品齐发,微软Build放大招:拥抱Agent胜算几何?

北京时间5月20日凌晨,如果你打开微软Build2025开发者大会的直播,最先吸引你的可能不是一场原本属于AI和开发者的技术盛会,而是开场不久后的尴尬一幕:一边是几位微软员工在台下大...

揭秘:一条SQL语句的执行过程是怎么样的?

数据库系统能够接受SQL语句,并返回数据查询的结果,或者对数据库中的数据进行修改,可以说几乎每个程序员都使用过它。而MySQL又是目前使用最广泛的数据库。所以,解析一下MySQL编译并执行...

各家sql工具,都闹过哪些乐子?

相信这些sql工具,大家都不陌生吧,它们在业内绝对算得上第一梯队的产品了,但是你知道,他们都闹过什么乐子吗?首先登场的是Navicat,这款强大的数据库管理工具,曾经让一位程序员朋友“火”了一把。Na...

详解PG数据库管理工具--pgadmin工具、安装部署及相关功能

概述今天主要介绍一下PG数据库管理工具--pgadmin,一起来看看吧~一、介绍pgAdmin4是一款为PostgreSQL设计的可靠和全面的数据库设计和管理软件,它允许连接到特定的数据库,创建表和...

Enpass for Mac(跨平台密码管理软件)

还在寻找密码管理软件吗?密码管理软件有很多,但是综合素质相当优秀且完全免费的密码管理软件却并不常见,EnpassMac版是一款免费跨平台密码管理软件,可以通过这款软件高效安全的保护密码文件,而且可以...