我制作了一个简单的移动(Android)应用程序和网络(Play 2.1.0)应用程序。它实际上是 Android 上的打地鼠游戏,您可以在 Web 应用程序上发布您的分数(当然还可以获取前 10 名分数的列表)。
因此,GET 最高分请求和 POST 请求都可以在本地(在我的计算机上)完美运行。但是当我在 Heroku 上推送我的应用程序时,只有 GET 最高分请求有效。正如我所注意到的,POST 请求的问题在于接收 JSON(来自 Android)的 web api (Play2) 控制器。我猜它不知道如何从请求中解析 Json ......
我使用这种处理 Json 请求的方式:http ://www.playframework.com/documentation/2.1.0/JavaJsonRequests
我修改了我的代码以发现问题:
@BodyParser.Of(BodyParser.Json.class)
public static Result newScore() {
JsonNode json;
try {
json = request().body().asJson();
String jsonString = json.toString();
return ok(jsonString);
} catch (Exception e1) {
return ok("PROBLEM");
}
}
localhost 上的响应是我发送的 json 字符串。Heroku 上的响应被 String PROBLEM 捕获异常。这是一个非常奇怪的问题,我不知道为什么它在 localhost 上可以正常工作,但在 heroku 上却不行……有什么想法吗?:)
更新(Android logcat):
02-08 00:01:09.140: I/SendResultService(18709): <!DOCTYPE html>
02-08 00:01:09.140: I/SendResultService(18709): <html>
02-08 00:01:09.140: I/SendResultService(18709): <head>
02-08 00:01:09.140: I/SendResultService(18709): <title>Error</title>
02-08 00:01:09.140: I/SendResultService(18709): <link rel="shortcut icon" href="">
02-08 00:01:09.140: I/SendResultService(18709): <style>
02-08 00:01:09.140: I/SendResultService(18709): html, body, pre {
02-08 00:01:09.140: I/SendResultService(18709): margin: 0;
02-08 00:01:09.140: I/SendResultService(18709): padding: 0;
02-08 00:01:09.140: I/SendResultService(18709): font-family: Monaco, 'Lucida Console', monospace;
02-08 00:01:09.140: I/SendResultService(18709): background: #ECECEC;
02-08 00:01:09.140: I/SendResultService(18709): }
02-08 00:01:09.140: I/SendResultService(18709): h1 {
02-08 00:01:09.140: I/SendResultService(18709): margin: 0;
02-08 00:01:09.140: I/SendResultService(18709): background: #A31012;
02-08 00:01:09.140: I/SendResultService(18709): padding: 20px 45px;
02-08 00:01:09.140: I/SendResultService(18709): color: #fff;
02-08 00:01:09.140: I/SendResultService(18709): text-shadow: 1px 1px 1px rgba(0,0,0,.3);
02-08 00:01:09.140: I/SendResultService(18709): border-bottom: 1px solid #690000;
02-08 00:01:09.140: I/SendResultService(18709): font-size: 28px;
02-08 00:01:09.140: I/SendResultService(18709): }
02-08 00:01:09.140: I/SendResultService(18709): p#detail {
02-08 00:01:09.140: I/SendResultService(18709): margin: 0;
02-08 00:01:09.140: I/SendResultService(18709): padding: 15px 45px;
02-08 00:01:09.140: I/SendResultService(18709): background: #F5A0A0;
02-08 00:01:09.140: I/SendResultService(18709): border-top: 4px solid #D36D6D;
02-08 00:01:09.140: I/SendResultService(18709): color: #730000;
02-08 00:01:09.140: I/SendResultService(18709): text-shadow: 1px 1px 1px rgba(255,255,255,.3);
02-08 00:01:09.140: I/SendResultService(18709): font-size: 14px;
02-08 00:01:09.140: I/SendResultService(18709): border-bottom: 1px solid #BA7A7A;
02-08 00:01:09.140: I/SendResultService(18709): }
02-08 00:01:09.140: I/SendResultService(18709): </style>
02-08 00:01:09.140: I/SendResultService(18709): </head>
02-08 00:01:09.140: I/SendResultService(18709): <body>
02-08 00:01:09.140: I/SendResultService(18709): <h1>Oops, an error occured</h1>
02-08 00:01:09.140: I/SendResultService(18709): <p id="detail">
02-08 00:01:09.140: I/SendResultService(18709): This exception has been logged with id <strong>6d9a6k11h</strong>.
02-08 00:01:09.140: I/SendResultService(18709): </p>
02-08 00:01:09.140: I/SendResultService(18709): </body>
02-08 00:01:09.140: I/SendResultService(18709): </html>
解决方案:好的,我解决了一个问题——这实际上是我的 Android 代码中的一个问题:
public void postData(String url,JSONObject obj) {
HttpParams myParams = new BasicHttpParams();
HttpConnectionParams.setConnectionTimeout(myParams, 10000);
HttpConnectionParams.setSoTimeout(myParams, 10000);
HttpClient httpclient = new DefaultHttpClient();
try {
HttpPost httppost = new HttpPost(url.toString());
httppost.setHeader("Content-type", "application/json");
StringEntity se = new StringEntity(obj.toString());
//se.setContentEncoding(new BasicHeader(HTTP.CONTENT_TYPE, "application/json")); // <-- PROBLEM
httppost.setEntity(se);
HttpResponse response = httpclient.execute(httppost);
String temp = EntityUtils.toString(response.getEntity());
Log.i(TAG, temp);
}
catch (ClientProtocolException e) {Log.e(TAG, "Client protocol ex");}
catch (IOException e) {Log.e(TAG, "io ex");}
}
这段代码现在可以工作了,我评论了有问题的部分:将 BasicHeader 设置为字符串实体。这显然不是 localhost 的问题,但它是 Heroku 的问题。