web层编码中action的处理比较麻烦,特别是代码量变大,多应用,多人维护等情况下特别困难。
如何摸索下维护简单,复用性强的代码方式很重要。
上次写了一篇文章:http://guoba6688-sina-com.iteye.com/blog/747756,简单的处理。
这几天和同事讨论,他们提出更优雅的方式,我试着写了下,希望大家指教。
解决目标:
1、action层代码简单
2、复杂逻辑维护简单,可复用。
思路:
1、action层将数据封装为DTO
2、调有DTOUtil,传入DTO,DTOUtil会找到配置好的对应handler来处理
3、在handler中调用workstep逐步处理,返回forwardResult
包结构:
1、core包 主要是框架类
2、biz.app 点评的处理逻辑
3、app.biz.client result解晰成forwardresult类,一般在action层
试验场景:
点评发布
主要代码:
biz.core 包
/**
*
* 描述 在handler上打注释,让dtoutil类通过dto找到对应的handler处理
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target( { ElementType.TYPE })
public @interface DTOHandlerAnnotation {
Class<? extends IDTO>[] queryFor() default {};
}
/**
*
* 描述 action 层传值接口,目前想不出什么样方法,暂做标识吧
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public interface IDTO {
}
/**
*
* 描述 具体的处理dto的类,如发布点评
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public interface IDTOHandler {
IResult execute(IDTO dto);
}
/**
*
* 描述 根据dto找到具体的handler处理
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public class DTOUtil implements InitializingBean{
private static Map<Class<? extends IDTO>,IDTOHandler> map = new HashMap<Class<? extends IDTO>,IDTOHandler>();
private List<IDTOHandler> dtoHandlers;
private void init() throws Exception{
for(IDTOHandler dtoHandler : dtoHandlers){
DTOHandlerAnnotation annotation
= dtoHandler.getClass().getAnnotation(DTOHandlerAnnotation.class);
if(annotation == null || annotation.queryFor() == null || annotation.queryFor().length == 0){
continue;
}
Class<? extends IDTO>[] dtoClaszs = annotation.queryFor();
for(Class<? extends IDTO> dtoClasz : dtoClaszs){
if(map.containsKey(dtoClasz)){
throw new IllegalAccessException("repeat dtoClaszs");
}
map.put(dtoClasz, dtoHandler);
}
}
}
public static IForwardResult execute(IDTO dto,IParseResult parseResult){
Assert.isTrue(dto != null);
Assert.isTrue(map.get(dto.getClass()) != null);
Assert.isTrue(parseResult != null);
return parseResult.getForwardResult(map.get(dto.getClass()).execute(dto));
}
@Override
public void afterPropertiesSet() throws Exception {
// TODO Auto-generated method stub
if(dtoHandlers == null || dtoHandlers.size() == 0){
throw new IllegalAccessException("daoHandlers list is null");
}
init();
}
public void setDtoHandlers(List<IDTOHandler> daoHandlers) {
this.dtoHandlers = daoHandlers;
}
}
/**
*
* 描述 资源依赖注入
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public interface IContextResource {
}
/**
*
* 描述 将共用的逻辑放入,暂没有
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public abstract class AbstractDAO implements IDTO{
}
/**
*
* 描述 返回action跳转result
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public interface IForwardResult {
String forword();
IResult getResult();
}
/**
*
* 描述 解晰result得到forwardResult的接口
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public interface IParseResult {
IForwardResult getForwardResult(IResult result);
}
/**
*
* 描述 返回的数据接口
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public interface IResult {
Map<String,Object> getResult();
}
/**
*
* 描述 分步接口,可以是链式执行
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public interface IWorkStep {
IResult execute();
IWorkStep nextWorkStep();
}
biz.app 包 点评的应用逻辑
/**
*
* 描述 规定处理点评的依赖类
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public interface IPostAppContextResource extends IContextResource{
IAppraisementRepository getAppraisementRepository();
}
/**
*
* 描述 发布点评的DTO
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public class PostAppDTO extends AbstractDAO{
private Appraisement app;
public PostAppDTO(Appraisement app){
this.app = app;
}
public Appraisement getAppraisement(){
return app;
}
}
其中Appraisement 属于 领域对象包层级
/**
*
* 描述 发布点评的处理类
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
@DTOHandlerAnnotation(queryFor={PostAppDTO.class})//这个注释用于DTOUtil做关系映射
public class PostAppDtoHandler implements IDTOHandler,IPostAppContextResource{
private IAppraisementRepository appraisementRepository;
public PostAppDtoHandler(){
}
@Override
public IResult execute(IDTO dto) {
// TODO Auto-generated method stub
Assert.isTrue(dto instanceof PostAppDTO);
Appraisement app = ((PostAppDTO)dto).getAppraisement();
IWorkStep workStep = new ValidateWorkStep(app,new SaveWorkStep(app, this));
return workStep.execute();
}
@Override
public IAppraisementRepository getAppraisementRepository() {
// TODO Auto-generated method stub
return appraisementRepository;
}
public void setAppraisementRepository(
IAppraisementRepository appraisementRepository) {
this.appraisementRepository = appraisementRepository;
}
}
/**
*
* 描述 验证点评的步骤
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public class ValidateWorkStep implements IWorkStep{
private Appraisement app;
private IWorkStep nextWorkStep;
public ValidateWorkStep(Appraisement app,IWorkStep nextWorkStep){
this.app = app;
this.nextWorkStep = nextWorkStep;
}
@Override
public IResult execute() {
// TODO Auto-generated method stub
System.out.println("ValidateWorkStep " + app);
return nextWorkStep().execute();
}
@Override
public IWorkStep nextWorkStep() {
// TODO Auto-generated method stub
return nextWorkStep;
}
}
/**
*
* 描述 保存点评的步骤
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public class SaveWorkStep implements IWorkStep{
private IPostAppContextResource postAppContextResource;
private Appraisement app;
public SaveWorkStep(Appraisement app,IPostAppContextResource postAppContextResource){
this.app = app;
this.postAppContextResource = postAppContextResource;
}
@Override
public IResult execute() {
// TODO Auto-generated method stub
app = this.postAppContextResource.getAppraisementRepository().createAppraisement(app);
return new IResult() {
@Override
public Map<String, Object> getResult() {
// TODO Auto-generated method stub
Map<String,Object> map = new HashMap<String, Object>();
map.put("appraisement", app);
return map;
}
};
}
@Override
public IWorkStep nextWorkStep() {
// TODO Auto-generated method stub
return null;
}
}
app.biz.client 包 一般在action层编写
/**
*
* 描述 发布点评ForwardResult解晰类
* 通过result来跳转页面
*
* @author 锅巴
* @version 1.0 2010-9-25
*/
public class PostAppParseResult implements IParseResult{
@Override
public IForwardResult getForwardResult(final IResult result) {
// TODO Auto-generated method stub
return new IForwardResult() {
@Override
public String forword() {
// TODO Auto-generated method stub
return "success";
}
@Override
public IResult getResult() {
// TODO Auto-generated method stub
return result;
}
};
}
}
配置文件:app_biz.context.xml
<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:p="http://www.springframework.org/schema/p" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">
<bean class="com.my.biz.core.DTOUtil">
<property name="dtoHandlers">
<list>
<bean class="com.my.biz.app.PostAppDtoHandler">
<property name="appraisementRepository">
<ref bean="appraisementRepository"/>
</property>
</bean>
</list>
</property>
</bean>
<bean id="appraisementRepository" class="com.my.infrastructure.persistence.AppraisementRepository"/>
</beans>
junit测试
public class AppBizTest {
ApplicationContext context = null;
@Before
public void setUp() throws Exception {
context = new ClassPathXmlApplicationContext(new String[]{"app_biz.context.xml"});
}
@Test
public void testAppBiz(){
Appraisement app = new Appraisement();
app.setContent("test");
IDTO dto = new PostAppDTO(app);
IParseResult parseResult = new PostAppParseResult();
IForwardResult forwardResult = DTOUtil.execute(dto, parseResult);
System.out.println(forwardResult.forword());
}
}
还不成熟,请各位指教。
分享到:
相关推荐
例如,在经典的三层架构(表示层、业务逻辑层和数据访问层)中,表示层和数据访问层的职责相对清晰明确,而业务逻辑层的职责则常常让人感到困惑。 #### 2.1、业务逻辑到底是什么 **定义与基本概念**: 业务逻辑是...
三层架构是一种常见的软件设计模式,它将应用程序分为三个主要层次:表现层(UI)、业务逻辑层(BLL)和数据访问层(DAL),以实现良好的代码组织和模块化。 1. **表现层(UI)**:这是用户与系统交互的界面,负责...
Openbiz的核心理念在于通过元数据(Metadata)实现业务逻辑的极致抽象,追求高内聚、低耦合的设计原则,旨在提高代码质量和开发效率。 #### Openbiz与业务逻辑重用 Openbiz框架的中间层设计类似于Java的中间层概念...
5. 测试数据管理:确保测试数据能够代表真实的业务数据,以验证业务逻辑的正确性。 此外,报告还可能探讨了工具和技术在提高业务覆盖率中的作用。比如,使用适合的测试管理工具可以帮助团队更好地追踪测试进度和...
这种架构将应用程序分为三个主要层次:表现层(UI)、业务逻辑层(DLL,通常包含服务接口和业务规则)、数据访问层(DAL,负责数据库交互)。接下来,我们将深入探讨每个层次的功能以及它们之间的交互。 1. **表现...
基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征...
表示层不知道具体的数据存储方式,业务逻辑层不关心用户界面如何显示,而数据访问层则独立于业务逻辑,只关注数据的存取。这种解耦合使得每一层都可以独立开发、测试和维护,提高了代码的可复用性和可扩展性。 在...
在C# .NET环境中,代码生成器尤其受欢迎,因为它可以帮助开发者快速构建应用的基础结构,如数据访问层、业务逻辑层以及用户界面层。这种工具可以显著提高开发效率,降低出错概率,让开发者更专注于业务逻辑和创新...
.NET三层架构是一种常见的软件开发模式,它将应用程序的逻辑分为三个独立的层:表现层(Presentation Layer)、业务逻辑层(Business Logic Layer)和数据访问层(Data Access Layer)。这种架构设计有助于提高代码...
三层架构通常包括表示层(Presentation Layer)、业务逻辑层(Business Logic Layer)和数据访问层(Data Access Layer)。 1. 表示层:这是用户与系统交互的部分,负责接收用户输入、显示输出信息。在餐饮管理系统...
这样,即使用户界面或数据存储方式发生变化,业务逻辑仍然可以保持不变,提高了代码的可维护性和重用性。 3. 数据访问层(Data Access Layer): 这一层负责与数据库或者其他数据存储进行交互,实现数据的读取、...
三层架构是一种常见的软件设计模式,它将应用程序逻辑划分为表现层、业务逻辑层和数据访问层,有助于提高代码的可维护性和可重用性。NHibernate则是一个强大的.NET ORM(对象关系映射)库,能够帮助开发者高效地处理...
在ASP.NET中,业务模型通常包含了数据访问层、业务逻辑层和服务接口层。 - BMW代码生成器帮助开发者快速创建这些模型,包括实体类、数据访问接口、服务接口和实现,确保符合特定业务需求。 2. **代码生成器**: -...
- **分层架构的设计**:分层架构是微服务设计中的常见模式,通常包括表现层、业务逻辑层、数据层等。其中,微服务的调用一般位于业务逻辑层。 - **数据设计的重要性**:数据设计是微服务架构中的关键环节之一。在...
三层架构是一种常见的软件设计模式,尤其在Windows桌面应用程序开发中,如WinForm程序,它将应用程序的业务逻辑、数据访问和用户界面分离,以提高代码的可维护性、可扩展性和可重用性。本项目是基于DotNetBar控件库...
三层架构是一种常见的软件设计模式,它将应用程序分为三个主要部分:表现层(Presentation Layer)、业务逻辑层(Business Logic Layer)和数据访问层(Data Access Layer),以实现良好的代码组织和模块化。...
三层架构是一种常见的软件设计模式,它将应用程序分为表示层、业务逻辑层(逻辑访问层)和数据访问层(LTS层),以实现职责分离和更好的可维护性。在LINQ下,这种架构略有变化,主要是因为LINQ的特性。 首先,作者...
文件名"SolutionTest"可能代表整个解决方案文件,里面可能包含了项目的源代码,包括表现层的ASP.NET页面,业务逻辑层的类库,以及数据访问层的数据连接和查询代码。 学习这个实例,初学者可以理解如何将应用的职责...
三层架构是一种软件设计模式,它将应用逻辑分解为三个主要部分:表现层(Presentation Layer)、业务逻辑层(Business Logic Layer)和数据访问层(Data Access Layer)。这种分层的设计有助于提高代码的可维护性、...