java URL编程

时间:2021-09-23 16:26:28

一、URL编程技术

URL是统一资源定位器的缩写,它是指向互联网“资源”的指针。URL表示了Internet上某个资源的地址。URL支持http,file,ftp等 多种协议。通过URL标识,可以直接使用通信协议获取远端计算机上的资源信息,方便快捷的开发Internet应用程序。

java.net 包中的URL类是对统一资源定位符的抽象,使用URL创建对象的应用程序称为客户端程序,一个URL对象存放着一个具体的资源的引用,表明客户要访问这个 URL中的资源,利用URL对象可以获取URL中的资源。一个URL对象通常包含最基本的三部分信息:协议、地址、资源。协议必须是URL对象所在的 JVM支持的协议,常用的协议如:HTTP、FTP等都是JVM支持的协议,地址必须是能连接的有效的IP地址或域名地址,资源可以是主机上的任何一个文 件。

URL代码实现:

 /**
* 使用URL直接读取或写入网络上的数据
* 2016/5/6
**/
package org.net; import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.*; public class NetTest_1 {
public static void main(String[] args) throws Exception {
//String str = "http://www.imooc.com";
URL imooc = new URL("http://www.imooc.com");
//#号后面表示锚点
URL url = new URL(imooc,"/index.html?username = tom#test");
System.out.println("protocol(协议):" + url.getProtocol());
System.out.println("host(主机): " + url.getPort());
//如果没有制定端口号,则使用默认的端口号 此时getPort()方法的返回值为-1
System.out.println("port(端口): " + url.getPort());
System.out.println("path(路径): " + url.getPath());
System.out.println("file(文件): " + url.getFile());
System.out.println("Ret(文件类型): " + url.getRef());
System.out.println("DefaultPort(默认端口): " + url.getDefaultPort());
System.out.println("query(用户): " + url.getQuery());
System.out.println("content(内容): " + url.getContent());
}
}

结果:

protocol(协议):http
host(主机): -1
port(端口): -1
path(路径): /index.html
file(文件): /index.html?username = tom
Ret(文件类型): test
DefaultPort(默认端口): 80
query(用户): username = tom
content(内容): sun.net.www.protocol.http.HttpURLConnection$HttpInputStream@5c647e05

 UPLConnection类

URLConnection用于应用程序和URL之间的连接,应用程序通过URLConection可以获得URL对象的相关信息,它是所有URL连接通信类的父类。该类的对象可以用来读写URL对象所表示的Internet上的数据。

代码实现:

 /**
* 读取Internet上的数据
* 2016/5/6
**/
package org.net;
import java.io.*;
import java.net.*; public class NetTest_2 {
static int ch;
public static void main(String[] args) throws Exception {
URL url = new URL("http://www.imooc.com");
URLConnection uc = url.openConnection();
System.out.println("文件类型: "+ uc.getContentType());
System.out.println("文件长度: "+ uc.getContentLength());
System.out.println("文件内容:");
System.out.println("###############################");
InputStream is = uc.getInputStream();
while((ch = is.read()) != -1){
System.out.print((char)ch);
}
is.close();
}
}

结果展示:

文件类型: text/html; charset=utf-8
文件长度: -1
文件内容:
###############################
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>慕课网-国内最大的IT技能学习平台</title>
<meta http-equiv="X-UA-Compatible" content="IE=edge, chrome=1">
.............(后边比较长,不再显示)