我的所有 Cloud Endpoints 方法都可以在本地工作,并且在部署应用程序时除了一个之外的所有方法都可以工作。这是方法:
@ApiMethod(name = "listUrl", path ="article/urls", httpMethod = HttpMethod.GET)
public String[] listUrl() {
List<Article> articles = getArticleList();
String[] urlArray = new String[articles.size()];
int i = 0;
for (Article article : articles)
urlArray[i++] = article.getUrl();
return urlArray;
}
我知道三种接受的返回类型是“POJO、数组或集合”。但我认为可能是导致错误的原因,所以尝试返回一个sString[]
集合。String
@ApiMethod(name = "listUrl", path ="article/urls", httpMethod = HttpMethod.GET)
public CollectionResponse<String>/*String[]*/ listUrl() {
List<Article> articles = getArticleList();
List<String> urls = new ArrayList<String>();
//String[] urlArray = new String[articles.size()];
//int i = 0;
for (Article article : articles)
urls.add(article.getUrl());
//urlArray[i++] = article.getUrl();
return /*urlArray*/ CollectionResponse.<String> builder().setItems(urls).build();
}
但无济于事。我继续收到“500 内部服务器错误”。
最奇怪的部分是,当我查看管理控制台中的日志时,它指出请求通过正常:
2013-09-22 22:08:00.715 /_ah/spi/com.example.hiserver.ArticleEndpoint.listUrl 200 55ms 0kb Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:23.0) Gecko/20100101 Firefox/23.0
xx.xxx.xx.xxx(my IP) - - [22/Sep/2013:22:08:00 -0700] "POST /_ah/spi/com.example.hiserver.ArticleEndpoint.listUrl HTTP/1.1" 200 129 - "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:23.0) Gecko/20100101 Firefox/23.0" "hylyt-it.appspot.com" ms=56 cpu_ms=21 cpm_usd=0.000014 app_engine_release=1.8.4 instance=00c61b117cdf561948b997f4ec6be2ca72c139d1