Java笔记--网络编程
1、IP地址:InetAddress类
--唯一的标识Internet上的计算机
--本地回环地址(hostAddress)127.0.0.1 主机名(hostName):localhost
//根据域名获取IP地址信息
InetAddress inet = InetAddress.getByName("localhost");
System.out.println(inet.getHostName());
System.out.println(inet.getHostAddress()); //获取本机IP地址
inet = InetAddress.getLocalHost();
System.out.println(inet);
2、端口号:标识正在计算机上运行的进程。
3、网络通信协议:计算机网络中实现通信必须有一些约定,即通信协议,对速率、传输代码、代码结构、传输控制步骤、出错控制等制定标准;
--传输层中的两个重要协议:1、传输控制协议TCP(Transmission Control Protocol); 2、用户数据报协议UDP(User DatagramProtocol)。4、网络套接字Socket:端口号与IP地址的组合。
--网络通信就是Socket间的通信,Socket允许程序把网络程序当成一个流,数据在两个Socket间通过IO传输。
--主动发起通信的应用程序成为客户端,等待通信请求的成为服务端。
4、Socket编程例子(TCP):
--Client:
public void client() {
Socket s = null;
OutputStream os = null;
InputStream is = null; try{
//1.创建一个Socket对象,通过构造器指明服务端的IP地址和接收程序的端口号
s = new Socket("127.0.0.1", 9090);
//2.getOutputStream获得OutputStream对象后发送数据
os = s.getOutputStream();
os.write("This is Client".getBytes());
//3.发送完毕之后关闭发送
s.shutdownOutput(); //4.getInoutStream获得InoutStream对象,接收服务器返回的数据
is = s.getInputStream();
byte[] b = new byte[20];
int len = 0;
while((len = is.read(b)) != -1){
System.out.println(new String(b, 0, len));
}
}catch(IOException e){
e.printStackTrace();
}finally{
//5.关闭相应的资源
if(is != null){
try {
is.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(os != null){
try {
os.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(s != null){
try {
s. close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
} }
--Server:
public void Server() {
ServerSocket ss = null;
Socket s = null;
InputStream is = null;
OutputStream os = null;
try{
ss = new ServerSocket(9090);
s = ss.accept();
is = s.getInputStream();
byte[] b = new byte[20];
int len = 0;
while((len = is.read(b)) != -1){
System.out.println(new String(b, 0, len));
} os = s.getOutputStream();
os.write("Accepted".getBytes());
}catch(IOException e){
e.printStackTrace();
}finally{
if(os != null){
try {
os.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(is != null){
try {
is.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(s != null){
try {
s. close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(ss != null){
try {
ss.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
5、类DatagramSocket和DataPacket实现了基于UDP协议的网络程序:
--UDP数据包通过数据报套接字DatagramSocket发送和接收,系统不保证UDP数据报一定能够安全送达目的地,也不确定什么时候可以到达;
--DatagramPacket类封装了UDP数据报,在数据报中包含了发送端的IP地址和端口号以及接收端的IP地址和端口号;
--UDP协议中每个数据报都给出了完整的地址信息,因此无须建立发送放与接收方的连接。
6、DatagramSocket编程(UDP):
--Client:
public void client() {
DatagramSocket ds = null;
try {
ds = new DatagramSocket(); byte[] b = "This is Client".getBytes();
DatagramPacket dp = new DatagramPacket(b, 0, b.length, InetAddress.getByName("127.0.0.1"), 8787); ds.send(dp);
}catch (IOException e) {
e.printStackTrace();
}finally{
ds.close();
}
}
--Server:
public void server(String[] args) {
DatagramSocket ds = null;
try {
ds = new DatagramSocket(8787); byte[] b = new byte[1024];
DatagramPacket dp = new DatagramPacket(b, 0, b.length); ds.receive(dp);
System.out.println(new String(b, 0, dp.getLength()));
}catch (IOException e) {
e.printStackTrace();
}finally{
ds.close();
}
}
7、URL编程(Uniform Resource Locator:统一资源定位符)
--构成:<传输协议>://<主机名>:端口号/<文件名>;
--URL类:一个URL对象对应着网络上的一个资源;
--URL类常用方法:1)public String getProtocol();//获取该URL的协议
2)public String getHost();//获取该URL的主机名
3)public String getPort();//获取该URL的端口号
4)public String getPath();//获取该URL的文件路径
5)public String getFile();//获取文件名
6)public String getRef();//获取文件的相对位置
7)public String getQuery();//获取该URL的查询名
--URL的openStream()方法能够从网络上读取数据。
8、URLConnection:表示URL所引用的远程对象的连接:
--UrlConnection urlConnection = url.openConnection();
--InputStream is = urlConnection.getInputStream();//输入流
--OutputStream os = urlConnection.getOutputStream();//输出流
Java笔记--网络编程的更多相关文章
- Netty | 第1章 Java NIO 网络编程《Netty In Action》
目录 前言 1. Java 网络编程 1.1 Javs NIO 基本介绍 1.2 缓冲区 Buffer 1.2 通道 Channel 1.3 选择器 Selector 1.4 NIO 非阻塞网络编程原 ...
- 二十三、Java基础--------网络编程
Java中另一个重要技术就是网络编程了,为了更好的学习web方向的知识,有必要对java之网络编程好好学习,本文将围绕网络编程技术进行分析. 常见的网络协议:UDP.TCP UDP 1. 将数据源和目 ...
- JAVA的网络编程
网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能,但是很多的初学者却因为很长一段时间无法进入网络编程的大门而放弃了对于该部分技术的学习. 在 学习网络编程以前,很多初学者可能觉得网络编 ...
- Java Socket 网络编程心跳设计概念
Java Socket 网络编程心跳设计概念 1.一般是用来判断对方(设备,进程或其它网元)是否正常动行,一 般采用定时发送简单的通讯包,如果在指定时间段内未收到对方响应,则判断对方已经当掉.用于 ...
- 20145325张梓靖 实验五 "JAVA的网络编程"
20145325张梓靖 实验五 "JAVA的网络编程" 实验内容 使用 JVAV语言 进行网络编程 对明文进行加密 设计过程 我完成的是客户端,服务端同伴 20145308刘昊阳 ...
- 【转】JAVA之网络编程
转自:火之光 网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能,但是很多的初学者却因为很长一段时间无法进入网络编程的大门而放弃了对于该部分技术的学习. 在 学习网络编程以前,很多初学者 ...
- JAVA的网络编程【转】
JAVA的网络编程[转] Posted on 2009-12-03 18:04 火之光 阅读(93441) 评论(20) 编辑 收藏 网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能, ...
- Java面向对象 网络编程 下
Java面向对象 网络编程 下 知识概要: (1)Tcp 练习 (2)客户端向服务端上传一个图片. (3) 请求登陆 (4)url 需求:上传图片. 客户端: ...
- Java面向对象 网络编程 上
Java面向对象 网络编程 上 知识概要: (1)网络模型 (2)网络通讯要素 (3)UDP TCP 概念 (4)Socket (5)UDP TCP 传输 ...
随机推荐
- 折腾前端条形码(Barcode)扫描识别, 笔记
barcode @zxing/library 方案 本地勉强把 Demo 在 React 里面跑通, 但是不好控制开始结束, API 不明确.实际识别率很低. 我是用手机屏幕放的条形码, 大概也有影响 ...
- Tomcat服务更新流程:
Tomcat服务更新流程: 1.把需要更新的war包放在服务器/servers/tomcat9/update下.2.负载均衡服务上把要更新的服务器权重值调为0,即服务不转在这台要更新的服务器上.(重要 ...
- XML规范化(DTD)
无意义的XML 之前说过因为xml没有预设的标签,所以说你怎麽写他一般都不会报错. 所以需要对xml的书写格式进行一些限制,这就引入了DTD 下面的这个xml你可以给book添加各种属性还不会报错,但 ...
- 「SDOI2013」森林
「SDOI2013」森林 传送门 树上主席树 + 启发式合并 锻炼码力,没什么好说的. 细节见代码. 参考代码: #include <algorithm> #include <cst ...
- 137、Java内部类之把内部类放到外部
01.代码如下: package TIANPAN; class Outer { // 外部类 private String msg = "Hello World !"; publi ...
- 123、Java面向对象之引用传递实例一
01.代码如下: package TIANPAN; class Message { private int num = 10; // 定义int基本类型的属性 public Message(int n ...
- 利用Python进行数据分析笔记-时间序列(时区、周期、频率)
此文对Python中时期.时间戳.时区处理等阐述十分清楚,特别值得推荐学习. 原文链接:https://blog.csdn.net/wuzlun/article/details/80287517
- CentOS安装后的第一步:配置IP地址
有关于centos7获取IP地址的方法主要有两种,1:动态获取ip:2:设置静态IP地址 在配置网络之前我们先要知道centos的网卡名称是什么,centos7不再使用ifconfig命令,可通过命令 ...
- C. Gas Pipeline DP
C. Gas Pipeline time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...
- display:flex下子元素宽度无效
在子元素上设置: width:60px; flex-shrink:0;