Java Tutorial
- Java - Home
- Java - Overview
- Java - History
- Java - Features
- Java vs C++
- Java Virtual Machine (JVM)
- Java - JDK vs JRE vs JVM
- Java - Hello World Program
- Java - Environment Setup
- Java - Basic Syntax
- Java - Variable Types
- Java - Data Types
- Java - Type Casting
- Java - Unicode System
- Java - Basic Operators
- Java - Comments
Java Control Statements
- Java - Loop Control
- Java - Decision Making
- Java - If-else
- Java - Switch
- Java - For Loops
- Java - For-Each Loops
- Java - While Loops
- Java - do-while Loops
- Java - Break
- Java - Continue
Object Oriented Programming
- Java - OOPs Concepts
- Java - Object & Classes
- Java - Class Attributes
- Java - Class Methods
- Java - Methods
- Java - Variables Scope
- Java - Constructors
- Java - Access Modifiers
- Java - Inheritance
- Java - Aggregation
- Java - Polymorphism
- Java - Overriding
- Java - Method Overloading
- Java - Dynamic Binding
- Java - Static Binding
- Java - Instance Initializer Block
- Java - Abstraction
- Java - Encapsulation
- Java - Interfaces
- Java - Packages
- Java - Inner Classes
- Java - Static Class
- Java - Anonymous Class
- Java - Singleton Class
- Java - Wrapper Classes
- Java - Enums
- Java - Enum Constructor
- Java - Enum Strings
Java Built-in Classes
Java File Handling
- Java - Files
- Java - Create a File
- Java - Write to File
- Java - Read Files
- Java - Delete Files
- Java - Directories
- Java - I/O Streams
Java Error & Exceptions
- Java - Exceptions
- Java - try-catch Block
- Java - try-with-resources
- Java - Multi-catch Block
- Java - Nested try Block
- Java - Finally Block
- Java - throw Exception
- Java - Exception Propagation
- Java - Built-in Exceptions
- Java - Custom Exception
Java Multithreading
- Java - Multithreading
- Java - Thread Life Cycle
- Java - Creating a Thread
- Java - Starting a Thread
- Java - Joining Threads
- Java - Naming Thread
- Java - Thread Scheduler
- Java - Thread Pools
- Java - Main Thread
- Java - Thread Priority
- Java - Daemon Threads
- Java - Thread Group
- Java - Shutdown Hook
Java Synchronization
- Java - Synchronization
- Java - Block Synchronization
- Java - Static Synchronization
- Java - Inter-thread Communication
- Java - Thread Deadlock
- Java - Interrupting a Thread
- Java - Thread Control
- Java - Reentrant Monitor
Java Networking
- Java - Networking
- Java - Socket Programming
- Java - URL Processing
- Java - URL Class
- Java - URLConnection Class
- Java - HttpURLConnection Class
- Java - Socket Class
- Java - Generics
Java Collections
Java Interfaces
- Java - List Interface
- Java - Queue Interface
- Java - Map Interface
- Java - SortedMap Interface
- Java - Set Interface
- Java - SortedSet Interface
Java Data Structures
Java Collections Algorithms
Advanced Java
- Java - Command-Line Arguments
- Java - Lambda Expressions
- Java - Sending Email
- Java - Applet Basics
- Java - Javadoc Comments
- Java - Autoboxing and Unboxing
- Java - File Mismatch Method
- Java - REPL (JShell)
- Java - Multi-Release Jar Files
- Java - Private Interface Methods
- Java - Inner Class Diamond Operator
- Java - Multiresolution Image API
- Java - Collection Factory Methods
- Java - Module System
- Java - Nashorn JavaScript
- Java - Optional Class
- Java - Method References
- Java - Functional Interfaces
- Java - Default Methods
- Java - Base64 Encode Decode
- Java - Switch Expressions
- Java - Teeing Collectors
- Java - Microbenchmark
- Java - Text Blocks
- Java - Dynamic CDS archive
- Java - Z Garbage Collector (ZGC)
- Java - Null Pointer Exception
- Java - Packaging Tools
- Java - Sealed Classes
- Java - Record Classes
- Java - Hidden Classes
- Java - Pattern Matching
- Java - Compact Number Formatting
- Java - Garbage Collection
- Java - JIT Compiler
Java Miscellaneous
- Java - Recursion
- Java - Regular Expressions
- Java - Serialization
- Java - Strings
- Java - Process API Improvements
- Java - Stream API Improvements
- Java - Enhanced @Deprecated Annotation
- Java - CompletableFuture API Improvements
- Java - Streams
- Java - Datetime Api
- Java 8 - New Features
- Java 9 - New Features
- Java 10 - New Features
- Java 11 - New Features
- Java 12 - New Features
- Java 13 - New Features
- Java 14 - New Features
- Java 15 - New Features
- Java 16 - New Features
Java APIs & Frameworks
Java Class References
- Java - Scanner Class
- Java - Arrays Class
- Java - Strings
- Java - Date & Time
- Java - ArrayList
- Java - Vector Class
- Java - Stack Class
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - The IdentityHashMap Class
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet Class
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection Interface
- Java - Array Methods
Java Useful Resources
Java - URLConnection Class
Java URLConnection Class
java.net.URLConnection, is an abstract class whose subclasses represent the various types of URL connections. Instances of this class can be used both to read from and to write to the resource referenced by the URL.
For example −
If you connect to a URL whose protocol is HTTP, the URL.openConnection() method returns an HttpURLConnection object.
If you connect to a URL that represents a JAR file, the URL.openConnection() method returns a JarURLConnection object, etc.
Steps to make a connection to a URL
Following are the steps to make a connectiion to the URL and start processing.
Invoke URL.openConnection() method to get connection object.
Update setup parameters and general request properties as required using connection object various setter methods.
Create a connection to remote object using connect() method of connection object.
Once remote object is available, access the content/headers of the remote object.
URLConnection Class Declaration
public abstract class URLConnection extends Object
URLConnection Class Fields
Sr.No. | Field & Description |
---|---|
1 | protected boolean allowUserInteraction If true, this URL is being examined in a context in which it makes sense to allow user interactions such as popping up an authentication dialog. |
2 | protected boolean connected If false, this connection object has not created a communications link to the specified URL. |
3 | protected boolean doInput This variable is set by the setDoInput method. |
3 | protected boolean doOutput This variable is set by the setDoOutput method. |
4 | protected long ifModifiedSince Some protocols support skipping the fetching of the object unless the object has been modified more recently than a certain time. |
5 | protected URL url The URL represents the remote object on the World Wide Web to which this connection is opened. |
6 | protected boolean useCaches If true, the protocol is allowed to use caching whenever it can. |
URLConnection Class Methods
The URLConnection class has many methods for setting or determining information about the connection, including the following −
Sr.No. | Method & Description |
---|---|
1 | void addRequestProperty(String key, String value) Adds a general request property specified by a key-value pair. |
2 | boolean getAllowUserInteraction() Returns the value of the allowUserInteraction field for this object. |
3 |
Returns setting for connect timeout. |
4 |
Retrieves the contents of this URL connection. |
5 | Object getContent(Class[] classes) Retrieves the contents of this URL connection. |
6 |
Returns the value of the content-encoding header field. |
7 |
Returns the value of the content-length header field. |
8 |
Returns the value of the content-length header field as long. |
9 |
Returns the value of the content-type header field. |
10 |
Returns the value of the date header field. |
11 | static boolean getDefaultAllowUserInteraction() Returns the default value of the allowUserInteraction field. |
12 |
Returns the default value of a URLConnection's useCaches flag. |
13 | static boolean getDefaultUseCaches(String protocol) Returns the default value of the useCaches flag for the given protocol. |
14 |
Returns the value of this URLConnection's doInput flag. |
15 |
Returns the value of this URLConnection's doOutput flag. |
16 |
Returns the value of the expires header field. |
17 | static FileNameMap getFileNameMap() Loads filename map (a mimetable) from a data file. |
18 |
Returns the value for the nth header field. |
19 | String getHeaderField(String name) Returns the value of the named header field. |
20 | long getHeaderFieldDate(String name, long Default) Returns the value of the named field parsed as date. |
21 | int getHeaderFieldInt(String name, int Default) Returns the value of the named field parsed as a number. |
22 | String getHeaderFieldKey(int n) Returns the key for the nth header field. |
23 | long getHeaderFieldLong(String name, long Default) Returns the value of the named field parsed as a number. |
24 | Map<String,List<String>> getHeaderFields() Returns an unmodifiable Map of the header fields. |
25 |
Returns the value of this object's ifModifiedSince field. |
26 |
Returns an input stream that reads from this open connection. |
27 |
Returns the value of the last-modified header field. |
28 | OutputStream getOutputStream() Returns an output stream that writes to this connection. |
29 |
Returns a permission object representing the permission necessary to make the connection represented by this object. |
30 |
Returns setting for read timeout. 0 return implies that the option is disabled (i.e., timeout of infinity). |
31 | Map<String,List<String>> getRequestProperties() Returns an unmodifiable Map of general request properties for this connection. |
32 | String getRequestProperty(String key) Returns the value of the named general request property for this connection. |
33 |
Returns the value of this URLConnection's URL field. |
34 |
Returns the value of this URLConnection's useCaches field. |
35 | static String guessContentTypeFromName(String fname) Tries to determine the content type of an object, based on the specified "file" component of a URL. |
36 | static String guessContentTypeFromStream(InputStream is) Tries to determine the type of an input stream based on the characters at the beginning of the input stream. |
37 | void setAllowUserInteraction(boolean allowuserinteraction) Set the value of the allowUserInteraction field of this URLConnection. |
38 | void setConnectTimeout(int timeout) Sets a specified timeout value, in milliseconds, to be used when opening a communications link to the resource referenced by this URLConnection. |
39 | static void setContentHandlerFactory(ContentHandlerFactory fac) Sets the ContentHandlerFactory of an application. |
40 | static void setDefaultAllowUserInteraction(boolean defaultallowuserinteraction) Sets the default value of the allowUserInteraction field for all future URLConnection objects to the specified value. |
41 | void setDefaultUseCaches(boolean defaultusecaches) Sets the default value of the useCaches field to the specified value. |
42 | static void setDefaultUseCaches(String protocol, boolean defaultVal) Sets the default value of the useCaches field for the named protocol to the given value. |
43 | void setDoInput(boolean doinput) Sets the value of the doInput field for this URLConnection to the specified value. |
44 | void setDoOutput(boolean dooutput) Sets the value of the doOutput field for this URLConnection to the specified value. |
45 | static void setFileNameMap(FileNameMap map) Sets the FileNameMap. |
46 | void setIfModifiedSince(long ifmodifiedsince) Sets the value of the ifModifiedSince field of this URLConnection to the specified value. |
47 | void setReadTimeout(int timeout) Sets the read timeout to a specified timeout, in milliseconds. |
48 | void setRequestProperty(String key, String value) Sets the general request property. |
49 | void setUseCaches(boolean usecaches) Sets the value of the useCaches field of this URLConnection to the specified value. |
50 |
Returns a String representation of this URL connection. |
Extends
This class extends following classes
java.lang.Object
Example of URLConnection Class Methods
The following URLConnectionDemo program connects to a URL entered from the command line.
If the URL represents an HTTP resource, the connection is cast to HttpURLConnection, and the data in the resource is read one line at a time.
package com.tutorialspoint; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; import java.net.URLConnection; public class URLConnectionDemo { public static void main(String [] args) { try { URL url = new URL("https://www.tutorialspoint.com"); URLConnection urlConnection = url.openConnection(); HttpURLConnection connection = null; if(urlConnection instanceof HttpURLConnection) { connection = (HttpURLConnection) urlConnection; }else { System.out.println("Please enter an HTTP URL."); return; } BufferedReader in = new BufferedReader( new InputStreamReader(connection.getInputStream())); String urlString = ""; String current; while((current = in.readLine()) != null) { urlString += current; } System.out.println(urlString); } catch (IOException e) { e.printStackTrace(); } } }
A sample run of this program will produce the following result −
Output
$ java URLConnectionDemo .....a complete HTML content of home page of tutorialspoint.com.....