3. 请补充下面的Socket通信程序内容:

(1)Socket通信中的服务端程序:ChatServerSocket.java

package naizi;
import java.io.*;
import java.net.*;
public class ChatServerSocket{
private ChatJFrame chatframe; //聊天室的图形用户界面
private ServerSocket server;
private Socket client;
public ChatServerSocket(int port, String name) //约定端口号、网名
{
try {
server = new ServerSocket(port);
client = server.accept();//等待接收客户端的连接申请
BufferedReader cin = new BufferedReader(new InputStreamReader(client.getInputStream()));//获得字符输入流 PrintWriter cout = new PrintWriter(client.getOutputStream(), true);//获得字符输出流 chatframe = new ChatJFrame(name," 服务端端口"+port,cout); String aline = ""; do{ aline = cin.readLine();//从输入流接收数据(读取一行数据) if (aline!=null && !aline.equals("bye")) chatframe.receive(aline); }while (aline!=null && !aline.equals("bye")); chatframe.setWriter(null); cin.close(); cout.close(); client.close(); server.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}//创建服务端Socket对象
}
public static void main(String args[])
{
new ChatServerSocket(2018,"王奕"); //约定端口号,指定网名
}
}

(2)Socket通信中的客户端程序:ChatSocket.java

package naizi;
import java.io.*;
import java.net.*;
public class ChatSocket{
private ChatJFrame chatframe; //聊天室的图形用户界面
private Socket client;
public ChatSocket(String host, int port, String name) //主机名、端口号、网名
{ try {
client = new Socket(host,port);
BufferedReader cin = new BufferedReader(new InputStreamReader(client.getInputStream()));//获得字符输入流 PrintWriter cout = new PrintWriter(client.getOutputStream(),true);//获得字符输出流 chatframe = new ChatJFrame(name,"客户端主机"+host+" 端口"+port,cout); String aline = ""; do{ aline = cin.readLine(); if (aline!=null && !aline.equals("bye")) chatframe.receive(aline); }while (aline!=null && !aline.equals("bye")); chatframe.setWriter(null); cin.close(); cout.close(); client.close();
} catch (UnknownHostException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}//创建客户端Socket对象向服务端发出连接请求
}
public static void main(String args[])
{
new ChatSocket("localhost",2018,"阮磊"); //指定主机和端口号,指定网名
}
}

(3)聊天框的图形界面程序:ChatJFrame.java

package naizi;
import java.awt.event.*;
import javax.swing.*;
import java.io.*;
@SuppressWarnings("serial")
public class ChatJFrame extends JFrame implements ActionListener
{
private JTextArea text_receiver; //显示对话内容的文本区
private JTextField text_sender; //输入发送内容的文本行
private PrintWriter cout; //字符输出流对象
private String name; //网名 public ChatJFrame(String name, String title, PrintWriter cout) //构造方法
{
super("聊天室 "+name+" "+title);
this.setSize(320,240);
this.setLocation(300,240);
this.setDefaultCloseOperation(EXIT_ON_CLOSE); this.text_receiver = new JTextArea();
this.text_receiver.setEditable(false); //不可编辑
this.getContentPane().add(this.text_receiver); JPanel panel = new JPanel();
this.getContentPane().add(panel,"South");
this.text_sender = new JTextField(12);
panel.add(this.text_sender);
this.text_sender.addActionListener(this); //注册单击事件监听器
JButton button_send = new JButton("发送");
panel.add(button_send);
button_send.addActionListener(this);
JButton button_leave = new JButton("离线");
panel.add(button_leave);
button_leave.addActionListener(this);
this.setVisible(true);
this.setWriter(cout);
this.name = name;
} public ChatJFrame()
{
this("","",null);
}
public void setWriter(PrintWriter cout) //设置字符输出流对象
{
this.cout = cout;
}
public void receive(String message) //显示对方发来的内容
{
text_receiver.append(message+"\r\n");
} public void actionPerformed(ActionEvent e)
{
if (e.getActionCommand()=="离线")
{
if (this.cout!=null)
{
this.cout.println(name+"离线");
this.cout.println("bye");
this.cout = null;
}
text_receiver.append("我离线\n");
}
else //发送
{
if (this.cout!=null)
{
this.cout.println(name+" 说:"+text_sender.getText());
text_receiver.append("我说:"+text_sender.getText()+"\n");
text_sender.setText("");
}
else
text_receiver.append("已离线,不能再发送。\n");
}
}
public static void main(String args[])
{
new ChatJFrame();
}
}

程序运行结果如下展示:

Java第三次作业第三题的更多相关文章

  1. Java第三次作业第五题

