Java中另一个重要技术就是网络编程了,为了更好的学习web方向的知识,有必要对java之网络编程好好学习,本文将围绕网络编程技术进行分析。

常见的网络协议:UDP、TCP

UDP

1、 将数据源和目的封装为数据包,不需要建立连接

2、每个数据包大小在64K内

3、因为面向无连接,所以不可靠(丢失数据)

4、不需要连接,速度快

常见的UDP:聊天、视频会议、桌面共享等等

TCP

1、 建立连接,形成传输数据的通道

2、在连接中进行大量数据的传输

3、通过三次握手完成连接,是可靠协议

4、必须建立连接,效率会相对较低

Socket

Socket就是为网络服务的一种机制,通信两段都有socket,网络通信其实就是socket间的通信。数据自练个socket间通过IO传输。

UDP建立连接步骤

需求:通过UDP传输方式,将一段文字发送出去,另一端进行接受并打印

思路:

发送端:

1、建立UDP socket服务

2、提供数据,将数据封装到数据包中

3、通过socket服务,将数据包发送出去

4、关闭资源

接受端:

1、定义UDP socket服务,通常会监听一个端口,方便与明确该应用程序处理的对象。

2、定义一个数据包,以便于存储接收到数据,数据包对象中提供了更多操作接收数据处理的方法

3、通过socket服务的receive方法,将接收到的数据包存于已定义的数据包中。

4、通过数据对象特有的功能将这些不同的数据取出,并进行后续的处理

5、关闭资源

具体步骤:

发送端:

1、创建UDP服务,通过DatagramSocket对象

DatagramSocket ds =new DatagramSocket();

2、确定数据并封装成数据包

DatagramPacket dp=new DatagramPacket(buf,buf.length,InetAdress,port)

3、通过socket服务,将已经封包的数据进行发送

ds.senf(dp)

4、关闭资源

ds.close();

接收端:

1、创建UDP socket,建立端点(指明监听的端口)

DatagramSocket ds =new DatagramSocket(100010);

2、 定义数据包用于存储接受进来的数据

Byte []by=new byte[1024];

DatagramPacket dp=new DatagramPacket(by,by.length);

3、通过服务的receive方法接受数据,并存于到已定义的数据包中

ds.receive(dp);

4、通过数据包的特有方法去除取出其中的数据

String s=new String(dp.getData());

5、关闭资源

ds.close();

TCP建立连接步骤

需求:建立TCP链接,并传输一段数据到服务器,服务器接收数据并打印该数据

客户端

1、 建立服务端点,指明主机名以及端口号

Socket s=new Socket("127.0.0.1",10010);

2、读取客户端要传送的数据

byte []by="TCP I am coming".getBytes();

3、通过socket输出流将数据发给服务器

OutputStream out=s.getOutputStream();

out.wirte(by);

5、关闭资源

s.close();

服务端:

1、 建立服务端并指明监听端口

ServerSocket ss=new ServerSocker=t(10010);

2、开启服务,并接受数据

Scoket s=ss.accept();

3、读取接受到的数据,并封装成包(本例只是打印)

InputStream in=s.getInputStream();

int len=0;

byte by[]=new byte[1024];

len=in.read(by);

System.out.println(new String(by,0,len));

4、关闭资源

s.close();

案例分析:

    需求:编写一个UDP聊天程序:
            分析:

有接受数据的部分,和发数据的部分,这两部分需要同时执行,这就需要用到多线程了

发送端:

