Java - TCP网络编程

Server

逻辑思路:

  1. 创建ServerSocket(port),然后服务器的socket就启动了
  2. 循环中调用accept(),此方法会堵塞程序,直到发现用户请求,返回用户的socket
  3. 利用多线程对用户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

逻辑思路:

  1. 创建Socket(IP, port),其参数为目标服务器的IP和port
  2. 然后就可以通过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网络编程的更多相关文章

  1. JAVA TCP网络编程学习笔记

    一.JAVA网络编程概述 网络应用程序,就是在已实现网络互联的不同计算机上运行的应用程序,这些程序之间可以相互交换数据.JAVA是优秀的网络编程语言,Java网络编程的类库位于java.net包中.J ...

  2. 二十三、Java基础--------网络编程

    Java中另一个重要技术就是网络编程了,为了更好的学习web方向的知识,有必要对java之网络编程好好学习,本文将围绕网络编程技术进行分析. 常见的网络协议:UDP.TCP UDP 1. 将数据源和目 ...

  3. JAVA的网络编程

    网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能,但是很多的初学者却因为很长一段时间无法进入网络编程的大门而放弃了对于该部分技术的学习. 在 学习网络编程以前,很多初学者可能觉得网络编 ...

  4. Java Socket 网络编程心跳设计概念

    Java Socket 网络编程心跳设计概念   1.一般是用来判断对方(设备,进程或其它网元)是否正常动行,一 般采用定时发送简单的通讯包,如果在指定时间段内未收到对方响应,则判断对方已经当掉.用于 ...

  5. 【转】JAVA之网络编程

    转自:火之光 网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能,但是很多的初学者却因为很长一段时间无法进入网络编程的大门而放弃了对于该部分技术的学习. 在 学习网络编程以前,很多初学者 ...

  6. JAVA的网络编程【转】

    JAVA的网络编程[转] Posted on 2009-12-03 18:04 火之光 阅读(93441) 评论(20) 编辑 收藏 网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能, ...

  7. Java面向对象 网络编程 下

    Java面向对象 网络编程  下 知识概要:                   (1)Tcp 练习 (2)客户端向服务端上传一个图片. (3) 请求登陆 (4)url 需求:上传图片. 客户端:   ...

  8. Java面向对象 网络编程 上

     Java面向对象 网络编程 上 知识概要:                     (1)网络模型 (2)网络通讯要素 (3)UDP TCP 概念 (4)Socket (5)UDP TCP 传输 ...

  9. TCP网络编程

    TCP网络编程  与UDP不同的是TCP是通过客服端和服务端的方式来传输数据的.客服端:public class TCPClient { /**     * @param args     * @th ...

随机推荐

  1. 模板—splay

    #include<iostream> #include<cstdio> #define cin(x) scanf("%d",&x) using na ...

  2. 「 CODE[VS] P2853 」 方格游戏

    题目大意 给定一张 $n\times n$ 的网格.每个格子上都有一个系数 $a$,先下 $A$ 和 $B$ 两人选择两条 $(1,1)\rightarrow (n,n)$ 路径.要求着两条路径不能相 ...

  3. CCF201604-1 折点计数 java(100分)

    试题编号: 201604-1 试题名称: 折点计数 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 给定n个整数表示一个商店连续n天的销售量.如果某天之前销售量在增长,而后一天 ...

  4. 九度oj 题目1066:字符串排序

    题目1066:字符串排序 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:6487 解决:2670 题目描述: 输入一个长度不超过20的字符串,对所输入的字符串,按照ASCII码的大小从小到 ...

  5. mysql 5.5与5.6 timestamp 字段 DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP的区别

    http://www.111cn.net/database/mysql/55392.htm 本文章来给各位同学介绍关于mysql 5.5与5.6 timestamp 字段 DEFAULT CURREN ...

  6. Codeforces Round #232 (Div. 2) On Sum of Fractions

    Let's assume that v(n) is the largest prime number, that does not exceed n; u(n) is the smallest pri ...

  7. codevs1001 舒适的线路

    题目描述 Description Z小镇是一个景色宜人的地方,吸引来自各地的观光客来此旅游观光.Z小镇附近共有N(1<N≤500)个景点(编号为1,2,3,…,N),这些景点被M(0<M≤ ...

  8. Linux下使用tcpdump进行抓包(转)

    技巧: 1.可以通过tcpdump抓取某个网卡的包,然后输出日志文件,通过Wireshark进行分析. 2.可以设置Wifi热点,然后通过手机连接这个热点,然后进行tcpdump的分析.而且在Ubun ...

  9. 17、Java并发性和多线程-避免死锁

    以下内容转自http://ifeve.com/deadlock-prevention/: 在有些情况下死锁是可以避免的.本文将展示三种用于避免死锁的技术: 加锁顺序 当多个线程需要相同的一些锁,但是按 ...

  10. JAVA 并发编程-线程池(七)

    线程池的作用: 线程池作用就是限制系统中运行线程的数量. 依据系统的环境情况.能够自己主动或手动设置线程数量,达到运行的最佳效果:少了浪费了系统资源,多了造成系统拥挤效率不高.用线程池控制线程数量,其 ...