    5. [问题描述]Fibonacci序列处理 从文件in.txt中读取第一个数作为Fibonacci数列的开始数n,读取第二个数,作为需要写入的数的个数m. 将从n开始的m个Fibonacci数列写入 ...

  2. Java第三次作业第四题

    4. [问题描述]读取一个文本文件in.txt,然后将这个文件的内容,反序写到另一个文件out.txt中. [输入形式]从文件in.txt中读信息. [输出形式]反序内容写入out.txt文件中. [ ...

  3. 2019寒假训练营第三次作业part2 - 实验题

    热身题 服务器正在运转着,也不知道这个技术可不可用,万一服务器被弄崩了,那损失可不小. 所以, 决定在虚拟机上试验一下,不小心弄坏了也没关系.需要在的电脑上装上虚拟机和linux系统 安装虚拟机(可参 ...

  4. 第三周作业(三)---WordCounter

    需求是这样的.写出一个程序,模仿wc.exe,可以统计出文件的一些信息(比如字符数.单词数目等等) 对于这个程序,我仍然用我从大一学来的C语言写的. 第一步:打开文件 printf("请输入 ...

  5. 第三周作业(三):wc程序

    本程序实现了统计文本档案中,文本单词数.字符数以及行数. 代码如下: #include<stdio.h> #include<stdlib.h> int linestatisti ...

  6. 第三周作业(三)WordCount

    这个程序主要就是统计一下文件中的字符数,单词数以及行数. 我的程序很简单,代码很简短,只实现了书中的基本功能. #include <stdio.h> #include <string ...

  7. 2019北航OO第三单元作业总结

    1.梳理JML语言的理论基础.应用工具链情况 JML基础理论: JML(Java Modeling Language)是用于对Java程序进行规格化设计的一种表示语言.JML是一种行为接口规格语言,基 ...

  8. OO第三单元作业(JML)总结

    OO第三单元作业(JML)总结 目录 OO第三单元作业(JML)总结 JML语言知识梳理 使用jml的目的 jml注释结构 jml表达式 方法规格 类型规格 SMT Solver 部署JMLUnitN ...

  9. OO第三次博客作业--第三单元总结

    一.JML 语言的理论基础及应用工具链 JML 是一种行为接口规格语言,提供了对方法和类型的规格定义手段.通过 JML 和其支持工具,不仅可以基于规格自动构造测试用例,并整合了 SMT Solver ...

随机推荐

  1. 12-Factor,构建原生软件应用方法论

    官方地址:https://12factor.net/zh_cn/ 原则1:一份基准代码,多份部署 这个原则不管对微服务模式还是其他软件开发模式来说都非常基本,所以被列为12原则的第一条,该原则包括如下 ...

  2. windows+appium自动化,Desired Capabilities参数填写,查看界面信息

    前言: 安装JDK并配置环境变量. 安装sdk并配置对应环境变量. 安装appium客户端. 手机打开开发者模式,并启用调试模式. 1.打开Appium客户端,点击Start Server V1.9. ...

  3. 字典更新与K-SVD

    字典更新与K-SVD 凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 1. 矩阵的奇异值分解 (Singular Value Decomposition, S ...

  4. 使用executor、callable以及一个Future 计算欧拉数e

    package test; import java.math.BigDecimal; import java.math.MathContext; import java.math.RoundingMo ...

  5. python webdriver 常用元素操作

    1.新建实例 xx_driver = os.path.abspath(r"路径") os.environ["webdriver.xx.driver"] = xx ...

  6. RabbitMQ简洁安装

    在实际开发过程中,为了解决并发量大的问题,我们往往会引入消息中间件这个杀手锏,今天带大家先入门一个消息中间件RabbitMQ,我们会从RabbitMQ安装.使用来分享. 1. RabbitMQ安装 这 ...

  7. yolo v2

    https://blog.csdn.net/wfei101/article/details/79398563 https://blog.csdn.net/oppo62258801/article/de ...

  8. HDU 2516

    题意略. 思路: 典型的斐波那契博弈,这里说一下结论: 如果先手面对的n不是斐波那契数,那么先手必胜:否则后手胜. 详见代码: #include<bits/stdc++.h> using ...

  9. linux安装redis详细步骤(系统centos 6.4 )

    1.安装redis 进入安装目录下载: cd  /usr/local/redis wget http://download.redis.io/releases/redis-3.0.7.tar.gz 解 ...

  10. Leetcode之二分法专题-852. 山脉数组的峰顶索引(Peak Index in a Mountain Array)

    Leetcode之二分法专题-852. 山脉数组的峰顶索引(Peak Index in a Mountain Array) 我们把符合下列属性的数组 A 称作山脉: A.length >= 3 ...