我目前尝试编写一个Android应用来设置和控制运行micropython的ESP8266。
在micropython服务器上,我像这样初始化一个websocket:
def __init__(self, task_manager, setup_mode):
address = socket.getaddrinfo('0.0.0.0', 80)[0][-1]
self._socket = socket.socket()
self._socket.bind(address)
self._socket.listen(1)
self._socket.setblocking(False)
self._socket.settimeout(5)
self._task_manager = task_manager
self._setup_mode = setup_mode
print('New Socket is listening on: ', address)
然后像这样简单地侦听传入的连接,然后对传入的消息做出反应。同样,列表被循环以允许微控制器逻辑每5秒更新一次。
client, address = self._socket.accept()
print("New request from:", address)
当我从PC上使用python发送测试请求时,一切正常。例如,一个简单的请求就是这样的:
data = json.dumps({'load': {'type': "is_lighthub", 'data': {}}})
response = requests.post(ip, json=data)
但是,当我尝试使用Android应用程序中的OkHttp发出相同的发布请求时,则ESP上没有传入连接。
这是android java代码:
private void addIfLighthub(final InetAddress address) {
try {
RequestBody body = RequestBody.create(JSON, "{\"load\": {\"type\": \"is_lighthub_server\", \"data\": {}}");
Request request = new Request.Builder()
.url("http://" + address.getHostAddress())
.post(body)
.build();
try (Response response = client.newCall(request).execute()) {
final JSONObject myResponse = new JSONObject(response.body().string());
if((boolean)myResponse.get("is_lighthub")) {
onlineDeviceList.add(address);
}
} catch (IOException e) {
System.out.println(e.getMessage());
}
} catch (JSONException jsonException) {
System.out.println(jsonException.getMessage());
}
}
然而,奇怪的是,该示例代码(例如提供了我的路由器的地址)确实收到了路由器的默认html站点...
那么,我想念什么吗?我刚刚接触网络,但是电话发出的简单发布请求应该与python示例代码中的请求相同,对吧?
还是我的java函数有错误?
谢谢你们的帮助!
答案 0 :(得分:0)
如果自己修复它! 错误是python测试客户端单独发送了json,而okhttp客户端则同时发送了两个。 这使得服务器在等待第二条消息时超时...