goft
  • gin脚手架使用文档
  • 所需环境
  • 建议的目录结构
  • 配置
  • 最简单的启动代码
  • 出错跟踪
  • 自定义错误展示
  • 覆盖系统内置异常处理
  • 路由
    • 路由写在一个文件里
    • 常规设置
  • 控制器
    • 控制器形式
    • 控制器方法
    • 控制器方法不想返回值
    • 输出JSON
    • 获取请求对象
  • 全局中间件
    • 基本定义
    • 注册中间件
    • 示例1:判断token参数
    • 示例2:修改响应内容
    • 跨域中间件
  • 路由级中间件
    • 基本定义
    • 示例:参数验证和业务分离
  • 依赖注入
    • 基本定义
    • 注册依赖配置
    • 基本使用
    • 注入Gorm和XOrm
  • 精简版领域驱动
    • 基本说明和概念
    • 基本分层
    • 领域层
    • 领域层之实体
    • 领域层之值对象
    • 领域层之仓储
    • 领域层之聚合
    • 领域服务层
    • 应用层(application)
    • 应用层之DTO
    • DTO和实体映射
    • 应用层之应用服务层
    • 代码落地
由 GitBook 提供支持
在本页

这有帮助吗?

  1. 精简版领域驱动

应用层之应用服务层

上一页DTO和实体映射下一页代码落地

最后更新于4年前

这有帮助吗?

视频地址:

主要职责

1、向上:给interface层调用,提供各种功能

2、向下:调用领域层

很薄的一层,没有业务逻辑, 不应该存在if/else这种判断

代码示例:

type UserService struct {
      AssUserReq *assembler.UserReq
      AssUserRsp *assembler.UserRSP
      UserRepo repos.IUserRepo `inject:"-"`
      UserLogRepo repos.IUserLogRepo `inject:"-"`
}
func(this *UserService) GetSimpleUserInfo(req *dto.SimpleUserReq) *dto.SimpleUserInfo  {
      userModel:=this.AssUserReq.D2M_UserModel(req) //DTO对象转为实体
   
      member:=aggregates.NewMember(userModel,this.UserRepo,this.UserLogRepo)

      return this.AssUserRsp.M2D_SimpleUserInfo(member.QueryUser().User)

}
应用层:应用服务层的基本用法、超简案例演示