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. 二:Go编程语言规范-类型

    1.类型 布尔值,数值与字符串类型的实例的命名是预声明的. 数组,结构,指针,函数,接口,切片,映射和信道这些复合类型可由类型字面构造. 每个类型 T 都有一个 基本类型:若 T 为预声明类型或类型字 ...

  2. [转]CISP(注册信息安全专业人员)认证(12天)

    本文转自:http://www.topsec.com.cn/shpx/rzpx/pxkc/cisp/index.htm CISP(注册信息安全专业人员)认证(11天) 中国信息安全产品测评认证中心(C ...

  3. Vim插件管理——Vundle

    Vim插件管理--Vundle 都说Vim时程序员写给自己的编辑器,其中的情结可想而知.身为一只程序狗CodingDoge,今天就让我带各位学习Vim的使用. vim因为其庞大而强劲的插件受到无比的推 ...

  4. HDU4003Find Metal Mineral[树形DP 分组背包]

    Find Metal Mineral Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65768/65768 K (Java/Other ...

  5. 使用 React.js 的渐进式 Web 应用程序:第 1 部分 - 介绍

      使用 React.js 的渐进式 Web 应用程序:第 1 部分 - 介绍 使用 React.js 的渐进式 Web 应用程序:第 1 部分 - 介绍 来自译者 markzhai:大家也知道最近 ...

  6. 创建简单的机器人模型smartcar

    前面我们使用的是已有的机器人模型进行仿真,这一节我们将建立一个简单的智能车机器人 smartcar,为后面建立复杂机器人打下基础. 一.创建硬件描述包. cd ~/catkin_ws/srcroscr ...

  7. java 22 - 20 多线程之线程池

    程序启动一个新线程成本是比较高的,因为它涉及到要与操作系统进行交互. 而使用线程池可以很好的提高性能,尤其是当程序中要创建大量生存期很短的线程时,更应该考虑使用线程池. 线程池里的每一个线程代码结束后 ...

  8. poj2531 Network Saboteur

    Network Saboteur Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 11122   Accepted: 5372 ...

  9. HTML5网站如何做到完全不需要jQuery

    jQuery是现在最流行的JavaScript工具库. 据统计,目前全世界57.3%的网站使用它.也就是说,10个网站里面,有6个使用jQuery.如果只考察使用工具库的网站,这个比例就会上升到惊人的 ...

  10. C# 根据正则表达式来判断输入的是不是数字

    最近在做输入判断的时候出现了一个需要判断输入合法性的问题,就是判断输入的是不是数字,判断方法是根据正则表达式来判断,具体方法如下: private bool IsRightNum(string str ...