-1 本地 test tps 两种 write getproto ade
InetAddress类用于标识网络上的硬件资源,表示互联网协议(IP)地址。
- InetAddress.getLocalHost();//获取本地对象
- InetAddress.getByName("");//获取指定名称对象
主要方法使用:
- //获取本机的InetAddress实例
- InetAddress add = InetAddress.getLocalHost();
- System.out.println("本地计算机名称:" + add.getHostName());
- System.out.println("本地IP地址:" + add.getHostAddress());
- byte[] bytes = add.getAddress(); //获取字节数组形式的IP地址
- System.out.println("字节数组形式的IP地址:" + Arrays.toString(bytes));
- System.out.println(add);
- //根据机器名获取InetAddress实例
- InetAddress add2 = InetAddress.getByName("LAPTOP-CU3IL302");
- System.out.println("本地计算机名称:" + add2.getHostName());
- System.out.println("本地IP地址:" + add2.getHostAddress());
- //根据IP地址和机器名称获取InetAddress实例
- InetAddress add3 = InetAddress.getByAddress("LAPTOP-CU3IL302", bytes);
- System.out.println("本地计算机名称:" + add3.getHostName());
- System.out.println("本地IP地址:" + add3.getHostAddress());
运行结果:
结论:
1)概念
例如:https://www.cnblogs.com/是博客园的首页网址,其中http表示协议(超文本传输协议),后面的网址就是资源名称。
2)URL常用方法
在java.net中提供了URL类来表示URL。
URL常用方法存在java.net包中,提供创建url/子url,获取url等方法。
---------------使用URL基本步骤-----------------
第一步:创建一个URL对象
这里介绍两种创建URL对象的方法,一种直接创建一个指定地址的URL,另一种是在刚刚创建的URL对象上嵌套一个新的URL
- //创建一个URL的实例
- URL blog = new URL("https://www.cnblogs.com");
- //?后面表示参数,#后面表示锚点
- URL url = new URL(blog, "/index.html?username=hysum#test");
注:这里有关URL参数的说明先不作详细解释,之后会专门写一篇关于这方面的文(还在学习中哈)。
第二步:使用URL方法调用相关信息
- System.out.println("协议:" + url.getProtocol());
- System.out.println("主机:" + url.getHost());
- //如果未指定端口号,则使用默认的端口号,此时getPort方法返回值为-1
- System.out.println("端口:" + url.getPort());
- System.out.println("文件路径:" + url.getPath());
- System.out.println("文件名:" + url.getFile());
- System.out.println("相对路径:" + url.getRef());
- System.out.println("查询字符串:" + url.getQuery());
运行结果:
解惑:为什么getPort方法返回的是-1?
答:如果未指定端口号,则使用默认的端口号,此时getPort方法返回值为-1。
解惑:文件路径/文件名/相对路径/查询字符串在URL中分别代表什么?
答:文件路径-- 即不含任何特殊符号的路径;
文件名-- 文件路径+?后面的参数;
相对路径-- #后面的锚点;
查询字符串--?后面的参数。
第三步:读取网页内容
1.通过URL对象的openStream()方法可以得到指定资源的输入流。
2.通过输入流可以读取、访问网络上的数据。
基本实现步骤如下:
- URL url = new URL("http://www.baidu.com");
- //获取字节输入流通过openStream方法
- InputStream is = url.openStream();
- //转化成字符输入流
- InputStreamReader isr = new InputStreamReader(is, "utf-8");
- //加缓冲提高读取效率
- BufferedReader br = new BufferedReader(isr);
- String date;
- while ((date = br.readLine()) != null) {
- System.out.println(date);
- }
注意:
第四步:保存网页内容为HTML文件
- BufferedReader br = new BufferedReader(isr);
- PrintWriter pw = new PrintWriter("C:\\Users\\acer\\Desktop\\baidu.html");
- String date;
- while ((date = br.readLine()) != null) {
- pw.println(date);
- pw.flush();
- }
运行后,我桌面就生成了一个baidu.html文件:
双击打开,发现都是乱码,这其实是浏览器编码解析问题。
把浏览器编码改为简体中文,则可以正常显示了
【Socket编程】Java中网络相关API的应用
来源: http://www.bubuko.com/infodetail-2310914.html