Taurus.MVC 2.3 开源发布:增强属性Require验证功能,自带WebAPI文档生成功能
背景:
上周,把 Taurus.MVC 在 Linux (CentOS7) 上部署任务完成后。
也不知怎么的,忽然就想给框架集成一下WebAPI文档功能,所以就动手了。
以为一天能搞完,结果,好几天过去了。
本来还想集成自动化批量执行测试功能,不过想想还是放到下一版本实现吧。
感觉差不多了,就先和大伙分享一下:
Taurus.MVC Nuget 更新:
昨夜,Nuget的Package升级了一下,和源码版本做了下同步。
通常源码的版本都会比Nuget包的靠前一个小版本:
目前:Taurus.MVC 升级到:V2.3.0.0 (CYQ.Data 同步升级到:V5.7.9.7)
最近版本的更新内容(好多功能都是在 CYQ.Data 里升级,所以这里记录很少):
V2.2.3.5(2017-04-19) - V 2.3 (2019-03-22)
1:支持Controller分布在不同的dll中(Taurus.Controllers配置允许多个,逗号分隔)。
2:支持Controller二次继承(A:B B:Taurus.Core.Controller) 1:支持NetCore下的的部署(路径和大小写调整) 1、增加了CMS功能的标签替换功能。
2、增加参数验证属性(Require),验证是否必填写和正则格式。
3、增强了参数的类型转换。
4、增加WebAPI文档生成功能。
5、CYQ.Data同时升级到V5.7.9.7
下面介绍一下重点功能:
一、新增几个请求属性:HttpPut、HttpHead、HttpDelete
原来只有HttpGet和HttpPost。
所以方法只能指定其中的一个,如:
[HttpGet]
public void GetToken(string un, string pwd) { }
现在新增了几个,机制稍为调整了一下,还允许可以同时指定多个:
[HttpPost,HttpPut]
public void GetToken(string un, string pwd) { }
二、新增参数验证属性:Require
该属性参数有4个重载:
public RequireAttribute(string paraName)
public RequireAttribute(string paraName, bool isRequired, string regex)
public RequireAttribute(string paraName, bool isRequired, string regex, string outParaName)
public RequireAttribute(string paraName, bool isRequired, string regex, string emptyTip, string regexTip)
一共6种使用方法:
使用一:指定un参数不能为空。
[HttpGet,Require("un")]
public void GetToken(string un, string pwd) { }
使用二:指定un、pwd、random三个参数都不能为空,Require可以指定多个。
[HttpPost,Require("un,pwd"),Require("random")]
public void GetToken(string un, string pwd) { }
使用三:指定user实体内的UserName参数不能为空、para数组内第1个对象的Name参数不能为空。
[HttpPost,Require("user.UserName,para.0.Name"]
public void GetToken(Users user,List<ParaEntity> para) { }
使用四:指定un不能为空,同时满足手机号的正则验性规则。
[HttpGet,Require("un",true,RegexConst.Mobile)]
public void GetToken(string un, string pwd) { }
使用五:指定验证的提示文字。
[HttpGet,Require("un",true,RegexConst.Mobile,"用户名")]
public void GetToken(string un, string pwd) { }
PS说明:没指定提示文字前,默认的提示是:
{0} is required. {0} is invalid. 指定提示文字后,如果是中文,则提示变为中文: {0}不能为空。 {0}格式错误。
使用六:指定自定义提示文字。
[HttpGet,Require("un",true,RegexConst.Mobile,"手机号是不能为空的","国内的手机号是11位数字的。")]
public void GetToken(string un, string pwd) { }
三、增强功能的:CMS 标签语法
1、${xxx} 允许xxx指定从系统的请求参数中获取:
A:从Get的请求参数中获取; B:从Request[XXX]的请求参数中获取; C:从Request.Header的请求参数中获取。
示例:${host}是从系统变量中获取的。
<h1 id="labSpaceName">
<a href="#">Web API 文档 - Taurus.MVC</a></h1>
<h2 id="labSpaceIntro">Host:http://${host}</h2>
2、${xxx:这里可以设置默认值。} 允许指定参数无值时的默认值。
示例:/detail?d=
<h1 class="title_txt">
<a href="#">${d:这家伙很懒,没有写说明。}</a>
</h1>
四、默认实现的用户权限及Token机制
如果要开启此功能,你需要设置以下的配置:
<!--是否启动默认的Token机制,可配置的映射字段:TableName,UserName,Password(这三个必填写,后面可选),FullName,Status,PasswordExpireTime,Email,Mobile,RoleID,TokenExpireTime(这个是配置小时)-->
<add key="Taurus.Auth" value="{TableName:Users,TokenExpireTime:24}"/>
指定好表名,及其它字段名的映射之后,该功能就自动开启了。
如果其它字段名和系统默认的名称一样,则可以不用指定映射。
对于WebAPI,启用后,可以通过以下路径获取Token
/auto/gettoken
参数:
?uid=xxx&pwd=xxx
对于方法的验证,指定token属性即可
[Token]
public void GetXX() { }
另外提供了AuthHelper类,集成(MVC)下的注册、登陆、退出、获取用户信息等基础功能。
public static bool Login(string userName, string password, out string errMsg)
public static bool Reg(string userName, string password, out string msg)
public static void Logout()
public static bool ChangePassword(string password) 基础属性:
public static bool TokenIsValid
public static string UserID
public static string UserName
public static string FullName
public static string Token
五、WebAPI文档生成功能
其实这个才是重点,上面的功能,都是在弄这个的时候,顺带完成的。
只需要配置:
<!--是否启动创建API文档,访问路径为:/doc-->
<add key="Taurus.IsStartDoc" value="true"/>
然后访问:/doc 路径,就可以看到WebAPI文档了。
示例地址:http://taurus.cyqdata.com/doc
对于控制器,项目属性里需要勾选输出Xml文档选项:
文档的默认界面(找皮肤好辛苦,最后找了秋色的博客皮肤改的)
方法详情页面:
如果要调整样式,可以看(如果是引用的Nuget,你目前仍需要从框架开源的源码处把Doc目录的Copy过去,后续版本会把这个打包进dll,动态解压):
总结:
1、Taurus.MVC 是轻量级的 mvc 框架,真正意义上的前后端分离,没有后端语法入侵。
2、学习成本比 ASP.NET MVC 低很多,性能高,易掌控,支持大并发。
3、同一套代码,一套机制,可以走在Win和Linux中,不用搞个.NET Core还部署在window这么尴尬。
4、回归Http本质的框架,你才能以不变应万变,不用陷入不断变化的框架的无限深坑里。
开源地址:https://github.com/cyq1162/Taurus.MVC
Taurus.MVC 2.3 开源发布:增强属性Require验证功能,自带WebAPI文档生成功能的更多相关文章
- GJM : Taurus.MVC 2.0 开源发布:WebAPI开发教程 [转载]
Taurus.MVC 2.0 开源发布:WebAPI开发教程 转载自http://www.cnblogs.com/cyq1162/p/6069020.html 因是新手 粘贴时有一个版权问题 本文原 ...
- Taurus.MVC 2.3.2 :WebAPI 文档集成测试功能及附加<%# JS执行功能语法 %>
前言: 前些天有网友提到了那个界面丑陋的SwaggerUI,让我想起了多年前实现的WebAPI文档未完成的功能点,于是,动手了,便有了本文的内容. 开源地址:https://github.com/cy ...
- Taurus.MVC 2.3.4 :WebAPI 文档集成测试功能升级:WebAPI批量自动化测试功能。
前言: 最近升级了一下Taurus.MVC,现在最新版本是:Taurus.MVC 2.3.4,源码版本和nuget同步. 下面分三个步骤介绍下新版本的WebAPI批量自动化测试功能. 1.启用WebA ...
- Taurus.MVC 2.2 开源发布:WebAPI 功能增强(请求跨域及Json转换)
背景: 1:有用户反馈了关于跨域请求的问题. 2:有用户反馈了参数获取的问题. 3:JsonHelper的增强. 在综合上面的条件下,有了2.2版本的更新,也因此写了此文. 开源地址: https:/ ...
- Taurus.MVC 2.0 开源发布:WebAPI开发教程
背景: 有用户反映,Tausus.MVC 能写WebAPI么? 能! 教程呢? 嗯,木有! 好吧,刚好2.0出来,就带上WEBAPI教程了! 开源地址: https://github.com/cyq1 ...
- Taurus.MVC WebAPI 入门开发教程8:WebAPI文档与自动化测试。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- .NET平台开源项目速览(4).NET文档生成工具ADB及使用
很久以前就使用ADB这个工具来生成项目的帮助文档.功能强大,在学习一些开源项目的过程中,官方没有提供CHM帮助文档,所以为了快速的了解项目结构和注释.就生成文档来自己看,非常好用.这也是一个学习方法吧 ...
- 再见丑陋的 SwaggerUI,这款开源的API文档生成神器界面更炫酷,逼格更高!
一般在使用 Spring Boot 开发前后端分离项目的时候,都会用到 Swagger.Swagger 是一个规范和完整的框架,用于生成.描述.调试和可视化 RESTful 风格的 Web API 服 ...
- 微软开源全新的文档生成工具DocFX
微软放弃Sandcastle有些年头了,微软最近开源了全新的文档生成工具DocFX,目前支持C#和VB,类似JSDoc或Sphinx,可以从源代码中提取注释生成文档之外,而且还有语法支持你加入其他的文 ...
随机推荐
- 《Linux/Unix系统编程手册》 时间子系统
Linux下操作系统编程有两本经典APUE即<Advanced Programming in the UNIX Environment>和TLPI<The Linux Program ...
- JavaScript Math 对象的常用方法
JavaScript Math 对象 Math 对象 Math 对象用于执行数学任务. 使用 Math 的属性和方法的语法: var pi_value=Math.PI; var sqrt_value= ...
- spring boot整合shiro
安全框架Shiro和Spring Security比较,本文主要围绕Shiro进行学习 一 Shiro 是一个强大而灵活的开源安全框架,能够清晰的处理认证 授权 管理会话以及,密码加密 01 .认证与 ...
- SQL 中如何删除重复(每列数据都重复)的记录,只保留一行?
如果数据表没有做好约束,那么数据库中难免会遇到数据重复的情况.今天就遇到这么个看起来简单却又费神的问题---如何去重. ------期间感谢微信公众号"有关SQL"的博主大牛提供的 ...
- create react app 项目部署在Spring(Tomcat)项目中
网上看了许多,大多数都是nginx做成静态项目,但是这样局限性太多,与Web项目相比许多服务端想做的验证都很麻烦,于是开始了艰难的探索之路,终于在不经意间试出来了,一把辛酸... 正常的打包就不说了. ...
- eclipse 内存优化
eclipse.ini配置如下: -Dfile.encoding=UTF-8-Xms512m-Xmx512m-Xmn170m-Xverify:none 注意-Xmn是-Xmx的三分之一关系 可以根据自 ...
- Python多版本管理-pyenv
经常遇到这样的情况: 系统自带的Python是2.x,自己需要Python 3.x,此时需要在系统中安装多个Python,但又不能影响系统自带的Python,即需要实现Python的多版本共存,pye ...
- Random在高并发下的缺陷以及JUC对其的优化
Random可以说是每个开发都知道,而且都用的很6的类,如果你说,你没有用过Random,也不知道Random是什么鬼,那么你也不会来到这个技术类型的社区,也看不到我的博客了.但并不是每个人都知道Ra ...
- Netty实现高性能的HTTP服务器
浅谈HTTP Method 要通过netty实现HTTP服务器(或者客户端),首先你要了解HTTP协议. HTTP在客户端 - 服务器计算模型中用作请求 - 响应协议. 例如,web浏览器可以是客户端 ...
- 浅析JavaScript解析赋值、浅拷贝和深拷贝的区别
文章首发于sau交流学习社区 一.赋值(Copy) 赋值是将某一数值或对象赋给某个变量的过程,分为: 1.基本数据类型:赋值,赋值之后两个变量互不影响 2.引用数据类型:赋**址**,两个变量具有相同 ...