java丶网络编程
来源:互联网 发布:固定收益私募 知乎 编辑:程序博客网 时间:2024/06/10 07:54
Java 网络编程(参考菜鸟教程)
网络编程是指编写运行在多个设备(计算机)的程序,这些设备都通过网络连接起来。
java.net 包中 J2SE 的 API 包含有类和接口,它们提供低层次的通信细节。你可以直接使用这些类和接口,来专注于解决问题,而不用关注通信细节。
java.net 包中提供了两种常见的网络协议的支持:
TCP:TCP 是传输控制协议的缩写,它保障了两个应用程序之间的可靠通信。通常用于互联网协议,被称 TCP / IP。
UDP:UDP 是用户数据报协议的缩写,一个无连接的协议。提供了应用程序之间要发送的数据的数据包。
本教程主要讲解以下两个主题。
Socket 编程:这是使用最广泛的网络概念,它已被解释地非常详细。
URL 处理:这部分会在另外的篇幅里讲,点击这里更详细地了解在 Java 语言中的 URL 处理。
Socket 编程
套接字使用TCP提供了两台计算机之间的通信机制。 客户端程序创建一个套接字,并尝试连接服务器的套接字。
当连接建立时,服务器会创建一个 Socket 对象。客户端和服务器现在可以通过对 Socket 对象的写入和读取来进行进行通信。
java.net.Socket 类代表一个套接字,并且 java.net.ServerSocket 类为服务器程序提供了一种来监听客户端,并与他们建立连接的机制。
以下步骤在两台计算机之间使用套接字建立TCP连接时会出现:
服务器实例化一个 ServerSocket 对象,表示通过服务器上的端口通信。
服务器调用 ServerSocket 类的 accept() 方法,该方法将一直等待,直到客户端连接到服务器上给定的端口。
服务器正在等待时,一个客户端实例化一个 Socket 对象,指定服务器名称和端口号来请求连接。
Socket 类的构造函数试图将客户端连接到指定的服务器和端口号。如果通信被建立,则在客户端创建一个 Socket 对象能够与服务器进行通信。
在服务器端,accept() 方法返回服务器上一个新的 socket 引用,该 socket 连接到客户端的 socket。
连接建立后,通过使用 I/O 流在进行通信,每一个socket都有一个输出流和一个输入流,客户端的输出流连接到服务器端的输入流,而客户端的输入流连接到服务器端的输出流。
TCP 是一个双向的通信协议,因此数据可以通过两个数据流在同一时间发送.以下是一些类提供的一套完整的有用的方法来实现 socket。
服务端实例:
import java.io.DataInputStream;import java.io.DataOutputStream;import java.net.ServerSocket;import java.net.Socket;/** * * Created by Administrator on 2017/9/6. */public class ServerH extends Thread { private ServerSocket server; public ServerH() throws Exception{ server = new ServerSocket(6066); server.setSoTimeout(10000); } @Override public void run() { while (true){ try { System.out.println("wait:"+server.getLocalPort()+"...."); Socket socket = server.accept(); System.out.println("yuancheng adress"+socket.getRemoteSocketAddress()); DataInputStream dis = new DataInputStream(socket.getInputStream()); System.out.println(dis.readUTF()); DataOutputStream dos = new DataOutputStream(socket.getOutputStream()); dos.writeUTF("thank you:"+socket.getLocalSocketAddress()); socket.close(); }catch (Exception e){ System.out.println("not not not!"); e.printStackTrace(); break; } } } public static void main(String[] args) throws Exception{ Thread t = new ServerH(); t.run(); }}
客户端实例:
import java.io.DataInputStream;import java.io.DataOutputStream;import java.io.InputStream;import java.io.OutputStream;import java.net.Socket;/** * Created by Administrator on 2017/9/6. */public class ClientH { public static void main(String[] args) throws Exception{ System.out.println("begin-------------"); Socket socket = new Socket("localhost",6066); System.out.println("yuancheng-adress---"+socket.getRemoteSocketAddress()); OutputStream os = socket.getOutputStream(); DataOutputStream dos = new DataOutputStream(os); dos.writeUTF("hello---"+socket.getLocalSocketAddress()); InputStream is = socket.getInputStream(); DataInputStream dis = new DataInputStream(is); System.out.println("end------"+dis.readUTF()); socket.close(); }}
执行操作,打开两个命令窗口编译两个类:
先执行ServerH.java,使Server.java进入等待状态等待连接,
再执行ClientH.java,使ClientH.java连接正在等待的服务器端。
1.执行java ServerH 后(进入等待)
2.当执行java ClientH后已连接。java ServerH等待结束。
- java丶网络编程
- 【网络编程】JAVA网络编程
- java网络编程:网络基本概念
- Java网络编程-UDP编程
- Java 高层网络编程
- Java网络编程2
- Java网络编程3
- Java网络编程4
- Java网络服务器编程
- java网络编程1
- java网络编程2
- JAVA网络编程
- Java网络服务器编程
- java网络编程
- Java 高层网络编程
- Java 高层网络编程
- Java网络服务器编程
- Java网络编程
- 常见浏览器兼容问题及解决方案分类汇总
- struts2拦截器简单介绍
- Android 框架 MVC、MVP、MVVM学习笔记
- mysql字符编码修改
- Thymeleaf简单介绍
- java丶网络编程
- JAVA开发Web Service几种框架介绍
- Spark性能优化——Java虚拟机垃圾回收调优
- 金蝶K3修改库存更新控制方式
- poj1062 昂贵的聘礼
- 运维参考题
- Redis中的哈希(Hash)
- 未能写入输出文件“CS0016: 未能写入输出文件“c:\Windows\Microsoft.NET\Framework64\v4.0.30319\Temporary ASP.NET Files\ro
- OpenDDS在windows下的安装教程(一)