Play框架拾遗之二:控制层

1、获取HTTP参数

在Controller控制器,已经内建HTTP请求中参数对象,我们可以这样获取:

public static void show(){
 String id=params.get("id");
 String[] names=params.getAll("name");
 Long lid=params.get("lid",Long.class);
}

日期等,可以用@As注解进行绑定,这样可以避开在conf文件中统一设定的格式,有些场合会用到:

public static void articlesSince(@As("dd/MM/yyyy") Date from) {
  List<Article> articles = Article.findBy("date >= ?", from);
  render(articles);
}

2、结果返回

服务端可以定制返回参数名称,如下,两个方法中,后者简单,但是返回name是client,但是前者的可以定制。

public class Clients extends Controller {
  public static void show(Long id) {
    Client client = Client.findById(id);
    renderArgs.put("client", client);
    render(); 
  }

  public static void show2(Long id){
    Client client=Client.findById(id);
    render(client);
  }
}

有个需要注意的是render()方法只允许传递本地变量。

3、Action链

如果在Controller方法中调用其他Controller方法,如下

public class Clients extends Controller {
  // get   /clients/{id}
  public static void show(Long id) {
    Client client = Client.findById(id);
    render(client);
  }
 
  //post  /clients 
  public static void create(String name) {
    Client client = new Client(name);
    client.save();
    show(client.id);
  }
}

按照定义,Action链的生命周期如下:

  1. 浏览器向/clients发送POST请求;

  2. 路由器调用Clients控制器中的create方法;

  3. create方法直接访问show方法;

  4. Java调用被拦截,路由器逆向生成带有id参数的URL来调用Clients.show;

  5. HTTP响应重定向为:/clients/3132;

  6. 浏览器地址栏中URL展现为:/clients/3132;

拦截器

除了常见的@catch ,@before ,还有对应的@After ,和@finally。Finally的作用与trycatch中的差不多。

public class Admin extends Application {
  @Finally
  static void log() {
    Logger.info("Action executed ...");
  }
}

还可以使用其他类中定义的拦截器,如:

public class Secure extends Controller {  
  @Before
  static void checkAuthenticated() {
    if(!session.containsKey("user")) {
      unAuthorized();
    }
  }
}

在其他的控制器中,可以通过@With(Secure.class)

@With(Secure.class)
public class Admin extends Application {   
    ...
}

你可能感兴趣的:(play,1.x)