/*
* 编写一个聊天程序:
* 分析:
* 有接受数据的部分,和发数据的部分,这两部分需要同时执行,这就需要用到多线程了
* */
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;
import java.net.UnknownHostException;
import java.util.Scanner;
/*
* 发送端
*
* */
public class UDP_Send_03 implements Runnable{
private DatagramSocket ds;
UDP_Send_03(DatagramSocket ds){
this.ds=ds;
}
public void run() {
try {
ds=new DatagramSocket();
Scanner sc=new Scanner(System.in);
String line;
while((line=sc.nextLine())!=null){
if("886".equals(line))
break;
byte by[]=line.getBytes();
DatagramPacket dp=new DatagramPacket(by,by.length,InetAddress.getByName("127.0.0.1"),10110);
ds.send(dp);
}
} catch (SocketException e) {
e.printStackTrace();
} catch (UnknownHostException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
} }

接收端:

import java.io.IOException;
import java.net.*; /*
* 编写一个聊天程序:
*
* 接受端
* */
public class UDP_Rec_03 implements Runnable {
private DatagramSocket ds;
UDP_Rec_03(DatagramSocket ds){
this.ds=ds;
}
public void run() {
try {
ds=new DatagramSocket(10110); while(true){
byte by[]=new byte[1024]; DatagramPacket dp=new DatagramPacket(by,by.length);
ds.receive(dp);
String data=new String(dp.getData(),0,dp.getLength()); System.out.println(data);
}
} catch (SocketException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} }
//通过多线程的方式同时开启两个服务,这样就可以模拟聊天软件的环境进行交流了
public static void main(String[] args) throws SocketException {
DatagramSocket ds=new DatagramSocket();
UDP_Rec_03 rec=new UDP_Rec_03(ds);
UDP_Send_03 send=new UDP_Send_03(ds);
new Thread(rec).start();
new Thread(send).start(); }
}

案例2:编写一个基于TCP的程序,完成客户端向服务器发送一段文字,服务器接收到后返回一段文字,客户端打印反馈的信息

客户端:

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.Socket;
import java.net.UnknownHostException; /*
* 文件复制,需求:将客户端的文件发到服务端,进行磁盘存储
* */
public class CopyOfTCP_cli_04优化版 {
public static void main(String[] args) throws UnknownHostException, IOException {
Socket s=new Socket("127.0.0.1",10011);
//获取输出流,将字节转化为字符,可以一次写一行数据
PrintWriter pw=new PrintWriter(s.getOutputStream(),true);
//读取文件,用到了带缓冲的Reader,可以一次读取一行
BufferedReader br=new BufferedReader(new FileReader("E:\\a.txt"));
String line=null;
while((line=br.readLine())!=null){
pw.println(line);
}
//文件发送完成,需要发送一个结束标记 要格外注意
pw.println("over"); //或者使用s.shutdownOutput(); BufferedReader in=new BufferedReader(new InputStreamReader(s.getInputStream())); while((line=in.readLine())!=null)
{
System.out.println("服务器说:"+line);
}
br.close();
in.close();
pw.close();
s.close(); }
}

服务端:

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.ServerSocket;
import java.net.Socket; public class CopyOfTCP_ser_04优化版 {
public static void main(String[] args) throws IOException {
ServerSocket ss=new ServerSocket(10011); Socket s=ss.accept();
//接受客户端发送的文件,用到了缓冲,并且将字节流转化为了字符流
BufferedReader br =new BufferedReader(new InputStreamReader(s.getInputStream()));
//向文件中写数据,用到了缓冲,可以写一行
BufferedWriter bo=new BufferedWriter(new FileWriter("E:\\BB.txt"));
//向客户端写数据,用到了将字节流包装为Printwriter 从而可以将字节转化为字符串处理
PrintWriter out=new PrintWriter(s.getOutputStream(),true);
String line=null;
while((line=br.readLine())!=null){
if("over".equals(line))
break;
bo.write(line);
bo.newLine();
bo.flush();
}
out.println("文件收到");
out.flush();
s.close(); }
}

二十三、Java基础--------网络编程的更多相关文章

  1. java基础-网络编程(Socket)技术选型入门之NIO技术

    java基础-网络编程(Socket)技术选型入门之NIO技术 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.传统的网络编程 1>.编写socket通信的MyServer ...

  2. Java基础——网络编程(二)

    一.套接字 Socket 网络驱动程序提供给应用程序编程的接口和一种机制,可以比喻成一个港口码头 应用程序只要把货放在这,就算完成了货物的运送.它在应用程序中创建,通过一种绑定机制与驱动程序建立关系, ...

