`
阅读更多
主要增加以下更新:
  • 验证器
  • 声明式事务
  • 7个默认Action方法

  • PS:这个例子也演示了如何使用ActiveRecord + Control + Validator 完成 Crud 。

    1.验证器
    1.8.6以及更旧版本的验证器使用起来非常鸡肋。主要存在一下几个缺点:
     
  • 验证规则定义之后,只要是控制器的属性,所有该控制器下的Action方法被执行的时候都会强制的激活验证程序。
  •  
  • 验证程序检测到错误信息后,框架自己把它给处理了,虽然能满足一定的需求,但是这种方式让开发者无法自己灵活控制。长久来说是不好的。

  • 基于上述两点,本次即将发布的版本1.9针对它们做了改善。请先看看下面这段代码;
    Pet.java
    @Entity
    @Table(name = "t_pet")
    public class Pet extends Model {
    
    	public final static Pet inst = new Pet();
    
    	@Required
    	@Length(min = 6, max = 6)
    	private String num;
    
    	@Required
    	@Length(min = 2, max = 6)
    	@Chinese
    	@Forbid(words = {"性爱", "革命"})
    	private String name;
    
    	@Size(min = 1, max = 10)
    	private int age = 1;
    
    	@Required
    	@Enumer(words = { "猫", "狗" })
    	private String type;
    
    	@Override
    	public String toString() {
    		return "Pet [num=" + num + ", name=" + name + ", age=" + age
    				+ ", type=" + type + ", id=" + id + "]";
    	}
    
            //setters and getters
    }
    

    PetsControl.java
    public class PetsControl {
    
    	private final static String PAGE_INT = "分页参数必须是整数格式";
    	private final static String PAGE_VALID = "分页参数必须大于 0 ";
    	private final static List<String> TYPES = Arrays.asList("狗", "猫");
    
    	private Pet pet = new Pet();// inject when create and update
    
    	@Required
    	@Size(min = 1)
    	@Int
    	private Long id;
    
    	@Int(mess = PAGE_INT)
    	@Size(min = 1, mess = PAGE_VALID)
    	private int pageNum = 1;
    
    	@Int(mess = PAGE_INT)
    	@Size(min = 1, mess = PAGE_VALID)
    	private int numPerPage = 10;
    
    	private String keyword = "";
    
    	@Validate({ "pageNum", "numPerPage" })
    	public String index(Validation val, Map model) {
    		if (val.hasErr())
    			return JsonConverter.convert(val.getAllErr());
    
    		model.put("pets", Pet.inst.find().fetch(pageNum, numPerPage));
    		model.put("dpc", new DivPageComp(pageNum, numPerPage, Pet.inst.count()));
    
    		return "html";
    	}
    
    	public String doSearchAtGet(Map model) {
    		model.put("pets", Pet.inst.find("name like ?", "%" + keyword + "%")
    				.fetch());
    
    		return "fmt:pets/view/list.html";
    	}
    
    	@Validate("pet.*")
    	@Transactional
    	public String create(Validation val, Map model) {
    		if (val.hasErr())
    			return JsonConverter.convert(val.getAllErr());
    
    		pet.create();
    
    		model.put("types", TYPES);
    
    		return "index";
    	}
    
    	@Validate({ "id", "pet.*" })
    	@Transactional
    	public String update(Validation val, Map model) {
    		if (val.hasErr())
    			return JsonConverter.convert(val.getAllErr());
    
    		pet.setId(id);
    		pet.save();
    
    		model.put("types", TYPES);
    
    		return "index";
    	}
    
    	@Validate("id")
    	@Transactional
    	public String destroy(Validation val) {
    		if (val.hasErr())
    			return JsonConverter.convert(val.getAllErr());
    
    		pet.setId(id);
    		pet.delete();
    
    		return "index";
    	}
    
    	@Validate("id")
    	public String show(Validation val) {
    		if (val.hasErr())
    			return JsonConverter.convert(val.getAllErr());
    
    		pet.setId(id);
    		pet.load();
    		
    		return "html";
    	}
    
    	@Validate("id")
    	public String edit(Validation val, Map model) {
    		if (val.hasErr())
    			return JsonConverter.convert(val.getAllErr());
    
    		pet.setId(id);
    		pet.load();
    		
    		model.put("types", TYPES);
    		
    		return "html";
    	}
    
    	public String editNew(Map model) {
    		
    		model.put("types", TYPES);
    		
    		return "html";
    	}
    
            //setters and getters
    }
    


    上面有个 doSearchAtGet 方法不是默认约定的方法,是属于自定义的Action方法。请对照前面博文中提到的 Action 方法名字新语法支持的内容。

    注意对照 7 个默认的方法:
    HTTP MethodURIClass.MethodParams
    GET/demoDemoControl.index
    POST/demoDemoControl.create
    PUT/demo/{id}DemoControl.updateid={id}
    DELETE/demo/{id}DemoControl.destroyid={id}
    GET/demo/{id}DemoControl.showid={id}
    GET/demo/{id}/editDemoControl.editid={id}
    GET/demo/newDemoControl.editNewid={id}


    当执行 GET /pets/new 打开 new.html后,直接什么也不填写就提交,然后验证器生效,页面上会打印:
    {"pet.num":"请完成必填内容","pet.name":"请填写全中文"}
    


    可以看到好几个Action方法上面都有 @Validate 注解。这个注解填写一个字符串数组。这些数组声明了在执行这个Action的时候哪些参数需要被验证。具体的验证规则交由属性上的那些类似 @Required @Size @Forbid 这样的注解来定义。也就是说:
    验证过程分为两点:
    1.定义规则, 在属性上面标注 @Required 等等的注解。
    2.触发验证行为, 在Action方法上标注 @Validate({"param1", "param2"}),来声明那些需要被验证的参数

    还有最后一个就是验证行为一旦触发,并且检测到错误消息后,框架不再截断当前Action的执行,而是将验证信息封装到一个 Validation 对象里面,就像:

    @Validate({ "id", "pet.*" })
    @Transactional
    public String update(Validation val, Map model) {
        if (val.hasErr())
            return JsonConverter.convert(val.getAllErr());
    
        return "通过验证啦...";
    }
    


    具体怎么判断是否验证不通过,直接调用:
    boolean flag = val.hasErr();
    


    然后取出所有的参数验证信息:
    Map<String,String> errors = val.getAllErr();
    

    上面这个 Map 里面是 “参数名”-“验证信息”这样的结构的。只要某个参数违反了验证规则的话,那么这个Map里面就会存在该参数以及对应的验证错误消息。
    例如:
    {"pet.age":"请填写一个大小介于 1 到 10 之间的整数","pet.num":"请填写长度介于6到6之间的文本","pet.name":"请不要包含下列字眼:[性爱#革命] "}
    


    这个PetControl的代码最好细细品读。方能理解一些约定思想。

    最后重申:约定优于配置, 配置覆盖约定。
    2
    2
    分享到:
    评论
    2 楼 laiweiweihi 2012-04-13  
    貌似掉线 写道
    嗯。。。。好文章。。。

    =。= !
    1 楼 貌似掉线 2012-04-13  
    嗯。。。。好文章。。。

    相关推荐

      eweb4j

      eweb4j是一个Java开发框架,它专注于提供高效、轻量级且易于使用的Web应用程序解决方案。这个框架的设计理念是简化开发流程,提高开发效率,同时保持代码的清晰性和可维护性。下面我们将深入探讨eweb4j框架的核心...

      java猜数字源码-eweb4j-framework:简单的Java网络框架

      EWeb4J ? = EWeb4J 是一个基于 Servlet/Jdbc 构建的轻量级 Java Web 开发框架。它可以代替 SSH 来开发一个完整的 Web 应用程序。 它专注于 少侵入、少配置、松耦合、RESTful架构风格的 Web 应用程序开发。 EWeb4J ...

      eweb4j最新版本src[附带需要的jar]

      `eweb4j`作为一个全面的Web应用框架,具备了MVC架构、数据访问、模板引擎、安全控制等核心功能,且源代码开放,方便开发者深入理解和定制。通过了解和掌握`eweb4j`,开发者可以快速构建稳定、高效的Web应用程序。...

      1756-eweb手册

      Rockwell 1756-Eweb模块

      一个很好的eweb编辑器

      在描述中提到的“eweb编辑器 要改下db中的后缀为asp”,这可能是指在使用eweb编辑器进行网站开发时,需要将数据库连接文件或动态页面文件的扩展名从原本的格式更改为ASP(Active Server Pages)格式。ASP是一种微软...

      在线编辑器(eweb)应用实例

      作为一个现代的在线编辑器,EWeb可能集成了版本控制系统,如Git。这样,你可以追踪代码更改,回滚到之前的版本,或者与团队成员协作。实例可能包括如何使用EWeb进行版本控制操作的指南。 七、实际应用示例 实例可能...

      1756-EWEB.pdf

      1756-EWEB

      eweb编辑器,shengcheng

      在线编辑HTML,使用户方便使用编码在线编辑HTML,使用户方便使用编码

      eweb.rar_eweb_editor

      《EWeb编辑器2.80:打造高效网页创作利器》 EWeb编辑器,全称为"EWeb Editor",是一款专业且用户友好的网页编辑工具,尤其以2.80版本备受好评,被誉为“绝对好用”。这款编辑器旨在简化网页制作流程,提升开发效率...

      eweb 网页编辑器

      4. **HTML源码编辑**:对于有经验的用户,eweb也提供了直接编辑HTML源码的功能,以便进行更精细的控制和自定义。 5. **表格与布局**:编辑器内建了表格创建和编辑工具,用户可以轻松创建复杂的表格结构,调整列宽和...

      eWeb.rar_eWeb Editor Clie_eWebEditor_eweb editoi_文本修改器_文本编辑器

      《eWeb Editor客户端:在线文本编辑器的深度解析与应用》 eWeb Editor是一款功能强大的在线文本编辑器,尤其在Web开发领域中被广泛应用。它以其便捷的操作界面和丰富的编辑功能,为网络编程人员提供了极大的便利。...

      eweb编辑器(带图片上传功能)

      ASP常用的后台编辑器,带图片上传功能 调用方法如下例子: &lt;textarea name="nr" ROWS="20" COLS="70"&gt;%=Server.HTMLEncode(rs("nr"))%&gt;&lt;/textarea&gt; &lt;iframe ID="eWebEditor1" src="../eWebEditor/...

      java开源框架下载集合

      EWeb4J支持多种数据库,并提供了强大的表单验证功能,使得开发者可以轻松创建复杂的数据驱动型Web应用。 #### 3. Spring Roo 1.2.1 **下载链接**: ...

      ControlLogix 热备手册(英文)

      热备系统是指在控制系统中设置两个或多个控制器,其中一个作为主控制器工作,其余作为备用控制器。当主控制器发生故障时,备用控制器能立即接管控制任务,确保系统的连续运行不受影响。热备系统主要用于对生产过程...

      eWeb7.3.0 商业版 支持上传版 在线html编辑器

      《eWeb7.3.0商业版:在线HTML编辑器的高效工具》 eWeb7.3.0商业版是一款专为网页制作和内容编辑设计的在线HTML编辑器,其核心在于提供用户友好的界面和丰富的功能,使得非专业程序员也能轻松地创建和编辑网页内容。...

      eWeb editor编辑器文件

      eWeb editor编辑器文件,说明,使用方法:将解压后的editor文件夹拷贝到项目根目录下,在需要的页面中加入以下内容: 办事内容:&lt;/font&gt;&lt;/td&gt; ;style=s_blue" frameborder="0" width="99%" ...

      eWEB - literate programming in AsciiDoc-开源

      让 AsciiDoc 成为您的文学编程工具集的一部分。 使用 eWEB,您可以使用嵌入的 WEB 代码片段编织和缠结作为 AsciiDoc 文档编写的文字程序。

      e-web editor 3.8

      4. **表格与列表**:对于数据展示,编辑器提供表格创建和编辑功能,包括单元格合并、行列插入删除、表格样式设置等。同时,也支持无序列表和有序列表的创建,便于组织信息。 5. **链接管理**:用户可以在编辑器中...

    Global site tag (gtag.js) - Google Analytics