12.6-全栈Java笔记:Java网络编程(四)

上节回顾:在学习了Socket建立客户端和服务器双向交流后,我们发现它的问答形式不够灵活。

本节课我们讲解如何在服务器和客户端之间实现聊天室~

需要思考的问题:

服务器端:一个线程专门发送消息,一个线程专门接收消息。

客户端:一个线程专门发送消息,一个线程专门接收消息。

除了消化这段代码外,还需要思考,怎么实现一个聊天室!(难度较大!!)

【示例1】聊天室服务器端


import java.io.BufferedReader;

import java.io.BufferedWriter;

import java.io.IOException;

import java.io.InputStreamReader;

import java.io.OutputStreamWriter;

import java.net.ServerSocket;

import java.net.Socket;

public class ChatServer {

public static void main(String[]   args)  {

ServerSocket server=null;

Socket socket=null;

BufferedReader in=null;

try {

server = new ServerSocket(8888);

socket=server.accept();

new ServerThread(socket).start();

//main线程负责读取客户端发来的信息

in=new BufferedReader(new   InputStreamReader(socket.getInputStream()));

while(true){

String str=in.readLine();

System.out.println("客户端说:"+str);

}

catch (IOException e) {

e.printStackTrace();

}finally{

try {

in.close();

catch (IOException e) {

e.printStackTrace();

}

try {

socket.close();

catch (IOException e) {

e.printStackTrace();

}

}

}

}

/**

专门向客户端发送消息的线程

@author Administrator

*

*/

class ServerThread extends Thread {

Socket ss;

BufferedWriter out;

BufferedReader br;

public ServerThread(Socket ss){

this.ss = ss;

try {

out=new BufferedWriter(new   OutputStreamWriter(ss.getOutputStream()));

br = new BufferedReader(new   InputStreamReader(System.in));

catch (IOException e) {

e.printStackTrace();

}

}

public void run(){

try {

while(true){

String str2 = br.readLine();

out.write(str2+"\n");

out.flush();

}

catch (IOException e) {

e.printStackTrace();

}finally{

try {

out.close();

catch (IOException e) {

e.printStackTrace();

}

try {

br.close();

catch (IOException e) {

e.printStackTrace();

}

}

}

}

 

【示例2】聊天室客户端


import java.io.BufferedReader;

import java.io.BufferedWriter;

import java.io.IOException;

import java.io.InputStreamReader;

import java.io.OutputStreamWriter;

import java.net.InetAddress;

import java.net.Socket;

import java.net.UnknownHostException;

public class ChatClient {

public static void main(String[] args) {

Socket  socket = null;

BufferedReader in = null;

try {

socket=new Socket(InetAddress.getByName("192.168.1.32"),8888);

new ClientThread(socket).start();

in=new BufferedReader(new   InputStreamReader(socket.getInputStream()));

//main线程负责接收服务器发来的信息

while(true){

System.out.println("服务器说:"+in.readLine());

}

catch (UnknownHostException e) {

e.printStackTrace();

catch (IOException e) {

e.printStackTrace();

}finally{

try {

socket.close();

catch (IOException e) {

e.printStackTrace();

}

try {

in.close();

catch (IOException e) {

e.printStackTrace();

}

}

}

}

/**

* 用于向服务器发送消息

@author Administrator

*

*/

class ClientThread extends Thread{

Socket s;

BufferedWriter out;

BufferedReader wt;

public ClientThread(Socket s){

this.s = s;

try {

out=new BufferedWriter(new   OutputStreamWriter(s.getOutputStream()));

wt=new BufferedReader(new   InputStreamReader(System.in));

catch (IOException e) {

e.printStackTrace();

}

}

public void run(){

try {

while(true){

String str = wt.readLine();

out.write(str+"\n" );

out.flush();

}

catch (IOException e) {

e.printStackTrace();

}finally{

try {

wt.close();

catch (IOException e) {

e.printStackTrace();

}

try {

out.close();

catch (IOException e) {

e.printStackTrace();

}

}

}

}



「全栈Java笔记」是一部能帮大家从零到一成长为全栈Java工程师系列笔记。笔者江湖人称 Mr. G,10年Java研发经验,曾在神州数码、航天院某所研发中心从事软件设计及研发工作,从小白逐渐做到工程师、高级工程师、架构师。精通Java平台软件开发,精通JAVAEE,熟悉各种流行开发框架。

 笔记包含从浅入深的六大部分:

A-Java入门阶段

B-数据库从入门到精通

C-手刃移动前端和Web前端

D-J2EE从了解到实战

E-Java高级框架精解

F-Linux和Hadoop

时间: 2024-07-31 11:31:33

12.6-全栈Java笔记:Java网络编程(四)的相关文章

Java笔记(9)-网络编程

不必说碧绿的菜畦,光滑的石井栏,高大的皂荚树,紫红的桑葚:也不必说鸣蝉在树叶里长吟,肥胖的黄蜂伏在菜花上,轻捷的叫天子(云雀)忽然从草间直窜向云霄里去了. 鲁迅 -–<从百草味到三味书屋> ---- [TOC] Java网络编程 URL 类 URL统一资源定位符 一个URL对象通常包含最基本的3部分信息:协议,地址,资源. 示例 用字节流读取流输入流中的数据时,由于汉字是两个字节,如果读取的长度不合适,就会有乱码,可以指定编码格式解决,增加一次读取的数据也可以解决, 用字符流也可以 中文乱码问

Java高并发网络编程(四)Netty

在网络应用开发的过程中,直接使用JDK提供的NIO的API,比较繁琐,而且想要进行性能提升,还需要结合多线程技术. 由于网络编程本身的复杂性,以及JDK API开发的使用难度较高,所以在开源社区中,涌现出来了很多对JDK NIO进行封装.增强的网络编程框架,比如Netty.Mina等. 一.Netty简介 https://netty.io/ 官网 Netty是一个高性能.高可扩展性的异步事件驱动的网络应用程序框架,它极大简化了TCP和UDP客户端和服务器开发等网络编程. Netty重要的四个内容

39.Python全栈之路:网络编程

socket socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字"向网络发出请求或者应答网络请求.      

我的全栈之路-Java架构师技术栈

我的全栈之路-Java架构师技术栈 我的全栈之路 JavaSE篇 Java概述与开发环境搭建 Java数据存储 Java数据计算 Java程序流程控制 Java数组 Java面向对象程序设计(上) Java面向对象程序设计(中) Java面向对象程序设计(下) Java常用API 集合 泛型 异常处理 注解 IO/BIO/NIO AIO网络框架tio设计与实现 多线程 网络编程 反射和动态代理 日志 XML 正则表达式 Java语言新特性实践 数据库编程(JDBC+MySQL) 数据结构 算法

我的全栈之路-Java基础之数据存储

我的全栈之路-Java基础之数据存储 我的全栈之路 2.1 标识符 标识符是在程序开发时给包,类.接口.注解,变量,方法命名的字符序列. 标识符在命名时需要遵守相关的规则和规范: 标识符的命名规则: 标识符不能是Java的关键字和保留字,关键字是Java中被赋予赋予特殊含义的单词,例如public static void等等.保留字是现有Java版本尚未使用,但是未来的Java版本可能会做关键字使用的单词,例如goto,const.但是可以包含关键字,保留字. 标识符可以由字母.数字.下划线组成

我的全栈之路-Java基础之macOS+Visual Studio Code开发Java程序

我的全栈之路-Java基础之macOS+Visual Studio Code开发Java程序 我的全栈之路 3.1 开发环境说明 首先说明下使用软件的版本,操作系统是基于macOS10.14.5,然后在macOS上安装了JDK11.03,如果想要了解macOS下JDK的安装,可以参考我的全栈之路-Java基础之macOS安装JDK,编辑器选用了微软公司开源的Visual Studio Code. 软件名称 软件版本 操作系统 macOS10.14.5 JDK JDK11.0.3 编辑器 Visu

Java学习之网络编程实例

转自:http://www.cnblogs.com/springcsc/archive/2009/12/03/1616413.html 多谢分享 网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能,但是很多的初学者却因为很长一段时间无法进入网络编程的大门而放弃了对于该部分技术的学习. 在学习网络编程以前,很多初学者可能觉得网络编程是比较复杂的系统工程,需要了解很多和网络相关的基础知识,其实这些都不是很必需的.首先来问一个问题:你 会打手机吗?很多人可能说肯定会啊,不就是按按电话号码

JAVA笔记26-网络编程(不等于网站编程)

一.网络基础(TCP/IP详解) 1.IP协议(Internet Protocol):网络层,支持网间数据报通信.无连接数据报传送,数据报路由选择和差错控制. IPv4 32位(4字节),IPv6 128位(16字节).P ping ICMP协议 2.TCP协议.UDP协议 (1)TCP(transmission control protocol 打电话):专门设计用于在不可靠的因特网上提供可靠的.端到端的字节流通信的协议.它是一种面向连接的协议.有三次握手.慢 (2)UDP(user data

黑马程序员————java中的网络编程

------<a href="http://www.itheima.com" target="blank">Java培训.Android培训.iOS培训..Net培训</a>.期待与您交流! ------- java中的网络编程 一.网络编程概述:基于互联网的编程 就是用来实现网络互连的不同计算机上运行的程序间可以进行数据交换. 二.网络模型:OSI和TCP/IP 1.OSI(Open System Interconnection开放系统互连

第62节:探索Java中的网络编程技术

前言 感谢! 承蒙关照~ 探索Java中的网络编程技术 网络编程就是io技术和网络技术的结合,网络模型的定义,只要共用网络模型就可以两者连接.网络模型参考. 一座塔有七层,我们需要闯关. 第一层物理层->第二层数据链路层->第三层网络层->第四层传输层->第五层会话层->第六层表示层->第七层应用层. 物理层是主要定义物理设备标准,数据链路层是主要讲从物理层接收的数据进行MAC地址(网卡的地址)的封装与解封装.这层的数据较帧. 网络层是将从下层接收到的数据进行IP地址的