[Update]Netty支持传输byte[]并封装使用
This commit is contained in:
@@ -0,0 +1,256 @@
|
||||
package com.mogo.telematic;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.net.nsd.NsdServiceInfo;
|
||||
import android.util.Log;
|
||||
|
||||
import com.mogo.telematic.client.NettyTcpClient;
|
||||
import com.mogo.telematic.client.NsdClient;
|
||||
import com.mogo.telematic.client.listener.MessageStateListener;
|
||||
import com.mogo.telematic.client.listener.NettyClientListener;
|
||||
import com.mogo.telematic.server.NSDServer;
|
||||
import com.mogo.telematic.server.NettyServerService;
|
||||
import com.mogo.telematic.server.bean.ClientChanel;
|
||||
import com.mogo.telematic.server.netty.NettyServerListener;
|
||||
import com.mogo.telematic.server.netty.NettyTcpServer;
|
||||
|
||||
import io.netty.channel.Channel;
|
||||
import io.netty.channel.ChannelFutureListener;
|
||||
|
||||
|
||||
public class NSDNettyManager {
|
||||
|
||||
private static final String TAG = "NSDNettyManager";
|
||||
|
||||
private volatile static NSDNettyManager sInstance;
|
||||
// client端用来过滤的
|
||||
public static final String SERVER_NAME = "NSD_SERVER";
|
||||
private NSDServer mNsdServer;
|
||||
private NettyTcpClient mNettyTcpClient;
|
||||
private NsdClient mNsdClient;
|
||||
private Context mContext;
|
||||
private NettyServerListener mListener;
|
||||
|
||||
private NSDNettyManager() {
|
||||
}
|
||||
|
||||
public static NSDNettyManager getInstance() {
|
||||
if (sInstance == null) {
|
||||
synchronized (NSDNettyManager.class) {
|
||||
if (sInstance == null) {
|
||||
sInstance = new NSDNettyManager();
|
||||
}
|
||||
}
|
||||
}
|
||||
return sInstance;
|
||||
}
|
||||
|
||||
private NettyServerListener mDefaultListener = new NettyServerListener() {
|
||||
@Override
|
||||
public void onMessageResponseServer(Object msg, String ChannelId) {
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onStartServer() {
|
||||
registerNsdServer();
|
||||
if (mListener != null) {
|
||||
mListener.onStartServer();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onStopServer() {
|
||||
if (mNsdServer != null) {
|
||||
mNsdServer.stopNSDServer();
|
||||
}
|
||||
if (mListener != null) {
|
||||
mListener.onStopServer();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onChannelConnect(Channel channel) {
|
||||
if (mListener != null) {
|
||||
mListener.onChannelConnect(channel);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onChannelDisConnect(Channel channel) {
|
||||
if (mListener != null) {
|
||||
mListener.onChannelDisConnect(channel);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* 启动Netty和NSD服务的Server端
|
||||
* @param context
|
||||
* @param listener
|
||||
*/
|
||||
public void startNSDNettyServer(Context context, NettyServerListener listener) {
|
||||
if (context == null) {
|
||||
throw new RuntimeException("Context must not be null!");
|
||||
} else {
|
||||
mContext = context;
|
||||
}
|
||||
mListener = listener;
|
||||
NettyTcpServer nettyTcpServer = NettyTcpServer.getInstance();
|
||||
if (!nettyTcpServer.isServerStart()) {
|
||||
nettyTcpServer.setListener(mDefaultListener);
|
||||
nettyTcpServer.start();
|
||||
} else {
|
||||
NettyTcpServer.getInstance().disconnect();
|
||||
}
|
||||
}
|
||||
|
||||
public boolean isServerStart() {
|
||||
return NettyTcpServer.getInstance().isServerStart();
|
||||
}
|
||||
|
||||
public void sendByteArrayToClient(byte[] byteArray, ChannelFutureListener listener) {
|
||||
NettyTcpServer.getInstance().sendMsgToClient(byteArray, listener);
|
||||
}
|
||||
|
||||
/**
|
||||
* 服务器端注册一个可供NSD探测到的网络 Ip 地址,便于给展示叫号机连接此socket
|
||||
*/
|
||||
private Runnable mNsdServerRunnable = new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
if (mNsdServer == null) {
|
||||
mNsdServer = new NSDServer();
|
||||
}
|
||||
mNsdServer.startNSDServer(mContext, NettyTcpServer.SERVER_NAME, NettyTcpServer.SERVER_PORT);
|
||||
|
||||
mNsdServer.setRegisterState(new NSDServer.IRegisterState() {
|
||||
@Override
|
||||
public void onServiceRegistered(NsdServiceInfo serviceInfo) {
|
||||
Log.i(TAG, "已注册服务onServiceRegistered: " + serviceInfo.toString());
|
||||
//已经注册可停止该服务
|
||||
// nsdServer.stopNSDServer();
|
||||
}
|
||||
@Override
|
||||
public void onRegistrationFailed(NsdServiceInfo serviceInfo, int errorCode) {
|
||||
|
||||
}
|
||||
@Override
|
||||
public void onServiceUnregistered(NsdServiceInfo serviceInfo) {
|
||||
|
||||
}
|
||||
@Override
|
||||
public void onUnRegistrationFailed(NsdServiceInfo serviceInfo, int errorCode) {
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
private void registerNsdServer() {
|
||||
new Thread(mNsdServerRunnable).start();
|
||||
}
|
||||
|
||||
/**
|
||||
* 选择连接的Client端的channel
|
||||
* @param channel
|
||||
*/
|
||||
public void selectChannel(Channel channel) {
|
||||
NettyTcpServer.getInstance().selectorChannel(channel);
|
||||
}
|
||||
|
||||
/**
|
||||
* 搜索并连接Netty服务端
|
||||
* @param context
|
||||
*/
|
||||
public void searchAndConnectServer(Context context, NettyClientListener listener) {
|
||||
if (mNsdClient == null) {
|
||||
mNsdClient = new NsdClient(context, SERVER_NAME, new NsdClient.IServerFound() {
|
||||
@Override
|
||||
public void onServerFound(NsdServiceInfo info, int port) {
|
||||
if (info != null) {
|
||||
String hostAddress = info.getHost().getHostAddress();
|
||||
Log.d(TAG, "NSD查询到指定服务器信息ip为:" + hostAddress + ",port为:" + port);
|
||||
//获取到指定的地址,进行Netty的连接
|
||||
connectNettyServer(hostAddress, port, listener);
|
||||
|
||||
if (info.getServiceName().equals(SERVER_NAME)) {
|
||||
//扫描到以后停止
|
||||
mNsdClient.stopServiceDiscovery();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onServerFail() {
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
mNsdClient.startNSDClient();
|
||||
}
|
||||
|
||||
private void connectNettyServer(String serverAddress, int port, NettyClientListener listener) {
|
||||
Log.d(TAG, "connectNettyServer");
|
||||
if (serverAddress == null || serverAddress.length() == 0) {
|
||||
Log.e(TAG, "Netty Server的ip不能为空!");
|
||||
return;
|
||||
}
|
||||
if (mNettyTcpClient == null) {
|
||||
mNettyTcpClient = new NettyTcpClient.Builder()
|
||||
.setHost(serverAddress) //设置服务端地址
|
||||
.setTcpPort(port) //设置服务端端口号
|
||||
.setMaxReconnectTimes(5) //设置最大重连次数
|
||||
.setReconnectIntervalTime(5) //设置重连间隔时间。单位:秒
|
||||
.setSendHeartBeat(true) //设置是否发送心跳
|
||||
.setHeartBeatInterval(5) //设置心跳间隔时间。单位:秒
|
||||
.setHeartBeatData(new byte[]{0x00, 0x00, 0x00, 0x00}) //设置心跳数据,可以是String类型,也可以是byte[],以后设置的为准
|
||||
.setIndex(0) //设置客户端标识.(因为可能存在多个tcp连接)
|
||||
// .setPacketSeparator("#")//用特殊字符,作为分隔符,解决粘包问题,默认是用换行符作为分隔符
|
||||
// .setMaxPacketLong(1024)//设置一次发送数据的最大长度,默认是1024,最大值为Integer.MAX
|
||||
.build();
|
||||
if (listener != null) {
|
||||
mNettyTcpClient.setListener(listener); //设置TCP监听
|
||||
}
|
||||
}
|
||||
|
||||
if (!mNettyTcpClient.getConnectStatus()) {
|
||||
mNettyTcpClient.connect();//连接服务器
|
||||
} else {
|
||||
mNettyTcpClient.disconnect();
|
||||
}
|
||||
}
|
||||
|
||||
public boolean getConnectStatus() {
|
||||
return mNettyTcpClient.getConnectStatus();
|
||||
}
|
||||
|
||||
/**
|
||||
* 发送byte[]到服务端
|
||||
* @param byteArray
|
||||
* @param listener
|
||||
*/
|
||||
public void sendByteArrayToServer(byte[] byteArray, final MessageStateListener listener) {
|
||||
if (mNettyTcpClient != null) {
|
||||
mNettyTcpClient.sendMsgToServer(byteArray, listener);
|
||||
}
|
||||
}
|
||||
|
||||
public static String bytesToHexFun(byte[] bytes, int length) {
|
||||
StringBuilder buf = new StringBuilder(length * 2);
|
||||
for (int i = 0; i < length; i++) {// 使用String的format方法进行转换
|
||||
buf.append(String.format("%02x", new Integer(bytes[i] & 0xFF)));
|
||||
}
|
||||
return buf.toString();
|
||||
}
|
||||
|
||||
/**
|
||||
* 断开Netty连接
|
||||
*/
|
||||
public void disconnect() {
|
||||
if (mNettyTcpClient != null) {
|
||||
mNettyTcpClient.disconnect();
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user