【发布时间】:2015-07-22 01:08:28
【问题描述】:
我一直在尝试从 SO 和其他网站上的大量示例中学习,但我无法弄清楚为什么我一起破解的示例不起作用。我正在构建一个小型概念验证应用程序,它可以识别语音并将其(文本)作为 POST 请求发送到 node.js 服务器。我已经确认语音识别可以正常工作,并且服务器正在接收来自常规浏览器访问的连接,所以我相信问题出在应用程序本身。我错过了一些小而愚蠢的东西吗?没有抛出错误,但服务器永远不会识别连接。提前感谢您的任何建议或帮助。
相关 Java(主要活动和必要的 AsyncTask):
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == 1001) {
if (resultCode == RESULT_OK) {
ArrayList<String> textMatchList = data.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);
if (!textMatchList.isEmpty()) {
String topMatch = textMatchList.get(0);
PostTask pt = new PostTask();
pt.execute(topMatch);
}
}
}
}
private class PostTask extends AsyncTask<String, String, String> {
@Override
protected String doInBackground(String... data) {
try {
URL url = new URL("http://<ip address>:3000");
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setReadTimeout(10000);
conn.setConnectTimeout(15000);
conn.setRequestMethod("POST");
conn.setDoOutput(true);
ContentValues values = new ContentValues();
values.put("data", data[0]);
OutputStream os = conn.getOutputStream();
BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(os, "UTF-8"));
StringBuilder sb = new StringBuilder();
sb.append(URLEncoder.encode("data", "UTF-8"));
sb.append("=");
sb.append(URLEncoder.encode(data[0], "UTF-8"));
writer.write(sb.toString());
writer.flush();
writer.close();
os.close();
conn.connect();
return "Text sent: " + data[0];
} catch (IOException e) {
e.printStackTrace();
return "LOL NOPE";
}
}
}
服务器 JS:
var http = require('http');
const PORT=3000;
function handleRequest(request, response){
response.end('It Works!! Path Hit: ' + request.url);
console.log("Request got.");
}
var server = http.createServer(handleRequest);
server.listen(PORT, '0.0.0.0');
console.log("Listening on 3000...");
【问题讨论】:
-
用这个 chrome 应用 chrome.google.com/webstore/detail/advanced-rest-client/… 试试你的帖子,看看你的 nodejs 服务器响应
-
响应了200码,返回的响应和浏览器一样。我什至不关心数据传输,我只希望应用程序命中的服务器注册。
-
你想访问本地主机吗?来自模拟器还是设备?
标签: java android node.js http post