spring-roo为错误的@id属性名称创建json控制器



我即将评估spring-roo,而我正在对现有的mysql数据库方案进行逆向工程。除了web mvc json all命令在某些情况下创建引用不存在的JPA实体getter:getId()*_Roo_Controller_Json.aj文件外,其他一切都很好。这种情况似乎发生在用@Id注释的字段的名称与id不同的情况下。奇怪的是,当我通过执行整个roo脚本从头开始创建应用程序时,这个问题并不总是发生(如下所示)。

JPA实体ITD看起来像:

privileged aspect FrmwrkAuthItem_Roo_Jpa_Entity {
    declare @type: FrmwrkAuthItem: @Entity;
    declare @type: FrmwrkAuthItem: @Table(name = "frmwrk_AuthItem");
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name = "name", length = 64)
    private String FrmwrkAuthItem.name;
    public String FrmwrkAuthItem.getName() {
        return this.name;
    }
    public void FrmwrkAuthItem.setName(String id) {
        this.name = id;
    }   
}

web mvc json all命令使用createFromJson()方法创建文件FrmwrkAuthItemController_Roo_Controller_Json.aj,其中使用了不存在的getter getId()(代码简化)。

privileged aspect FrmwrkAuthItemController_Roo_Controller_Json {
    ...
    @RequestMapping(method = RequestMethod.POST, headers = "Accept=application/json")
    public ResponseEntity<String> FrmwrkAuthItemController.createFromJson(@RequestBody String json, UriComponentsBuilder uriBuilder) {
        HttpHeaders headers = new HttpHeaders();
        headers.add("Content-Type", "application/json");
        try {
            FrmwrkAuthItem frmwrkAuthItem = FrmwrkAuthItem.fromJsonToFrmwrkAuthItem(json);
            frmwrkAuthItemService.saveFrmwrkAuthItem(frmwrkAuthItem);
            RequestMapping a = (RequestMapping) getClass().getAnnotation(RequestMapping.class);
            /******************************************** 
             * below is the corrupt line of code with frmwrkAuthItem.getId()
             * frmwrkAuthItem.getName() would be correct! 
             ********************************************/
            headers.add("Location",uriBuilder.path(a.value()[0]+"/"+frmwrkAuthItem.getId().toString()).build().toUriString());
            return new ResponseEntity<String>(headers, HttpStatus.CREATED);
        } catch (Exception e) {
            return new ResponseEntity<String>("{"ERROR":"+e.getMessage()+""}", headers, HttpStatus.INTERNAL_SERVER_ERROR);
        }
        ....

创建应用程序的roo脚本是:

project --topLevelPackage org.myproject
jpa setup --provider ECLIPSELINK --database MYSQL --databaseName myproject  --userName *** --password ***
addon install bundle --bundleSymbolicName org.springframework.roo.wrapping.mysql-connector-java
database reverse engineer --schema myproject --service --package ~.domain
json all
web mvc setup --package ~.contoller
web mvc all --package ~.contoller
web mvc json all

您使用的是哪个Spring Roo版本?

如果它是最新的,我认为这个问题可能是一个bug。你能在春日制作一张关于它的门票吗?。

为了获得更快的解决方案,可以包含项目的备份(可以在删除Roo.log文件的user/passwd后使用backup Spring-Roo-shell命令)。

谨致问候。

最新更新