package server;
import java.nio.channels.SelectionKey;
import java.nio.channels.SocketChannel;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Scanner;
import java.util.Set;
import common.Message;
import common.MessageType;
import common.SocketResource;
import common.SocketUtilForMessage;
import common.SystemMessage;
import common.SystemOrderType;
import common.TextMessage;
import common.UserInfoMessage;
public class ServerSocketForMessage extends SocketInServer {
private SocketUtilForMessage util;
private Map<String,Integer> userMap;
@Override
public boolean startSocket(int port) {
util = new SocketUtilForMessage();
userMap = new HashMap<String, Integer>();
return super.startSocket(port);
}
@Override
public void doRead(SelectionKey key) {
SocketChannel socketChannel = (SocketChannel)key.channel();
Message message = util.readMessage(socketChannel);
if(message == null){
//System.out.println(" 关闭连接通道");
this.closeChannel(socketChannel);
return;
}
//遍历所有已连接socket,注册写事件
/*this.stringForSending = str;
Collection<SocketChannel> collection = this.getSocketChannelMap().values();
Iterator<SocketChannel> iterator = collection.iterator();
while(iterator.hasNext()){
SocketChannel sChannel = iterator.next();
//iterator.remove();
if(sChannel == socketChannel) continue;
sChannel.keyFor(this.getSelector()).interestOps(SelectionKey.OP_WRITE);
}*/
handleMessage(message,socketChannel);
System.out.println(" 信息接受完毕");
}
@Override
public void doWrite(SelectionKey key) {
SocketChannel socketChannel = (SocketChannel)key.channel();
if(key.attachment() != null){
Message message = (Message)key.attachment();
Integer size = util.writeMessage(socketChannel, message);
if(size == null){
//System.out.println(" 关闭连接通道");
this.closeChannel(socketChannel);
return;
}
System.out.println();
key.attach(null);
}
List<Message> messageList = SocketResource.getSocketResource(socketChannel.hashCode()).getMessageList();
Iterator<Message> iterator = messageList.iterator();
while(iterator.hasNext()){
Message message = iterator.next();
iterator.remove();
Integer size = util.writeMessage(socketChannel, message);
if(size == null){
//System.out.println(" 关闭连接通道");
this.closeChannel(socketChannel);
return;
}
System.out.println();
}
key.interestOps(SelectionKey.OP_READ);
System.out.println(" 信息发送完毕");
}
public void handleMessage(Message message,SocketChannel socketChannel){
if(message.getMessageType() == MessageType.UserInfoMessage){
UserInfoMessage userInfoMessage = (UserInfoMessage)message;
System.out.print("用户名:"+userInfoMessage.getAddresser()+",密码:"+userInfoMessage.getPassword()
+",请求验证...");
if(checkUser(userInfoMessage.getAddresser(),userInfoMessage.getPassword())){
System.out.println(" 请求通过");
//添加用户到在线用户表,创建资源区,注册写事件,附加系统信息
userMap.put(userInfoMessage.getAddresser(), socketChannel.hashCode());
SocketResource socketResource = SocketResource.newResourceInstance(socketChannel);
socketResource.setUsername(userInfoMessage.getAddresser());
socketResource.setPassword(userInfoMessage.getPassword());
socketChannel.keyFor(this.getSelector()).interestOps(SelectionKey.OP_WRITE).attach(new SystemMessage(SystemOrderType.ConnectionPermitted));
}else{
//注册写事件,附加系统信息
System.out.println(" 拒绝请求");
//this.getSocketChannelMap().remove(socketChannel);
//this.closeChannel(socketChannel);
socketChannel.keyFor(this.getSelector()).interestOps(SelectionKey.OP_WRITE).attach(new SystemMessage(SystemOrderType.ConnectionRefused));
}
}else if(message.getMessageType() == MessageType.TextMessage){
TextMessage textMessage = (TextMessage)message;
System.out.print(" 消息内容为\""+textMessage.getTextContent()+"\" ");
if(textMessage.isPrivate()){
String recipient = textMessage.getRecipient();
if(userMap.get(recipient) != null){
Integer socketChannelId = userMap.get(recipient);
SocketResource socketResource = SocketResource.getSocketResource(socketChannelId);
socketResource.getSocketChannel().keyFor(this.getSelector()).interestOps(SelectionKey.OP_WRITE);
socketResource.getMessageList().add(textMessage);
}else{
this.persistMessage(textMessage);
}
}else{
//getUserSet(textMessage.getRecipient());
//临时测试,所有在线用户充当组员
Collection<Integer> keys = userMap.values();
Iterator<Integer> iterator = keys.iterator();
while(iterator.hasNext()){
Integer key = iterator.next();
SocketResource socketResource = SocketResource.getSocketResource(key);
socketResource.getSocketChannel().keyFor(this.getSelector()).interestOps(SelectionKey.OP_WRITE);
socketResource.getMessageList().add(textMessage);
}
}
}else{
//待开发消息类型
}
}
public boolean checkUser(String username,String password){
//用户登录验证,待开发
return true;
}
public void persistMessage(Message message){
//持久化消息,待开发
}
public Set<String> getUserSet(String userGroup){
//根据组名拿到组员集,待开发
return null;
}
public static void main(String[] args){
final ServerSocketForMessage server = new ServerSocketForMessage();
if(!server.startSocket(7788)) return;
new Thread(new Runnable() {
@Override
public void run() {
server.handleOPS();
}
}).start();
Scanner scanner = new Scanner(System.in);
while(scanner.hasNext()){
String str = scanner.next() + "<系统消息>";
SystemMessage systemMessage = new SystemMessage(str);
//Collection<SocketChannel> collection = server.getSocketChannelMap().values();
Collection<Integer> keys = server.userMap.values();
Iterator<Integer> iterator = keys.iterator();
while(iterator.hasNext()){
Integer key = iterator.next();
SocketResource socketResource = SocketResource.getSocketResource(key);
systemMessage.setRecipient(socketResource.getUsername());
socketResource.getSocketChannel().keyFor(server.getSelector()).interestOps(SelectionKey.OP_WRITE);
socketResource.getMessageList().add(systemMessage);
}
}
}
}
没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
收起资源包目录
SocketApp3.rar (39个子文件)
SocketApp3
src
client
SocketForMessage.java 4KB
SocketInClient.java 3KB
SocketForString.java 2KB
server
SocketInServer.java 4KB
ServerSocketForString.java 2KB
ServerSocketForMessage.java 6KB
common
SocketUtil.java 2KB
SocketResource.java 2KB
SystemMessage.java 819B
SystemOrderType.java 253B
Message.java 952B
MessageType.java 171B
UserInfoMessage.java 523B
TextMessage.java 606B
SocketUtilForString.java 888B
SocketUtilForMessage.java 2KB
bin
client
SocketForMessage$1.class 637B
SocketInClient.class 3KB
SocketForString$1.class 631B
SocketForString.class 3KB
SocketForMessage.class 5KB
server
ServerSocketForString$1.class 667B
ServerSocketForString.class 4KB
SocketInServer.class 5KB
ServerSocketForMessage$1.class 673B
ServerSocketForMessage.class 7KB
common
MessageType.class 241B
SocketUtilForString.class 2KB
SocketUtil.class 2KB
TextMessage.class 884B
SystemMessage.class 1KB
SocketResource.class 3KB
SocketUtilForMessage.class 3KB
Message.class 1KB
UserInfoMessage.class 835B
SystemOrderType.class 258B
.classpath 301B
.settings
org.eclipse.jdt.core.prefs 629B
.project 386B
共 39 条
- 1
资源评论
ww1049292751
- 粉丝: 1
- 资源: 2
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 基于Python实现的自动化办公项目.zip
- 基于python实现的基于PyQt5和爬虫的小说阅读系统.zip
- 机械设计整经机上纱自动化sw20非常好的设计图纸100%好用.zip
- Screenshot_20240427_031602.jpg
- 网页PDF_2024年04月26日 23-46-14_QQ浏览器网页保存_QQ浏览器转格式(6).docx
- 直接插入排序,冒泡排序,直接选择排序.zip
- 在排序2的基础上,再次对快排进行优化,其次增加快排非递归,归并排序,归并排序非递归版.zip
- 实现了7种排序算法.三种复杂度排序.三种nlogn复杂度排序(堆排序,归并排序,快速排序)一种线性复杂度的排序.zip
- 冒泡排序 直接选择排序 直接插入排序 随机快速排序 归并排序 堆排序.zip
- 课设-内部排序算法比较 包括冒泡排序、直接插入排序、简单选择排序、快速排序、希尔排序、归并排序和堆排序.zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功