SparkJava变量范围

时间:2015-10-11 20:24:00

标签: spark-java

我正在开发一个SparkJava(不是Apache Spark)应用程序,我想在之前的过滤器和后期路由之间共享一个对象。过滤器和路由在不同的类中定义。我不愿意继续使用会话,因为它是一个移动应用程序json api,从理论上讲,它应该是免费会话。变量范围应该从请求处理的开始到结束。

    before(Main.API_PROTECTED + "/*", (req, res) -> {
        String token = req.headers("Authorization");
        if (token == null | "".equals(token)) {
            halt(401, "You're not welcome.");
        } else {
            Partner partner = new PartnerDAO().getPartnerByToken(token.replace("Bearer ", ""));
            if (partner == null) {
                halt(401, "You're not welcome.");
            }
        }
    });

上面有上面的过滤器,我想通过下面的帖子分享合作伙伴对象:

        post(Main.API_PROTECTED + "/vendors",
            (req, res) -> {
                // Do stuff to insert Vendors in the Database, verifying access control using the partner object
                return "";
            });

也许在将来,应用程序需要扩展,因此请记住,可能有多个节点正在运行。

1 个答案:

答案 0 :(得分:4)

将对象添加到过滤器中的请求中。

 request.attribute("myObject", "my value");

在帖子中查找

request.attribute("myObject");  // "my value"
相关问题