Mario是一个基于.NETCore的简单快速开发框架

Posted deeround

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mario是一个基于.NETCore的简单快速开发框架相关的知识,希望对你有一定的参考价值。

Mario .NET Core简单快速开发框架

Mario是一个基于.NET Core的简单快速开发框架

GitHub:https://github.com/deeround/Mario

技术特点

基于.NET Core 2.2 集成常用三方组件
AutoMapper
FluentValidation
Newtonsoft.Json
NLog
Swashbuckle

支持jwt认证、支持API资源权限验证
支持swagger中API分组显示
所有服务自动注入,无需手动注入

......

使用场景

中小型项目有时候并不需要各种复杂的驱动设计,复杂的分层设计,只需简单业务逻辑开发。Mario框架就是为了简化我们开发,减少各种繁琐的配置注入,只需关注于业务逻辑开发本身。

框架结构

技术图片

项目 说明
Mario.Core 底层核心库
Mario.Data 数据封装库
Mario.Mvc WebApi封装库
Mario.Web WebApi业务库
WangSql 数据底层库

业务模块开发

简单模块

技术图片

当我们业务非常简单,我们连实体类都不写的应用场景,就是简单直接干,只用写API,直接在控制器写业务就行了。

分为以下几步即可完成:
1、模块相关配置

技术图片

  • 配置swagger信息,每个模块都是配置swagger信息(需要开启API分组功能)
  • 配置数据库信息,可以配置多个多种数据库(支持很多数据库的)
2、添加模块目录

技术图片

  • Test就是模块
  • TestControllers就是API,在控制器里面写业务逻辑就行了
  • TestApiModule.cs为模块启动初始化类,可以在里面写模块初始化逻辑
3、添加测试控制器

在TestControllers下添加Test控制器

     public class TestController : ApiController
    {
        /// <summary>
        /// 演示使用原始方法和扩展方法查询数据
        /// </summary>
        /// <returns></returns>
        [HttpGet()]
        public IList<Dictionary<string, object>> GetList()
        {
            return SqlMapper.Query<Dictionary<string, object>>("select * from T_SYS_USER", null).ToList(); //原始方法
            //return SqlMapper.ListSod("select * from T_SYS_USER"); //扩展方法
        }

        /// <summary>
        /// 分页查询
        /// </summary>
        /// <returns></returns>
        [HttpGet()]
        public PageData<StrObjDict> GetPage(string name)
        {
            string sql = "select * from T_SYS_USER where 1=1";
            StrObjDict sod = new StrObjDict();
            if (!string.IsNullOrEmpty(name))
            {
                sql += $" and USERNAME like '%$USERNAME$%'";
                sod.Add("USERNAME", name);
            }
            //排序设置
            sql += $" order by USERNAME desc";

            return SqlMapper.PageSod(sql, sod, 1, 20, out int total);
        }

        /// <summary>
        /// 定义好入参,但不定义出参格式
        /// 方便扩展入参,也可使用swagger直接测试,但是前端无法通过swagger查看接口出参格式,只有请求后才知道出参格式
        /// </summary>
        /// <param name="name"></param>
        /// <returns></returns>
        [HttpGet()]
        public IList<StrObjDict> GetByName(string name)
        {
            //return SqlMapper.ListSod("select * from T_SYS_USER where USERNAME=#USERNAME#", name); //写法1
            return SqlMapper.ListSod("select * from T_SYS_USER where USERNAME=#USERNAME#", new StrObjDict() { { "USERNAME", name } }); //写法1

        }

        /// <summary>
        /// 这个是上面方法另一种写法
        /// 这种方法不固定入参,可随时添加删除入参,但是无法使用swagger直接测试,可使用postman等其他接口工具测试
        /// 这种方法前端入参和出参都不知道格式,需要前后端提前约定好出入参
        /// </summary>
        /// <returns></returns>
        [HttpGet()]
        public IList<StrObjDict> GetByNameNoParam()
        {
            var param = ApiContext.GetRequestParam();
            string name = param.GetString("name");

            //return SqlMapper.ListSod("select * from T_SYS_USER where USERNAME like '%$USERNAME$%'", name); //写法1
            return SqlMapper.ListSod("select * from T_SYS_USER where USERNAME=#USERNAME#", new StrObjDict() { { "USERNAME", name } }); //写法1

        }

    }
4、使用swagger测试API

访问 http://localhost:4567/swagger/index.html

技术图片

复杂模块

包含dto和实体相互转换、实体验证、登录验证、加入service层等
主要用于展示框架更多功能,实际上框架还有更多特性供探索。

技术图片

具体代码请查看GitHub

GitHub & 说明

GitHub link https://github.com/deeround/Mario

Mario框架仅仅提供给大家学习使用,现在只有后端,暂无前端,后期可能考虑使用vue做个admin模板,目前还在完善中......

以上是关于Mario是一个基于.NETCore的简单快速开发框架的主要内容,如果未能解决你的问题,请参考以下文章

推荐一个前后端分离.NetCore+Angular快速开发框架

.NETCore 快速开发做一个简易商城

开源一个基于.netcore的企业级应用开发框架------FAP

基于.NetCore开发博客项目 StarBlog - 模型设计

基于.NetCore开发博客项目 StarBlog

基于.NetCore开发博客项目 StarBlog - 环境准备和创建项目