Google 无状态后端应用的应用云端点 API

Google App Cloud Endpoint API for Stateless Backend App

我们在 Google App Engine (GAE) 上有一个无状态后端 Java 应用 运行。引擎接收字符串 A (json) 和 returns 不同的字符串 B (json)。

Google 云端点上的示例围绕创建实体 - 定义 CloudEndpoint Class。大多数示例似乎都与 DataStore - 后端数据库相关联。

在我们的例子中,数据不是持久化的,也没有主键。我们成功地创建了一个实体——将输入和输出字符串作为两个字段。它有效,但是 resp 有效负载还包含输入字符串的副本。

我们有一个使用标准 servlet(req.string 和不同的 resp string)的解决方案,使用 doPost 方法。

任何建议 - 对于我们的场景 - 是否需要 CloudEndPoint and/or 如果有一种简单的方法可以在 Cloud Endpoint 中执行此操作?

谢谢

没有什么可以强制您使用数据存储。不需要就不要用

例如,您可以从一个 Pojo 转换为另一个

public class Input {
    public String inputValue;
}

public class Output {
    public String outputValue;
}

@Api(name = "myApi", version = "v1")
public class MyApi {

    @ApiMethod(name = "hello")
    public Output hello(Input input) {
        Output response = new Output();
        response.resultValue = "Hello " + input.inputValue;
        return response;
    }

}

通过 APIs 资源管理器(对我来说 http://localhost:8888/_ah/api/explorer)显示它导致 POST 请求/响应等效 JSON 对象:

POST http://localhost:8888/_ah/api/myApi/v1/hello
{
 "inputValue": "Hans"
}

哪个returns

200 OK
{
 "resultValue": "Hello Hans"
}

端点的一大优点是您可以编写简单的 Java 方法,例如 Output hello(Input input) 并从自动生成的 (Java) 客户端代码中使用它们,而不是 "see" 这些方法是通过 HTTP 调用的。

如果您弄清楚 URL 是什么但那不是预期用途,您可以通过常规 http 使用它们。

在应用程序引擎中执行 JSON 方法的一种更通用的方法是使用 JAX-RS 实现,如 Jersey。这样您就不必拥有_ah/api/vN/apiname/methodname 方法和它们附带的限制(例如异常情况下的特定错误响应)。

使用 JAX-RS 的代码可能看起来像

@Path("/whatEverILike")
@Produces(MediaType.APPLICATION_JSON)
@Consumes(MediaType.APPLICATION_JSON)
public class MyApi {

    @POST
    public Output hello(Input input) {
        Output response = new Output();
        response.resultValue = "Hello " + input.inputValue;
        return response;
    }
}

但是设置这样的项目有点困难,因为您需要很多依赖项。例如,对于 Jersey,您可能需要以下 2 个包括几个传递依赖项:

org.glassfish.jersey.containers:jersey-container-servlet-core:2.22
org.glassfish.jersey.media:jersey-media-json-jackson:2.22

展开为

aopalliance-repackaged-2.4.0-b31.jar  jackson-core-2.5.4.jar                     javassist-3.18.1-GA.jar       jersey-client-2.22.jar                  jersey-media-jaxb-2.22.jar
hk2-api-2.4.0-b31.jar                 jackson-databind-2.5.4.jar                 javax.annotation-api-1.2.jar  jersey-common-2.22.jar                  jersey-media-json-jackson-2.22.jar
hk2-locator-2.4.0-b31.jar             jackson-jaxrs-base-2.5.4.jar               javax.inject-1.jar            jersey-container-servlet-core-2.22.jar  jersey-server-2.22.jar
hk2-utils-2.4.0-b31.jar               jackson-jaxrs-json-provider-2.5.4.jar      javax.inject-2.4.0-b31.jar    jersey-entity-filtering-2.22.jar        osgi-resource-locator-1.0.1.jar
jackson-annotations-2.5.4.jar         jackson-module-jaxb-annotations-2.5.4.jar  javax.ws.rs-api-2.0.1.jar     jersey-guava-2.22.jar                   validation-api-1.1.0.Final.jar