ABP+AdminLTE+Bootstrap Table权限管理系统第六节--abp控制器扩展及json封装

ABP+AdminLTE+Bootstrap Table权限管理系统一期
Github:https://github.com/Jimmey-Jiang/ABP-ASP.NET-Boilerplate-Project-CMS
前往博客园总目录:ABP+AdminLTE+Bootstrap Table权限管理系统一期

 一,控制器AbpController

   说完了Swagger ui 我们再来说一下abp对控制器的处理和json的封装.
   首先我们定义一个控制器,在新增控制器的时候,控制器会自动继承自AbpController,AbpControllerASP.NET MVC Controllers进行了集成.
并且拥有了以前强大的功能.  
 
     
 

    我们看到AbpController封装了很多方法,集成了很多东西,继承自System.Web.Mvc.Controller,abp包含一下功能
      1. 本地化
       2. 异常处理
      3. 对返回的JsonResult进行包装
      4. 审计日志
      5. 权限认证([AbpMvcAuthorize]特性)
      6. 工作单元(默认未开启,通过添加[UnitOfWork]开启)
      7. 错误机制的响应.

  AbpController定义了L方法简化本地化。

     
 本地化:你需要设置LocalizationSourceName才能使用**L方法。你可以在控制器基类SimpleTaskSystemControllerBase里面设置,就可以在各个控制器里面调用了.这样保证一些公共东西的代码复用性.当然L方法也可以在视图地面调用,这样在控制js版本等作用还是非常方便的.
    同时在控制器里面也可以注入一些其他公共的东西,如你也可以使用预注如AbpSession,EventBus,PermissionManager,PermissionChecker,SettingManager,FeatureManager,FeatureChecker,LocalizationManager,Logger,CurrentUnitOfWork基础属性等。
 
异常处理和结果包装:
所有的异常都是自动处理、记录并给客户端返回一个合适的响应.如果返回类型时JsonResult(或异步actions的Task<JsonResult>), ABP会默认包装action的结果。你可以通过为controllers或actions或从全局的启动配置使用WrapResult和DontWrapResult**特性来改变异常处理和包装。
审计日志:
AbpMvcAuditFilter用来集成审计日志系统。它默认记录所有actions的所有请求(如果审计没有被禁用)。你可以为actions和controllers使用AuditedDisableAuditing**特性来控制审计日志。
  验证:
AbpMvcValidationFilter自动检查ModelState.IsValid,如果action没通过验证则阻止其执行.
 授权:
你可以给controllers或actions使用AbpMvcAutorize特性来禁止未授权的用户使用你的controllers和actions。如下:

  
  
工作单元:
AbpMvcUowFilter**用来集成工作单元系统。它自动在action执行前可以使一个工作单元并在action结束后完成工作单元(如果没有异常抛出)。你可以使用UnitOfWork特性来控制action的UOW的行为。你也可以使用启动配置来更改所有actions的默认工作单元特性。
 模型绑定器:
 AbpMvcDateTimeBinder用来格式

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值