
通过 okhttp 调用 wordpress json api 提交评论时,需主动检查 `response.issuccessful()` 判断 http 状态码(如 200 表示成功),而非仅依赖异常捕获——因为网络请求成功但服务器返回错误(如 400、500)不会触发 `ioexception`。
在你的代码中,catch (IOException e) 仅能捕获网络层异常(如连接超时、DNS 失败、无网络等),而无法捕获 HTTP 业务错误(例如 WordPress 返回 {"status":"error","message":"Invalid email"} 或 HTTP 状态码为 400 Bad Request / 500 Internal Server Error)。因此,即使评论提交失败,只要网络通畅、服务器响应了(哪怕内容是错误信息),execute() 就不会抛出异常,导致 "Comment Failed" 日志永远不会打印。
✅ 正确做法:在 response 返回后,先调用 response.isSuccessful()(等价于状态码 200–399),再根据结果处理成功或失败逻辑:
OkHttpClient httpClient = new OkHttpClient();
String url = "https://www.sikhnama.com/?json=respond/submit_comment" +
"&post_id=" + Postid +
"&name=" + URLEncoder.encode(name, "UTF-8") +
"&email=" + URLEncoder.encode(email, "UTF-8") +
"&content=" + URLEncoder.encode(comment, "UTF-8");
Request request = new Request.Builder()
.url(url)
.build();
try {
Response response = httpClient.newCall(request).execute();
runOnUiThread(() -> {
if (response.isSuccessful()) {
// ✅ HTTP 响应成功(如 200)
try {
String responseBody = response.body().string();
Toast.makeText(getApplicationContext(), "评论已提交!", Toast.LENGTH_SHORT).show();
Log.d("Comment", "Success: " + responseBody);
} catch (IOException e) {
Toast.makeText(getApplicationContext(), "解析响应失败", Toast.LENGTH_SHORT).show();
Log.e("Comment", "Failed to read response body", e);
}
} else {
// ❌ HTTP 请求失败(如 400、403、500 等)
int statusCode = response.code();
String errorMsg = "评论提交失败(HTTP " + statusCode + ")";
Toast.makeText(getApplicationContext(), errorMsg, Toast.LENGTH_LONG).show();
Log.w("Comment", errorMsg + ", Response: " + response.message());
}
});
} catch (IOException e) {
// ⚠️ 仅捕获网络异常:无网络、连接拒绝、超时等
e.printStackTrace();
runOnUiThread(() -> {
Toast.makeText(getApplicationContext(), "网络错误,请检查网络连接", Toast.LENGTH_LONG).show();
Log.e("Comment", "Network error", e);
});
}? 关键注意事项:
- 务必对 URL 参数进行 URLEncoder.encode(..., "UTF-8"):否则含空格、@、/ 等特殊字符的 name 或 email 会导致请求被截断或 400 错误;
- 不要忽略 response.body().string() 的重复调用风险:该方法只能调用一次,后续调用将返回空字符串,建议读取后缓存;
- WordPress JSON API 已弃用(v1/v2):你当前使用的 ?json=... 是非常老旧的插件接口(如 WP REST API v1),强烈建议升级至官方支持的 WP REST API(如 POST /wp-json/wp/v2/comments),它更安全、标准且持续维护;
- 生产环境请添加超时配置与线程切换封装(如使用 Coroutine 或 Retrofit + LiveData),避免 runOnUiThread 在 Activity 销毁后引发崩溃。
总结:判断评论是否提交成功,核心在于区分「网络可达性」和「业务有效性」——前者靠 try-catch IOException,后者必须依赖 response.isSuccessful() 及响应体内容解析。二者缺一不可。










