当前位置: 首页 > 工具软件 > PrettyFaces > 使用案例 >

prettyfaces的URL配置 基于 annotation

慎峻
2023-12-01

如果你讨厌XML,你可以尝试着使用基于注解的形式配置 prettyfaces也开始了annotation潮流。

 

 

Annotation based configuration

 

在web.xml中加入以下的
<context-param>
   <param-name>com.ocpsoft.pretty.BASE_PACKAGES</param-name>
   <param-value>com.example.myapp,com.ocpsoft</param-value>
</context-param>
com.example.myapp和com.ocpsoft指明了这两个包是要被annotation扫描到的。
如果你一点都不想用annotation也可以加上下面的
<context-param>
   <param-name>com.ocpsoft.pretty.BASE_PACKAGES</param-name>
   <param-value>none</param-value>
</context-param>
一般情况prettyfaces只会扫描到class路径的annotation,如果你也想让他扫描到lib引入的jar中的annotation
可以加上下面这句话
<context-param>
   <param-name>com.ocpsoft.pretty.SCAN_LIB_DIRECTORY</param-name>
   <param-value>true</param-value>
</context-param>

Simple URL mappings

@Named("bean")
@RequestScoped
@URLMapping(id = "store", pattern = "/store/", viewId = "/faces/shop/store.jsf")
public class StoreBean {
  /* your code */
}
@Named("bean")
@RequestScoped
@URLMappings(mappings={
  @URLMapping(id = "categoryBean", pattern = "/store/#{ bean.category }/", viewId = "/faces/shop/store.jsf"),
  @URLMapping(id = "categoryBean2", pattern = "/shop/#{ bean.category }/", viewId = "/faces/shop/store.jsf")
})
public class CategoryBean {

  private String category;

  /* Getters & Setters */
}

Page actions

最佳实践
我们如果采用一个页面 一个backbean的方式进行开发,那么我们可以在这个backBean的前面加上
@URLMapping(id = "viewItem", pattern = "/store/item/#{ bean.itemId }/", viewId = "/faces/shop/item.jsf")
类似这样的注解来restful化我们的应用

同时注意一个小BUG,在我使用pretty faces 3.2.0 version的时候
其中基于注解的配置方式pattern = "/store/item/#{ bean.itemId }/"   其中  #{ bean.itemId } 后边必须跟着 一个 /  来结束 要不然回出问题。

 

 

 类似资料: