1、客户端

  1.1:创建服务端点

  1.2:获取已有数据

  1.3:通过socket输出流将数据发送给服务端

  1.4:读取服务端反馈信息

  1.5:关闭socket

import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.Socket;
import java.net.UnknownHostException; public class TCPClient
{ static Socket socket;
public static void main(String[] args)
{
BufferedReader br = null;
BufferedInputStream bi = null;
BufferedOutputStream bo = null;
try
{
socket = new Socket("10.9.194.71", 8638);
bi = new BufferedInputStream(socket.getInputStream());
bo = new BufferedOutputStream(socket.getOutputStream()); br = new BufferedReader(new InputStreamReader(System.in));
String line = null;
while ((line = br.readLine()) != null)
{
bo.write(line.getBytes());
bo.flush();
if (line.equals("quit"))
{
bi.close();
bo.close();
br.close();
socket.close();
break;
}
byte[] buf = new byte[1024];
int len = bi.read(buf); System.out.println(new String(buf, 0, len));
} } catch (UnknownHostException e)
{
e.printStackTrace();
} catch (IOException e)
{
e.printStackTrace();
}
finally
{
try
{
if (bi != null)
bi.close();
if (br != null)
br.close();
if (bo != null)
bo.close();
if (socket != null)
socket.close();
} catch (IOException e)
{ e.printStackTrace();
}
}
} }

2、服务器

import java.io.IOException;
import java.net.ServerSocket; public class TCPServer
{
static int acount = 0; public static void main(String[] args)
{ try
{
ServerSocket serverSocket = new ServerSocket(8638);
while (true)
new Thread(new MultiClient(serverSocket.accept(), ++acount))
.start();
} catch (IOException e)
{
e.printStackTrace();
}
}
} import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.net.Socket;
import java.util.Date; public class MultiClient implements Runnable
{ private Socket client;
private int acount;
private BufferedInputStream bi = null;
private BufferedOutputStream bo = null; public MultiClient(Socket client, int acount)
{ this.client = client;
this.acount = acount;
} @Override
public void run()
{
try
{
Date start = new Date(); String recordStart = start + " :: "
+ client.getInetAddress().getHostAddress() + " :: 第"
+ acount + "用户成功连接";
System.out.println(recordStart);
WriteLog.writeLog(recordStart);
bi = new BufferedInputStream(client.getInputStream());
BufferedOutputStream bo = new BufferedOutputStream(
client.getOutputStream()); while (true)
{
byte[] buf = new byte[1024];
int len = bi.read(buf);
String info = new String(buf, 0, len);
System.out.println(info);
bo.write(("Has Receive:" + info).getBytes());
bo.flush();
if (info.equals("quit"))
break;
}
Date end = new Date(); String recordEnd = end + " :: "
+ client.getInetAddress().getHostAddress() + " :: 第"
+ acount + "用户退出连接";
System.out.println(recordEnd);
WriteLog.writeLog(recordEnd); } catch (Exception e)
{
e.printStackTrace();
} finally
{
try
{
if (bi != null)
bi.close();
if (bo != null)
bo.close();
if (client != null)
client.close();
} catch (IOException e)
{ e.printStackTrace();
}
}
}
} import java.io.File;
import java.io.FileWriter; public class WriteLog
{
public static void writeLog(String str)
{
File logFile = new File("server-log.txt");
try
{
FileWriter out = new FileWriter(logFile, true);
out.append(str + '\n');
out.close();
} catch (Exception e)
{
e.printStackTrace();
}
}
}

