我有一个使用socket.io和Android应用程序的Node.js服务器。我希望我的应用程序连接到服务器。 (我在当地工作)
首先我启动服务器: command prompt
以下是代码:
var express = require('express'); // call express
var app = express();
var http = require('http').Server(app);
var io = require('socket.io')(http);
var port = process.env.PORT || 1234;
app.get('/',function(req,res){
res.send("Welcome to my socket");
});
io.on('connection', function (socket) {
console.log('one user connected : '+socket.id);
// when the client emits 'new message', this listens and executes
socket.on('new message', function (data) {
// we tell the client to execute 'new message'
console.log('this is message :',data);
});
});
http.listen(port, function () {
console.log('Server listening at port %d', port);
});
然后我尝试连接我的活动:
public class AvisActivity extends AppCompatActivity {
private Socket mSocket;
{
try {
mSocket = IO.socket("http://172.21.191.234:1234");
} catch (URISyntaxException e) { Log.v("AvisActivity", "error connecting to socket");}
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_avis);
Log.v("AvisActivity", "try to connect");
mSocket.connect();
Log.v("AvisActivity", "connection sucessful");
}
}
我的问题是我从未在服务器上看到“一个用户连接”的日志,但我总是在android日志中看到“尝试连接”和“连接成功”。
有人可以为我解开这个谜团吗?
更新
我的代码工作得很好,但我遇到了阻止网络套接字的一些Wifi配置(实际上我的学校做了,这就是我的问题来自哪里)
答案 0 :(得分:2)
您的代码很好,它运行正常,您只需确认您正在连接的IP地址是正确的,并且还在manifest.xml中添加了INTERNET权限
<uses-permission android:name="android.permission.INTERNET"/>
答案 1 :(得分:2)
对于其他在Google上搜索的人,这有助于我获得有关此问题的一些日志信息:
Log.v("AvisActivity", "try to connect");
mSocket.connect();
mSocket.io().on(Manager.EVENT_TRANSPORT, new Emitter.Listener() {
@Override
public void call(Object... args) {
Transport transport = (Transport) args[0];
transport.on(Transport.EVENT_ERROR, new Emitter.Listener() {
@Override
public void call(Object... args) {
Exception e = (Exception) args[0];
Log.e(TAG, "Transport error " + e);
e.printStackTrace();
e.getCause().printStackTrace();
}
});
}
});
对我来说,问题是客户端不会使用TLSv1.1或1.2。在写这篇文章时我还没想出来。使我的服务器支持TLSv1.0是我目前的解决方法。
答案 2 :(得分:1)
在最新版本的Android中,您需要添加AndroidManifest.xml“ android:usesCleartextTraffic = true”以允许使用纯文本进行连接。
示例:
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme"
android:usesCleartextTraffic="true">
答案 3 :(得分:1)
对于API 23及更高版本,您必须在清单文件中添加android:usesCleartextTraffic="true"
。
答案 4 :(得分:0)
将套接字初始化代码放在onCreate
方法中,如下所示:
public class AvisActivity extends AppCompatActivity {
private Socket mSocket;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_avis);
try {
mSocket = IO.socket("http://172.21.191.234:1234");
}
catch (URISyntaxException e) {
Log.v("AvisActivity", "error connecting to socket");
}
Log.v("AvisActivity", "try to connect");
mSocket.connect();
Log.v("AvisActivity", "connection sucessful");
}
}
答案 5 :(得分:0)
<强>更新强>
我的代码工作得很好,但是我遇到了阻止网络套接字的一些Wifi配置(实际上我的学校做了,这就是我的问题来自哪里)。但我真的不知道他们是怎么阻止它的。
此外,在我的项目后期部署到OVH服务器时,我遇到了使用1234端口的问题。请务必使用提供商提供/解锁的端口。
答案 6 :(得分:0)
看看这个答案,用这一行对我有用:
opts.transsports = new String[]{"websocket"};