Java - TCP网络编程
Java - TCP网络编程
Server
逻辑思路:
- 创建ServerSocket(port),然后服务器的socket就启动了
- 循环中调用accept(),此方法会堵塞程序,直到发现用户请求,返回用户的socket
- 利用多线程对用户socket进行IO操作
注意:对Scoket/File进行创建、关闭,都需要放try catch中,检测 IOException,所以将网络IO部分整体放入try catch中即可。
1. 字符串操作
输出:PrintWriter out=new PrintWriter(sock.getOutputStream(), true);
读取:BufferedReader in=new BufferedReader(new InputStreamReader(sock.getInputStream()));
或者:Scanner input=new Scanner(sock.getInputStream());
2. 字节操作(一般用于传输文件,体积大,要求效率高,用BufferedInputStream/BufferedOutputStream)
输出:BufferedOutputStream out=new BufferedOutputStream(sock.getOutputStream());
输出:BufferedInputStream out=new BufferedInputStream(sock.getInputStream());
import java.io.*;
import java.net.*; public class TCP_Server { public static void main(String[] args){ int port=8888; try {
ServerSocket sock=new ServerSocket(port);
System.out.println("服务器启动,Port:"+sock.getLocalPort());
while(true){
Socket client=sock.accept(); //***注意,accept()是个阻塞函数,返回client socket***
System.out.println("监测到TCP连接来自:"+client.getRemoteSocketAddress());
new WorkThread(client).start(); //多线程
}
}
catch (IOException e) {
System.out.println("ERROR Found: "+e.getMessage());
}
//end try catch }
} class WorkThread extends Thread{ Socket sock;
public WorkThread(Socket sock){
this.sock=sock;
} public void run(){
try{
//此处用BufferedReader实现
BufferedReader in=new BufferedReader(new InputStreamReader(sock.getInputStream()));
PrintWriter out=new PrintWriter(sock.getOutputStream(),true); String s=null;
while((s=in.readLine())!=null){ //断开会返回null
if(s.equals("end"))
break;
System.out.println("收到:"+s);
out.println("Server:"+s);
} /*注意,readLine()是个阻塞函数,放在while((s=readLine())!=null)中会堵塞程序,等待用户的数据。
*有两种方式中断循环
*1.用户端断开TCP程序,in.readLine()会返回null
*2.用户正常退出,用户端发送个[结束标记]给服务器,服务器根据标记,中断循环
*/
System.out.println("监测到TCP连接来自:"+sock.getRemoteSocketAddress()+"已断开。"); in.close();
out.close();
sock.close();
}
catch(IOException e){
System.out.println(e.getMessage());
}
} }
Client
逻辑思路:
- 创建Socket(IP, port),其参数为目标服务器的IP和port
- 然后就可以通过Socket进行IO操作了
import java.net.*;
import java.io.*;
import java.util.*; public class TCP_Client { public static void main(String[] args) { Scanner in=new Scanner(System.in); try{ int port=8888;
String ip="127.0.0.1"; Socket sock=new Socket(ip, port); //从socket中输出
PrintWriter out=new PrintWriter(sock.getOutputStream(),true);
//从socket中读取,此处用Scanner实现
Scanner input=new Scanner(sock.getInputStream()); while(true){
System.out.print("请输入消息:");
String s=in.nextLine();
if(s.equals("end")){
out.println(s);
break;
} out.println(s);
System.out.println("发送:"+s);
s=input.nextLine();
System.out.println("收到:"+s);
} in.close();
input.close();
out.close();
sock.close();
}
catch (IOException e){
System.out.println("ERROR Found: "+e.getMessage());
} } }
Java - TCP网络编程的更多相关文章
- JAVA TCP网络编程学习笔记
一.JAVA网络编程概述 网络应用程序,就是在已实现网络互联的不同计算机上运行的应用程序,这些程序之间可以相互交换数据.JAVA是优秀的网络编程语言,Java网络编程的类库位于java.net包中.J ...
- 二十三、Java基础--------网络编程
Java中另一个重要技术就是网络编程了,为了更好的学习web方向的知识,有必要对java之网络编程好好学习,本文将围绕网络编程技术进行分析. 常见的网络协议:UDP.TCP UDP 1. 将数据源和目 ...
- JAVA的网络编程
网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能,但是很多的初学者却因为很长一段时间无法进入网络编程的大门而放弃了对于该部分技术的学习. 在 学习网络编程以前,很多初学者可能觉得网络编 ...
- Java Socket 网络编程心跳设计概念
Java Socket 网络编程心跳设计概念 1.一般是用来判断对方(设备,进程或其它网元)是否正常动行,一 般采用定时发送简单的通讯包,如果在指定时间段内未收到对方响应,则判断对方已经当掉.用于 ...
- 【转】JAVA之网络编程
转自:火之光 网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能,但是很多的初学者却因为很长一段时间无法进入网络编程的大门而放弃了对于该部分技术的学习. 在 学习网络编程以前,很多初学者 ...
- JAVA的网络编程【转】
JAVA的网络编程[转] Posted on 2009-12-03 18:04 火之光 阅读(93441) 评论(20) 编辑 收藏 网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能, ...
- Java面向对象 网络编程 下
Java面向对象 网络编程 下 知识概要: (1)Tcp 练习 (2)客户端向服务端上传一个图片. (3) 请求登陆 (4)url 需求:上传图片. 客户端: ...
- Java面向对象 网络编程 上
Java面向对象 网络编程 上 知识概要: (1)网络模型 (2)网络通讯要素 (3)UDP TCP 概念 (4)Socket (5)UDP TCP 传输 ...
- TCP网络编程
TCP网络编程 与UDP不同的是TCP是通过客服端和服务端的方式来传输数据的.客服端:public class TCPClient { /** * @param args * @th ...
随机推荐
- buf.writeUIntBE()函数详解
buf.writeUIntBE(value, offset, byteLength[, noAssert]) buf.writeUIntLE(value, offset, byteLength[, n ...
- 解决window 10 安装软件2503 2502错误
1.首先打开任务管理器,可以通过右键点击桌面上的任务栏打开任务管理器,也可以通过同时按下键盘上的Ctrl+Alt+Delete键打开任务管理器. 2.打开任务管理器后,切换到“详细信息”选项卡,找到e ...
- java 十四周总结
- 基于服务器版centos7的Hadoop/spark搭建
前提说明: 1.Hadoop与spark是两个独立的框架,只安装spark也可独立运行,spark有自己的调度器(standalone模式): 2.在Hadoop的基础上安装spark就是为了使用ya ...
- ubuntu_linux自动补全出现问题
问题:输入: cd p,使用Tab补全,期望进入pub_work目录,虽然自动补全,成功进入目录:却给我打印一连串的字符,纠结: fly@Flyme:~$ cd p+ local cur prev w ...
- Python基础(八)装饰器
今天我们来介绍一下可以提升python代码逼格的东西——装饰器.在学习装饰器之前我们先来复习一下函数的几个小点,方便更好的理解装饰器的含义. 一.知识点复习 1, 在函数中f1和f1()有什么不同,f ...
- java多线程synchronized volatile解析
先简单说说原子性:具有原子性的操作被称为原子操作.原子操作在操作完毕之前不会线程调度器中断.即一个操作或者多个操作 要么全部执行并且执行的过程不会被任何因素打断,要么就都不执行.在Java中,对除了l ...
- PhantomJS & headless browser & pdf
PhantomJS http://phantomjs.org/ https://github.com/Medium/phantomjs https://github.com/Medium/phanto ...
- image url to base64
image url to base64 https://www.base64-image.de/ https://www.browserling.com/tools/image-to-base64 h ...
- Portal嵌入SAPUI5应用程序
Embedding SAPUI5 Applications You can embed SAPUI5 applications directly into the SAP Fiori launchpa ...