本项目是 CAP 项目的 Java 实现超集,基于
整洁架构、
Mediator中介者模式、
Outbox发件箱模式、
CQS命令查询分离模式
以及UoW模式
等理念,cap4j期望解决如何基于领域模型 方便地 实现领域驱动设计的问题。
如果对以上架构理念有充分了解,那么cap4j的使用将会非常顺手。另一方面,通过cap4j来构建你的服务,你将学会一种实现领域驱动设计的完整落地方法。
为了方便框架应用与理解,cap4j配备了代码生成插件cap4j-ddd-codegen,基于该插件,我们可以非常方便地生成初始项目脚手架、实体映射代码和基于JPA的聚合仓储代码。
定好maven坐标三要素:
groupId、artifactId、version
在pom.xml中添加
cap4j-ddd-codegen-maven-plugin插件。
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>io.github.netcorepal</groupId>
    <artifactId>cap4j-ddd-mvc-example</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>jar</packaging>
    <name>cap4j-ddd-mvc-example</name>
    <dependencies>
        <dependency>
            <groupId>io.github.netcorepal</groupId>
            <artifactId>cap4j-ddd-codegen-maven-plugin</artifactId>
            <version>1.0.0-alpha-4</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>io.github.netcorepal</groupId>
                <artifactId>cap4j-ddd-codegen-maven-plugin</artifactId>
                <version>1.0.0-alpha-4</version>
                <configuration>
                    <basePackage>org.netcorepal.cap4j.ddd.example</basePackage>
                    <archTemplate>https://raw.githubusercontent.com/netcorepal/cap4j/main/cap4j-ddd-codegen-template-nested.json</archTemplate>
                    <multiModule>false</multiModule>
                    <moduleNameSuffix4Adapter>-adapter</moduleNameSuffix4Adapter>
                    <moduleNameSuffix4Domain>-domain</moduleNameSuffix4Domain>
                    <moduleNameSuffix4Application>-application</moduleNameSuffix4Application>
                    <connectionString>
                        <![CDATA[jdbc:mysql://127.0.0.1:3306/test?serverTimezone=Asia%2FShanghai&useSSL=false&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull]]>
                    </connectionString>
                    <user>root</user>
                    <pwd>123456</pwd>
                    <schema>test</schema>
                    <table></table>
                    <ignoreTable>\_\_%</ignoreTable>
                    <ignoreFields>db_%</ignoreFields>
                    <versionField>version</versionField>
                    <deletedField>db_deleted</deletedField>
                    <readonlyFields>db_created_at,db_updated_at</readonlyFields>
                    <entityBaseClass></entityBaseClass>
                    <entityClassExtraImports>static org.netcorepal.cap4j.ddd.domain.event.DomainEventSupervisorSupport.events</entityClassExtraImports>
                    <entitySchemaOutputMode>ref</entitySchemaOutputMode>
                    <entitySchemaOutputPackage>domain._share.meta</entitySchemaOutputPackage>
                    <fetchType>EAGER</fetchType>
                    <idGenerator>org.netcorepal.cap4j.ddd.domain.distributed.SnowflakeIdentifierGenerator</idGenerator>
                    <enumValueField>code</enumValueField>
                    <enumNameField>name</enumNameField>
                    <enumUnmatchedThrowException>true</enumUnmatchedThrowException>
                    <datePackage4Java>java.time</datePackage4Java>
                    <typeRemapping></typeRemapping>
                    <generateDefault>false</generateDefault>
                    <generateDbType>true</generateDbType>
                    <generateSchema>true</generateSchema>
                    <generateParent>false</generateParent>
                    <generateAggregate>true</generateAggregate>
                    <repositorySupportQuerydsl>true</repositorySupportQuerydsl>
                    <aggregateRootAnnotation></aggregateRootAnnotation>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>通常,cap4j-ddd-codegen插件只需要我们根据团队或项目的实际情况调整以下配置项即可使用。
<basePackage>项目基础包名,一般为com.yourcompany.project</basePackage>
<connectionString>数据库链接</connectionString>
<user>数据库账号</user>
<pwd>数据库密码</pwd>
<schema>数据库名称</schema>
插件配置项
archTemplate是gen-arch命令生成脚手架目录与项目基础代码的配置文件地址。开放自定义方便大家根据自己团队需求进行定制化。格式说明后续补充,不过格式很简单,按示例中的配置自己应该就能看懂并应用。有兴趣更详细了解的参考源码GenArchMojo
mvn cap4j-ddd-codegen:gen-arch如果没有意外,cap4j-ddd-codegen插件将根据配置文件cap4j-ddd-codegen-template.json完成项目结构初始化!
基于基础包路径配置,
<basePackage>org.netcorepal.cap4j.ddd.example</basePackage> cap4j-ddd-codegen插件在maven项目源码目录src/main/java/org/netcorepal/cap4j/ddd/example下将会生成4个package。
_share公共代码adapter适配层(Interface Adapter)application应用层(Application Business Rules)domain领域层(Enterpprise Business Rules)
以上代码分层完全遵循整洁架构对于代码分层组织的观点。
更详细分层结构介绍,移步项目分层结构介绍。