Java网络编程——TCP实例的更多相关文章

  1. java 网络编程-tcp/udp

    --转自:http://blog.csdn.net/nyzhl/article/details/1705039 直接把代码写在这里,解释看这里吧:http://blog.csdn.net/nyzhl/ ...

  2. java网络编程(TCP详解)

    网络编程详解-TCP 一,TCP协议的特点              面向连接的协议(有发送端就一定要有接收端)    通过三次连接握手建立连接 通过四次握手断开连接 基于IO流传输数据 传输数据大小 ...

  3. java网络编程TCP传输—流操作—拿到源后的写入动作

    在网络编程中的TCP传输里,拿到Socket的源后,应该怎么进行读写操作呢,下面我列举了两种方法,希望大家帮忙补充···· 1.利用byte数组作为一个缓冲区进行读写 客户端上传 //获取socket ...

  4. Java分享笔记:Java网络编程--TCP程序设计

    [1] TCP编程的主要步骤 客户端(client): 1.创建Socket对象,构造方法的形参列表中需要InetAddress类对象和int型值,用来指明对方的IP地址和端口号. 2.通过Socke ...

  5. JAVA网络编程TCP通信

    Socket简介: Socket称为"套接字",描述IP地址和端口.在Internet上的主机一般运行多个服务软件,同时提供几种服务,每种服务都打开一个Socket,并绑定在一个端 ...

  6. Java网络编程(TCP客户端)

    TCP传输:两个端点建立连接后会有一个传输数据的通道,这个通道就称为流,而且是建立在网络基础上的流,之为socket流,该流中既可以读取也可以写入. TCP的两个端点:一个客户端:ServerSock ...

  7. java网络编程—TCP(1)

    演示tcp的传输的客户端和服务端的互访. 需求:客户端给服务端发送数据,服务端收到后,给客户端反馈信息. 客户端: 1,建立socket服务.指定要连接主机和端口. 2,获取socket流中的输出流. ...

  8. Java网络编程(TCP服务端)

    /* * TCP服务端: * 1.创建服务端socket服务,并监听一个端口 * 2.服务端为了给客户端提供服务,获取客户端的内容,可以通过accept方法获取连接过来的客户端对象 * 3.可以通过获 ...

  9. JAVA网络编程-----TCP沟通

    java采纳TCP变速箱使用Socket和ServerSocket数据传输. 采纳tcp步模式数据传输: 1.设定client和服务器 ,分别对应Socket和ServerSocket 2.建立连接后 ...

随机推荐

  1. mysql 性能优化方案 (转)

    网 上有不少mysql 性能优化方案,不过,mysql的优化同sql server相比,更为麻烦与复杂,同样的设置,在不同的环境下 ,由于内存,访问量,读写频率,数据差异等等情况,可能会出现不同的结果 ...

  2. BI软件搞不定业务管理报表的需求

    BI是商业智能的缩写,是可以帮助企业做出明智的业务经营决策的工具,其数据来源于各个业务系统,如ERP.CRM.SCM.进销存.HER.OA等. BI系统不同于传统的管理信息系统,他号称是一个整体应用的 ...

  3. c++学习之容器细枝末节(1)

    对照着c++primier 开始学习第九章容器,把课后习题当做练习,虽然是看过书上的讲解,但是做题编程的时候,一些需要注意的地方还是难免有遗漏. 一下是几点印象比较深刻的总结: (1)前几章只学了ve ...

  4. SVN服务器&客户端的搭建和使用

    目录结构: 1. SVN服务器搭建和使用-VisualSVNServer 2. SVN客户端安装和使用-TortoiseSVN 3. TortoiseSVN使用方法 SVN简介 SVN是Subvers ...

  5. HDU 2516 取石子游戏

    Problem Description 1堆石子有n个,两人轮流取.先取者第1次可以取任意多个,但不能全部取完.以后每次取的石子数不能超过上次取子数的2倍.取完者胜.先取者负输出"Secon ...

  6. HDU1502/Luogu1352/UVa1220 party[树形DP]

    题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员都会增加一定的快乐指数Ri, ...

  7. Unity Ragdoll(布娃娃系统)

    逼真的动作如何实现的? 在一些游戏中当NPC或玩家死亡的时候,死亡的肢体动作十分逼真,这一物理现象如何用Unity来实现呢?Unity物理引擎中的Ragdoll系统,可以用来创建这种效果,具体请参阅以 ...

  8. vijos1059 积木城堡[n年浙江省队第X轮](背包的方案总数 or 01背包)

    描述 XC的儿子小XC最喜欢玩的游戏用积木垒漂亮的城堡.城堡是用一些立方体的积木垒成的,城堡的每一层是一块积木.小XC是一个比他爸爸XC还聪明的孩子,他发现垒城堡的时候,如果下面的积木比上面的积木大, ...

  9. css3属性选择器

  10. swift三方库

    链接: Swift 有哪些优秀的第三方库? Swift 中AFNetworking 的替代方案 Alamofire Swift2.0后Alamofire的使用方法 [快速学会Swift第三方库] Al ...