Java URL Uniform Resource Locator

To find any resource on the internet, you need to have an address of it.

The URL and IP addresses are the pointers used for this purpose. An IP address points to the physical address of the computer. Instead of all that, the URL contains the protocol to be used, the domain name or an IP address, the path, and optional fragment identifier. It is easy to see that an IP address is the part of a URL, although it is common to see a domain name instead of an IP address.

A domain name specifies the address where Internet users can access your website. As previous computer uses IP addresses, which are a series of numbers, but it is difficult for humans to remember strings of numbers. Because of this, domain names were developed, is the combination of letters and numbers to represent the address to access your website.

URL is an acronym for Uniform Resource Locator. It is used to address resources(document) on the World Wide Web. A resource can be a file or a directory or a more complicated object, like a query to a database or search engine. Web browsers request pages from the web servers by using a URL. A URL refers to a web address.

The Internet is facing a rapid depletion of the IP address pool due to the rapid growth of the internet. IPv6 was invented for increasing the number of IP addresses that can be used over the network. And also, there is no limit to the number of possible URL as there is no shortage of the name.

The syntax of the URL:

The Scheme -It tells about the protocol to be used to access the resource.

The hostname– The hostname indicates where the resources located on the internet.

Port number -It indicates where the server located on the internet.

Path-It specifies the specific resource within the host that the user wants to access.

Query-string-It contains data to be passed on server-side scripts running on the server. It is preceded by a question mark (?), is usually a string of name and value pairs separated by an ampersand.

Fragment-identifier –It is introduced by a hash character (#) is the optional last part of a URL for a document that specifies a location within the page.

How to translate URL:

The web browser finds web pages using an IP or internet protocol. The IP is a series of numbers like, and it becomes difficult to remember a number for every website that you want to visit. It is far easier to use a word-based URL like When the host writes a URL into an address field, your web browsers uses DNS(Domain name Server) for translating the URL to the corresponding IP.

It is essential for processing the request through a Domain Name Server(DNS) for converting the domain name into an IP address. Without the DNS, the request would fail as the computer would not be able to find the host. The browser can then use IP numbers to find the information for you.


Some constructor for creating URL instances:

Constructor Description
URL(String str1) It creates a URL object from a specified String.
URL(String protocol, String host11, String file) It creates a URL object from the specified protocol, host11, and file name.
URL(String protocol, String host1, int port1, String file1) It creates a URL object from protocol, host, port, and filename.  
URL(URL url1 ,String str1) It creates a URL object by parsing the given string in the given context
URL(String protocol, String host1, int port, String file1, URLStreamHandler handler1) It creates a URL object from the specified protocol, host, port number, filename, and handler1.
URL (URL url1, String str, URLStreamHandler handler) It creates a URL by parsing the given str with the specified handler within a specific context.

URL provides many methods as follows for parsing the URL:

Method Description
   public String getProtocol()     It returns the protocol of the URL.  
 public String getHost()   It returns the hostname of the URL.  
 public String getPort()   It returns the Port Number of the URL  
 public String getFile()   It returns the file name of the URL
 public URLConnection openConnection()   It returns the instance of URLConnection. i.e., associated with this URL.  
public String toString() It returns the String representation of the given URL object
public String getAuthority() It returns the authority part of the URL or null if empty.
 public String getPath() It returns the path of the URL or null if empty.
public String getQuery() It returns the query part of the URL.
 public int getDefaultPort() It returns the default port used.
Public String getRef() It returns the reference of the URL

Types of URL:

  1. file URL

The file protocol is used in a URL that specifies the location of an operating system file. It is used to retrieve files from within a computer.


  • The file URL is used to designate files accessible on a particular host computer.
  •  This URL does not designate a resource that is universally accessible over the internet.


Here, the host is the fully qualified domain name of the system on which the path is accessible, and the path is a hierarchical directory path. It specifies the localhost, the machine from which the URL is being interpreted if the host is omitted.



The output of the code:

Types of URL

2. http URL

The Hypertext Transfer Protocol specifies the application-level protocol for distributed, collaborative, hypermedia information systems. It is the TCP/IP based communication protocol that can be used for delivering the data on the World Wide Web. The data may be the html files, image files, videos, etc. It is a foundation protocol for securing the communication between two systems for e.g., the browsers and the webserver. When you write a URL on your browsers, it sends an http request to the webserver for the webpage. In response, the server sends the http response to the client.


  • The http protocol refers to the request/response protocol working in the client/server- based architecture where the browser acts like http clients, and the server acts as a server. It is a stateless protocol because each command is executed independently without having any knowledge of the commands that came before it.
  • It is media independent because any type of data can be sent by it.
  • It is connection-less as the server processes the request and sends a response back, after which the client disconnects the connection.




Static and Dynamic Binding in Java

The output of the above program:

http URL

 3. https URL

The https is not a separate protocol from http. It simply uses TLS/SSL encryption over the http protocol. The https prevents the websites from having their information broadcasted in a way that is easily viewed by anyone on the network. With https, traffic encrypts in such a way that even if the packets are intercepted, they will come across as nonsensical characters. 


  • The https stands for secure hypertext transfer protocol. It is the secure version of http, by which the data is sent in a secure form between your browsers and the websites to which you are connected.
  • It means all communications between your browsers and the website are encrypted.
  • The importance of https over the http is the safety of our data from middle hackers as it is encrypted.
  • It is mainly for secure web pages, like online banking and online shopping order forms.




The output:

https URL

4. ftp URL

ftp is the standard network protocol used for transferring computer files between a client and server on a client-server computer network. It is also used for downloading or uploading the files from or to the remote host.


  • File Transfer protocol URL is the standard mechanism provided by TCP/IP for copying a file from one device to another device.
  • It is used for downloading or uploading files between a client and a server on a computer network in a most secure way.
  • It allows the back and forth transferring of the files.

Example: To show file Transfer and file Receiver by using the ftp protocol

File Transfer

The output of the program:

ftp URL

File Receiver

The output of the program:

File Receiver

Way of addressing the URL:

  1. Absolute URL? An absolute URL is the complete address of a resource. An absolute URL depends on the protocol, hostname, folder name, and file name. It is similar to the addresses defined by the Indian postal service that contains the name, house number, street address, city, state, and pin code. If any of the information is missing, the mail cannot be delivered to the right person. Similarly, if you miss the information from the URL, the resource file cannot be accessed.

Example 1:

The output of the above program:

Way of addressing the URL


Output of program:

Way of addressing the URL
  • Relative URL –Relative URL does not contain all the parts of a URL, it is always considered with respect to a base URL. A relative URL contains the folder name and file name or only the file name. This URL is basically used when the resource file is stored in the same folder or the same server. In this situation, the browser does not require the protocol and the server name because it assumes the resource file is stored in the folder or the server that is relative to the original file. A relative URL contains enough information to reach the resource relative to another URL. There is a Constructor that creates a URL object from another URL object (the base) and a relative URL specification.


The first argument is the URL object that specifies the base of the new URL. The other argument is a string that specifies rest of the resource name relative to the base. If baseURL is null, then the constructor treats relativeURL like an absoluteURL specification. If relativeURL specifies absolute URL specification, then the constructor ignores baseURL.

Example: We can create a URL that points to Then we resolve a URL relative as   “../interface-in-java “. The double dots (..) means to go to the parent folder.

The output of the above program:

relative URL specification

Pin It on Pinterest

Share This