app开发者平台在数字化时代的重要性与发展趋势解析
640
2022-10-30
Anet 是一个 .NET Core 通用框架,特点是简单易用
什么是 Anet
Anet 是一个 .NET Core 通用框架,特点是简单易用。它的定义是:
A .NET Core Common Lib, Framework and Boilerplate.
它的取名正是来自于这个定义的前面四个字母:ANET。Anet 的宗旨是使 .NET 项目开发变得简单和快速。它适用于面向现代化微服务开发 WebAPI、服务程序和网站。
为什么选择 Anet
很多传统的 .NET 开源框架模板(比如 ABP)都比较重,学习成本高,使用起来条条框框,比较麻烦。而 Anet 就简单易用得多,尤其适合面向微服务快速开发。
和其它模板框架一样,Anet 封装了一些实用工具类,集成了轻量 ORM 框架 Dapper。但 Anet 对 Dapper 做了一些改进,使得事务可以放在业务层独立处理,数据访问层则不需要关心事务。
Anet 的使用
下面贴一些 Anet 的使用示例,这些示例代码都可以在本仓库中找到。
使用前先安装 Nuget 包:
Install-Package Anet# 或者dotnet add package Anet
1. 查询操作
public class UserRepository : RepositoryBase
2. 新增操作
public class UserService{ private readonly UserRepository userRepository; public UserService(UserRepository userRepository) { this.userRepository = userRepository; } public async Task CreateUserAsync(UserRequestDto dto) { var newUser = new AnetUser { UserName = dto.UserName }; using (var tran = userRepository.BeginTransaction()) { await userRepository.InsertAsync(newUser); // Other business logic code. tran.Commit(); } } // ...(其它代码)}
3. 更新操作
public class UserService{ private readonly UserRepository userRepository; public UserService(UserRepository userRepository) { this.userRepository = userRepository; } public async Task UpdateUserAsync(long userId, UserRequestDto dto) { var user = await userRepository.FindAsync(userId); if (user == null) throw new NotFoundException(); using(var tran = userRepository.BeginTransaction()) { await userRepository.UpdateAsync( update: new { dto.UserName }, clause: new { Id = userId }); tran.Commit(); } } // ...(其它代码)}
4. 删除操作
public class UserService{ private readonly UserRepository userRepository; public UserService(UserRepository userRepository) { this.userRepository = userRepository; } public async Task DeleteUserAsync(long id) { var rows = await userRepository.DeleteAsync(id); if (rows == 0) throw new NotFoundException(); } // ...(其它代码)}
5. 定时任务
Anet 封装了一个 Scheduler,它可以满足大部分任务调度的需求。下面演示如何通过 Anet 来实现一个简单任务轮循程序,模拟一个发送消息的任务调度服务。这个示例也可以在 GitHub 仓库中找到源代码。
首先创建一个 Console(.NET Core)应用,需要先安装 Anet 的两个包:
Install-Package AnetInstall-Package Anet.Job
要添加一个定时任务就添加一个 IJob 接口的实现。这里添加一个 MessageJob 类,使它实现 IJob 接口,代码如下:
public class MessageJob : IJob{ private readonly ILogger
你要关心的就是 ExecuteAsync 方法,把你的执行代码放在此方法中。
然后只需在 Program.cs 的入口 Main 方法中进行初始化和配置即可,例如:
// 初始化应用App.Init((config, services) =>{ // 绑定配置 Settings = new SettingsModel(); config.Bind(Settings); // 注册服务 services.AddTransient
一个简单的消息发送服务就做好了,每隔指定秒数就会执行发送任务。此外,你还可以用 Scheduler.StartNewAt 方法进一步实现定时需求:
// 等同于 Scheduler.StartNew
运行后在控制台看到的效果是:
这个示例包含了记录日志,控制台上的信息都是临时的,你也可以查看运行目录下的 logs 文件夹中的日志文件。完整代码请在本仓库查看。
Anet 的目前状态
Anet 才刚起步,处在最小可用状态。它目前只是一个通用库,封装了一些常用的类(比如基于 Snowflake 算法的 Id 生成器、用户密码加密等),还算不上框架,还有很多事情要做。后面我也会写一些文章介绍这个项目。
但一个人的力量终究是有限的,特别希望大家能加入到这个项目中和我一起开发。
贡献者
Thanks goes to these wonderful people:
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~