SparkJava 变量范围

Lae*_*ner 2 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.");
            }
        }
    });
Run Code Online (Sandbox Code Playgroud)

有上面的 before 过滤器,我想从中与下面的 post 路由共享合作伙伴对象:

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

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

dom*_*arr 5

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

 request.attribute("myObject", "my value");
Run Code Online (Sandbox Code Playgroud)

去帖子里找找看

request.attribute("myObject");  // "my value"
Run Code Online (Sandbox Code Playgroud)