  3. Java基础——网络编程

    一.网络编程概述 概述: Java是 Internet 上的语言,它从语言级上提供了对网络应用程序的支持,程序员能够很容易开发常见的网络应用程序. Java提供的网络类库,可以实现无痛的网络连接,联网 ...

  4. java基础—网络编程

    一.网络基础概念 首先理清一个概念:网络编程 != 网站编程,网络编程现在一般称为TCP/IP编程.

  5. JAVA基础——网络编程之网络链接

    一.网络编程基本概念 1.OSI与TCP/IP体系模型 2.IP和端口 解决了文章最开始提到的定位的问题. IP在互联网中能唯一标识一台计算机,是每一台计算机的唯一标识(身份证):网络编程是和远程计算 ...

  6. Java基础——网络编程(一)

    本文主要记录网络编程的一些基础知识,学了前班部分,对专业术语有些蒙,但是,收货也是很多很多的.观察了自己计算机的进程,查找其他网络地址的IP,对互联网的层次关系有了更深一步的了解.下面多是概念的摘录, ...

  7. Java基础——网络编程(三)

    TCP 网络编程 -- tcp 分为客户端和服务端 -- 客户端对应的对象是 Socket -- 服务端对应的对象是 ServerSocket -- 如果客户端先启动,则出现 connection r ...

  8. 梦入IBM之java基础-网络编程

    如今我们来谈谈最后的内容:网络编程: 1):TCP中是线程与线程进行通讯!内部的执行机制是这种:先有一个线程去监听某个port.然后假设有Socket连接上来了以后,server会生成一个Socket ...

  9. Java基础-网络编程1

    网络编程 Socket 基本概念 C/S结构 :全称为Client/Server结构,是指客户端和服务器结构.常见程序有QQ.迅雷等软件. B/S结构 :全称为Browser/Server结构,是指浏 ...

随机推荐

  1. 【Alpha】Daily Scrum Meeting第八次

    一.本次Daily Scrum Meeting主要内容 抓紧冲刺(接下去两天都在下午增加一个小会议) 剩余任务的概况 二.项目进展 学号尾数 今日已完成任务 接下去要做 502 无 将数据库的数据转换 ...

  2. Oracle ITL(Interested Transaction List)理解

    ITL(Interested Transaction List) ITL是位于数据块头部的事物槽列表,它是由一系列的ITS(Interested Transaction Slot,事物槽)组成,其初始 ...

  3. swift 资料

    swift 开源代码学习 https://github.com/belm/BaiduFM-Swift http://www.cnblogs.com/zzc19920809/p/4881268.html ...

  4. https://blog.helong.info/blog/2015/03/13/jump_consistent_hash/

    转载请说明出处:http://blog.csdn.net/cywosp/article/details/23397179     一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希(DHT) ...

  5. 移动端rem 适配

    在 index.html 中添加如下代码 <script> let html = document.documentElement; window.rem = html.getBoundi ...

  6. 浅析“依赖注入(DI)/控制反转(IOC)”的实现思路

    开始学习Spring的时候,对依赖注入(DI)——也叫控制反转(IOC)—— 的理解不是很深刻.随着学习的深入,也逐渐有了自己的认识,在此记录,也希望能帮助其他入门同学更深入地理解Spring.本文不 ...

  7. 在命令行下使用perl

    http://blog.sina.com.cn/s/blog_4af3f0d20100g9oz.html aaa@domain.com  2aaa@domain.com 111bbb@home.com ...

  8. 枚举Enum

    #region 根据枚举名称获取值或反之        /// <summary>        /// 根据枚举的名称,得到该枚中该名称对应的值        /// </summ ...

  9. Java实现归并排序

    package Sort; import java.util.Arrays; public class MergeSort { public static void merge(int[] list, ...

  10. SSIS2012 项目部署模型

    SSIS 2012 支持两种部署模型:项目部署模型和包部署模型. 使用项目部署模型可以将项目部署到 Integration Services 服务器,使用包部署模型可以将单独的包部署到Integrat ...