mirror of
https://gitee.com/farsunset/cim.git
synced 2025-08-02 20:45:46 +08:00
Update CIMSession.java
This commit is contained in:
parent
4dcd82b8fb
commit
8f77898348
@ -5,6 +5,7 @@ import java.net.InetAddress;
|
|||||||
import java.net.SocketAddress;
|
import java.net.SocketAddress;
|
||||||
import java.net.UnknownHostException;
|
import java.net.UnknownHostException;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import org.apache.mina.core.future.WriteFuture;
|
import org.apache.mina.core.future.WriteFuture;
|
||||||
import org.apache.mina.core.session.IoSession;
|
import org.apache.mina.core.session.IoSession;
|
||||||
|
|
||||||
@ -18,25 +19,23 @@ import com.farsunset.cim.nio.constant.CIMConstant;
|
|||||||
|
|
||||||
public class CIMSession implements Serializable{
|
public class CIMSession implements Serializable{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
private static final long serialVersionUID = 1L;
|
private transient static final long serialVersionUID = 1L;
|
||||||
public static String ID = "ID";
|
public transient static String ID = "ID";
|
||||||
public static String HOST = "HOST";
|
public transient static String HOST = "HOST";
|
||||||
|
|
||||||
private IoSession session;
|
private transient IoSession session;
|
||||||
|
|
||||||
private String gid;//session全局ID
|
private String gid;//session全局ID
|
||||||
private Long nid;//session在本台服务器上的ID
|
private Long nid;//session在本台服务器上的ID
|
||||||
private String deviceId;//客户端设备ID
|
private String deviceId;//客户端ID (设备号码+应用包名)
|
||||||
private String host;//session绑定的服务器IP
|
private String host;//session绑定的服务器IP
|
||||||
private String account;//session绑定的账号
|
private String account;//session绑定的账号
|
||||||
private String channel;//终端设备类型
|
private String channel;//终端设备类型
|
||||||
private String deviceModel;//终端设备型号
|
private String deviceModel;//终端设备型号
|
||||||
|
|
||||||
private Long bindTime;//登录时间
|
private Long bindTime;//登录时间
|
||||||
|
|
||||||
private Long heartbeat;//心跳时间
|
private Long heartbeat;//心跳时间
|
||||||
|
|
||||||
public CIMSession(IoSession session) {
|
public CIMSession(IoSession session) {
|
||||||
@ -57,11 +56,9 @@ public class CIMSession implements Serializable{
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void setAccount(String account) {
|
public void setAccount(String account) {
|
||||||
if(session!=null)
|
|
||||||
{
|
|
||||||
session.setAttribute(CIMConstant.SESSION_KEY, account);
|
|
||||||
}
|
|
||||||
this.account = account;
|
this.account = account;
|
||||||
|
|
||||||
|
setAttribute(CIMConstant.SESSION_KEY, account);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -74,7 +71,10 @@ public class CIMSession implements Serializable{
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void setGid(String gid) {
|
public void setGid(String gid) {
|
||||||
|
|
||||||
this.gid = gid;
|
this.gid = gid;
|
||||||
|
|
||||||
|
setAttribute("gid", gid);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Long getNid() {
|
public Long getNid() {
|
||||||
@ -96,6 +96,8 @@ public class CIMSession implements Serializable{
|
|||||||
|
|
||||||
public void setChannel(String channel) {
|
public void setChannel(String channel) {
|
||||||
this.channel = channel;
|
this.channel = channel;
|
||||||
|
|
||||||
|
setAttribute("channel", channel);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getDeviceModel() {
|
public String getDeviceModel() {
|
||||||
@ -104,10 +106,14 @@ public class CIMSession implements Serializable{
|
|||||||
|
|
||||||
public void setDeviceModel(String deviceModel) {
|
public void setDeviceModel(String deviceModel) {
|
||||||
this.deviceModel = deviceModel;
|
this.deviceModel = deviceModel;
|
||||||
|
|
||||||
|
setAttribute("deviceModel", deviceModel);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setDeviceId(String deviceId) {
|
public void setDeviceId(String deviceId) {
|
||||||
this.deviceId = deviceId;
|
this.deviceId = deviceId;
|
||||||
|
|
||||||
|
setAttribute("deviceId", deviceId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -125,6 +131,7 @@ public class CIMSession implements Serializable{
|
|||||||
|
|
||||||
public void setBindTime(Long bindTime) {
|
public void setBindTime(Long bindTime) {
|
||||||
this.bindTime = bindTime;
|
this.bindTime = bindTime;
|
||||||
|
setAttribute("bindTime", bindTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Long getHeartbeat() {
|
public Long getHeartbeat() {
|
||||||
@ -133,14 +140,22 @@ public class CIMSession implements Serializable{
|
|||||||
|
|
||||||
public void setHeartbeat(Long heartbeat) {
|
public void setHeartbeat(Long heartbeat) {
|
||||||
this.heartbeat = heartbeat;
|
this.heartbeat = heartbeat;
|
||||||
if(session!=null)
|
setAttribute(CIMConstant.HEARTBEAT_KEY, heartbeat);
|
||||||
{
|
|
||||||
session.setAttribute(CIMConstant.HEARTBEAT_KEY, heartbeat);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setHost(String host) {
|
public void setHost(String host) {
|
||||||
this.host = host;
|
this.host = host;
|
||||||
|
|
||||||
|
setAttribute("host", host);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void setIoSession(IoSession session) {
|
||||||
|
this.session = session;
|
||||||
|
}
|
||||||
|
|
||||||
|
public IoSession getIoSession() {
|
||||||
|
return session;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -195,7 +210,7 @@ public class CIMSession implements Serializable{
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
String ip = InetAddress.getLocalHost().getHostAddress();
|
String ip = InetAddress.getLocalHost().getHostAddress();
|
||||||
return ip.equals(host) && session!=null;
|
return ip.equals(host);
|
||||||
} catch (UnknownHostException e) {
|
} catch (UnknownHostException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
@ -215,29 +230,14 @@ public class CIMSession implements Serializable{
|
|||||||
if (o instanceof CIMSession) {
|
if (o instanceof CIMSession) {
|
||||||
|
|
||||||
CIMSession t = (CIMSession) o;
|
CIMSession t = (CIMSession) o;
|
||||||
if(!t.isLocalhost())
|
if(t.deviceId!=null && deviceId!=null && t.nid!=null && nid!=null)
|
||||||
{
|
{
|
||||||
return false;
|
return t.deviceId.equals(deviceId) && t.nid.longValue()==nid.longValue() && t.host.equals(host);
|
||||||
}
|
}
|
||||||
if (t.session.getId() == session.getId()&& t.host.equals(host)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setIoSession(IoSession session) {
|
|
||||||
this.session = session;
|
|
||||||
}
|
|
||||||
|
|
||||||
public IoSession getIoSession() {
|
|
||||||
return session;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user