全パッケージ クラス階層 このパッケージ 前項目 次項目 インデックス
java.lang.Object | +----java.net.URLConnection
URLConnection は、アプリケーションと URL との間の通信リンクを表すすべてのクラスのスーパークラスです。このクラスのインスタンスを使用して、URL で参照するリソースの読み込みと書き込みの両方を行うことができます。一般に、URL への接続を作成する際には複数の手順が必要となります。
 
| openConnection() | connect() | 
|---|---|
| リモートリソースへの接続に影響するパラメータを操作する | リソース、クエリーヘッダーフィールド、情報の内容と対話処理を行う | 
openConnection メソッドを呼び出すことによって、接続オブジェクトを作成する
 connect メソッドを使用してリモートオブジェクトへの実際の接続を確立する
 セットアップパラメータを修正するには次のメソッドを使用します。
setAllowUserInteraction
   setDoInput
   setDoOutput
   setIfModifiedSince
   setUseCaches
 一般要求プロパティを修正するには次のメソッドを使用します。
setRequestProperty
 
 AllowUserInteraction パラメータと UseCaches パラメータのデフォルト値を設定するには、setDefaultAllowUserInteraction と setDefaultUseCaches を使用します。一般要求プロパティのデフォルト値を設定するには、setDefaultRequestProperty メソッドを使用します。
 
 上記の両方の set メソッドには対応する get メソッドがあり、パラメータや一般要求プロパティの値を取得することができます。使用できるパラメータと一般要求プロパティは、プロトコルによって異なります。
 
リモートオブジェクトへの接続を確立したあと、ヘッダーフィールドと内容にアクセスするには次のメソッドを使用します。
getContent
   getHeaderField
   getInputStream
   getOutputStream
 一部のヘッダーフィールドには頻繁にアクセスします。次のメソッドは、これらのフィールドにアクセスする際に便利なメソッドです。
getContentEncoding
   getContentLength
   getContentType
   getDate
   getExpiration
   getLastModifed
 
 getContent メソッドは、リモートオブジェクトの種類を判別する際に getContentType メソッドを使用します。サブクラスでは、getContentType メソッドをオーバーライドするときにこのメソッドを使用すると便利です。
 
 一般に、接続前のパラメータと一般要求プロパティは、無視することができます。接続前のパラメータと一般要求プロパティのデフォルト値は読み取りが可能です。このインタフェースの大部分のクライアントで、よく使用するメソッドは getInputStream メソッドと getObject メソッドです。これらは URL クラスの便利なメソッドによってミラーされます。
 
  http 接続の要求プロパティとヘッダーフィールドの詳細については、次のサイトを参照してください。
 
http://www.w3.org/hypertext/WWW/Protocols/HTTP1.0/draft-ietf-http-spec.html
 
 allowUserInteraction
	allowUserInteraction
  true の場合、この URL はユーザーとの対話処理 (認証ダイアログのポップアップなど) の実行が可能なコンテキストで検査されている。
   connected
	connected
  false の場合、この接続オブジェクトは指定の URL への通信リンクを作成していない。
   doInput
	doInput
  setDoInput メソッドを使用する。
   doOutput
	doOutput
  setDoOutput メソッドを使用する。
   fileNameMap
	fileNameMap
   ifModifiedSince
	ifModifiedSince
   url
	url
   useCaches
	useCaches
  true の場合、そのプロトコルでは可能なときにはいつでもキャッシュ内のデータを使用することができる。
 
 URLConnection(URL)
	URLConnection(URL)
   
 connect()
	connect()
   getAllowUserInteraction()
	getAllowUserInteraction()
  allowUserInteraction フィールドの値を返す。
   getContent()
	getContent()
   getContentEncoding()
	getContentEncoding()
  content-encoding ヘッダーフィールドの値を返す。
   getContentLength()
	getContentLength()
  content-length ヘッダーフィールドの値を返す。
   getContentType()
	getContentType()
  content-type ヘッダーフィールドの値を返す。
   getDate()
	getDate()
  date ヘッダーフィールドの値を返す。
   getDefaultAllowUserInteraction()
	getDefaultAllowUserInteraction()
  allowUserInteraction フィールドのデフォルト値を返す。
   getDefaultRequestProperty(String)
	getDefaultRequestProperty(String)
   getDefaultUseCaches()
	getDefaultUseCaches()
  URLConnection の useCaches フラグのデフォルト値を返す。
   getDoInput()
	getDoInput()
  URLConnection の doInput フラグの値を返す。
   getDoOutput()
	getDoOutput()
  URLConnection の doOutput フラグの値を返す。
   getExpiration()
	getExpiration()
  expires ヘッダーフィールドの値を返す。
   getHeaderField(int)
	getHeaderField(int)
  n 番目のヘッダーフィールドの値を返す。
   getHeaderField(String)
	getHeaderField(String)
   getHeaderFieldDate(String, long)
	getHeaderFieldDate(String, long)
   getHeaderFieldInt(String, int)
	getHeaderFieldInt(String, int)
   getHeaderFieldKey(int)
	getHeaderFieldKey(int)
  n 番目のヘッダーフィールドのキーを返す。
   getIfModifiedSince()
	getIfModifiedSince()
  ifModifiedSince フィールドの値を返す。
   getInputStream()
	getInputStream()
   getLastModified()
	getLastModified()
  last-modified ヘッダーフィールドの値を返す。
   getOutputStream()
	getOutputStream()
   getRequestProperty(String)
	getRequestProperty(String)
   getURL()
	getURL()
  URLConnection の URL フィールドの値を返す。
   getUseCaches()
	getUseCaches()
  URLConnection の useCaches フィールドの値を返す。
   guessContentTypeFromName(String)
	guessContentTypeFromName(String)
   guessContentTypeFromStream(InputStream)
	guessContentTypeFromStream(InputStream)
   setAllowUserInteraction(boolean)
	setAllowUserInteraction(boolean)
  URLConnection の allowUserInteraction フィールドの値を設定する。
   setContentHandlerFactory(ContentHandlerFactory)
	setContentHandlerFactory(ContentHandlerFactory)
  ContentHandlerFactory を設定する。
   setDefaultAllowUserInteraction(boolean)
	setDefaultAllowUserInteraction(boolean)
  URLConnection オブジェクトの allowUserInteraction フィールドのデフォルト値を指定した値に設定する。
   setDefaultRequestProperty(String, String)
	setDefaultRequestProperty(String, String)
   setDefaultUseCaches(boolean)
	setDefaultUseCaches(boolean)
  useCaches フィールドの設定値を指定した値に設定する。
   setDoInput(boolean)
	setDoInput(boolean)
  URLConnection  の doInput フィールド値を指定した値に設定する。
   setDoOutput(boolean)
	setDoOutput(boolean)
  URLConnection の doOutput フィールド値を指定した値に設定する。
   setIfModifiedSince(long)
	setIfModifiedSince(long)
  URLConnection の ifModifiedSince フィールド値を指定した値に設定する。
   setRequestProperty(String, String)
	setRequestProperty(String, String)
   setUseCaches(boolean)
	setUseCaches(boolean)
  URLConnection の useCaches フィールド値を指定した値に設定する。
   toString()
	toString()
  String 表現を返す。
 
 url
url
protected URL url
 このフィールドの値にアクセスするには、getURL メソッドを使用します。
 
 この変数のデフォルト値は、URLConnection コンストラクタの URL 引数の値です。
 doInput
doInput
protected boolean doInput
setDoInput メソッドを使用します。この変数の値を取得するには getDoInput メソッドを使用します。
 
 URL 接続を使用して、入力と出力を行うことができます。アプリケーションで URL 接続からデータの読み込みを行う際には、doInput フラグを true に設定します。
 
 このフィールドのデフォルト値は true です。
 doOutput
doOutput
protected boolean doOutput
setDoOutput メソッドを使用します。この変数値を取得するには getDoInput メソッドを使用します。
 
 URL 接続を使用して、入力や出力を行うことができます。アプリケーションで URL 接続に書き込みを行う場合は、doOutput フラグを true に設定します。
 
 このフィールドのデフォルト値は false です。
 allowUserInteraction
allowUserInteraction
protected boolean allowUserInteraction
true の場合、この URL はユーザーとの対話処理 (認証ダイアログのポップアップなど) の実行が可能なコンテキストで検査されています。false の場合、ユーザーとの対話処理は許可されていません。
 
 このフィールドの値を設定するには setAllowUserInteraction メソッドを使用します。
このフィールドの値を取得するには getAllowUserInteraction メソッドを使用します。
 このフィールドのデフォルト値は、setDefaultAllowUserInteraction メソッドを最後に呼び出したとき、引数に指定した値です。
 useCaches
useCaches
protected boolean useCaches
trueの場合、プロトコルは可能なときにキャッシュ内のデータを使用することができます。false の場合、プロトコルは常にオブジェクトの新しいコピーを取得する必要があります。
 
 このフィールド値を設定するには setUseCaches メソッドを使用します。このフィールド値を取得するには getUseCaches メソッドを使用します。
 
 このフィールドのデフォルト値は、 setDefaultUseCaches メソッドを最後に呼び出したときに指定した値です。
 ifModifiedSince
ifModifiedSince
protected long ifModifiedSince
ゼロ以外の値は、1970 年 1 月 1 日 GMT から数えた秒数を表します。この値よりもあとにオブジェクトが変更されている場合にだけ、オブジェクトが取り寄せられます。
 この変数を設定するには setIfModifiedSince メソッドを使用します。この変数値を取得するには getIfModifiedSince メソッドを使用します。
 
 このフィールドのデフォルト値は 0 (常にオブジェクトを取り寄せる) です。
  
 fileNameMap
fileNameMap
public static FileNameMap fileNameMap
 connected
connected
protected boolean connected
false の場合、この接続オブジェクトは指定した URL への通信リンクを作成していません。true の場合は、通信リンクが確立されています。
 
 URLConnection
URLConnection
protected URLConnection(URL url)
 
 connect
connect
public abstract void connect() throws IOException
 connect メソッドを呼び出したときに、接続がすでに確立されていれば
 (connected フィールドの値が true)、メソッド呼び出しは無視されます。
 
URLConnection オブジェクトは 2 つの段階を踏みます。まずオブジェクトが作成され、そのあと接続が確立されます。作成後、接続を確立する前に、さまざまなオプション (doInput や UseCaches など) を指定することができます。接続後にこれらのオプションを設定しようとするとエラーになります。接続に依存する操作 (getContentLength など) を行うと、必要に応じて接続が暗黙的に確立されます。
 getURL
getURL
public URL getURL()
URLConnection の URL フィールド値を返します。
URLConnection の URL フィールド値
     getContentLength
getContentLength
public int getContentLength()
content-length ヘッダーフィールドの値を返します。
-1
   getContentType
getContentType
public String getContentType()
content-type ヘッダーフィールドの値を返します。
null 
     getContentEncoding
getContentEncoding
public String getContentEncoding()
content-encoding ヘッダーフィールドの値を返します。
null 
     getExpiration
getExpiration
public long getExpiration()
expires ヘッダーフィールドの値を返します。
 getDate
getDate
public long getDate()
date ヘッダーフィールドの値を返します。
0 。値は 1970 年 1 月 1 日 GMT から数えた秒数として返される
     getLastModified
getLastModified
public long getLastModified()
last-modified ヘッダーフィールドの値を返します。値は 1970 年 1 月 1 日 GMT から数えた秒数として返されます。
URLConnection が参照するリソースが変更されら日付。不明の場合は 0
     getHeaderField
getHeaderField
public String getHeaderField(String name)
null
   getHeaderFieldInt
getHeaderFieldInt
  public int getHeaderFieldInt(String name,
                               int Default)
 一部の種類の接続 (http-ng など) は事前に解析してあるヘッダーをもつので、この形式の getHeaderField が存在しています。そのような種類の接続クラスでは、このメソッドをオーバーライドして解析を回避することができます。
Default の値
   getHeaderFieldDate
getHeaderFieldDate
  public long getHeaderFieldDate(String name,
                                 long Default)
 一部の種類の接続 (http-ng など) では事前に解析してあるヘッダーをもつので、この形式の getHeaderField が存在しています。そのような種類の接続クラスでは、このメソッドをオーバーライドして解析を回避することができます。
Default 引数
   getHeaderFieldKey
getHeaderFieldKey
public String getHeaderFieldKey(int n)
n 番目のヘッダーフィールドのキーを返します。
n 番目のヘッダーフィールドのキー。フィールドの数が n 個よりも少ない場合は null 
   getHeaderField
getHeaderField
public String getHeaderField(int n)
n 番目のヘッダーフィールドの値を返します。フィールドの数が n 個よりも少ない場合は null を返します。
 
 このメソッドと getHeaderFieldKey メソッドを組み合わせて使用すると、メッセージ内のすべてのヘッダーを繰り返し処理することができます。
n 番目のヘッダーフィールドの値
     getContent
getContent
public Object getContent() throws IOException
 このメソッドでは最初に getContentType メソッドを呼び出し、オブジェクトの情報の種類を判別します。アプリケーションでその種類の内容を見るのがはじめての場合は、その種類の情報ヘッダーが作成されます。
 
setContentHandlerFactory メソッドを使用し ContentHandler ファクトリのインスタンスがセットアップされている場合は、そのインスタンスの createContentHandler メソッドを呼び出し、内容の種類を引数として渡す。その結果、その内容の種類の ContentHandler が返される。
 createContentHandler メソッドが null を返す場合、アプリケーションは次の名前のクラスをロードする。
     
         sun.net.www.content.<contentType>
     ピリオド (「.」) に置換し、アルファベット以外のすべての文字を下線文字「_」に置換することによって作成される。アルファベット文字とは、26 個の大文字の ASCII 文字 (「A」から「Z」まで)、26 子の小文字の ASCII 文字 (「a」から「z」まで、および 10 個の ASCII 数字 (「0」から「9」まで) を表す。指定したクラスが存在しない場合、または ContentHandler のサブクラスではない場合は、UnknownServiceException がスローされる。
 
instanceOf 操作を行う
     getInputStream
getInputStream
public InputStream getInputStream() throws IOException
 getOutputStream
getOutputStream
public OutputStream getOutputStream() throws IOException
 toString
toString
public String toString()
String 表現を返します。
URLConnection の文字列表現
     setDoInput
setDoInput
public void setDoInput(boolean doinput)
URLConnection の doInput フィールド値を指定した値に設定します。
 URL 接続を使用して入出力を行うことができます。URL 接続を使用して入力を行う場合には DoInput フラグを true に設定します。出力を行う場合には false に設定します。DoOutput を明示的に true に設定しない限り、doInput のデフォルト値は true です。DoOutput を true に設定した場合には、DoInput のデフォルト値は false になります。
 getDoInput
getDoInput
public boolean getDoInput()
URLConnection の doInput フラグの値を返します。
URLConnection の doInput フラグの値
     setDoOutput
setDoOutput
public void setDoOutput(boolean dooutput)
URLConnection の doOutput フィールド値を指定した値に設定します。
 URL 接続を使用して入出力を行うことができます。URL 接続を使用して出力を行う場合には、DoOutput フラグを true に設定します。入力を行う場合には false に設定します。デフォルト値は false です。
 getDoOutput
getDoOutput
public boolean getDoOutput()
URLConnection の doOutput フラグの値を返します。
URLConnection の doOutput フラグの値
     setAllowUserInteraction
setAllowUserInteraction
public void setAllowUserInteraction(boolean allowuserinteraction)
URLConnection の allowUserInteraction フィールド値を設定します。
 getAllowUserInteraction
getAllowUserInteraction
public boolean getAllowUserInteraction()
allowUserInteraction フィールド値を返します。
allowUserInteraction フィールド値
     setDefaultAllowUserInteraction
setDefaultAllowUserInteraction
public static void setDefaultAllowUserInteraction(boolean defaultallowuserinteraction)
URLConnection オブジェクトの allowUserInteraction フィールドのデフォルト値を指定の値に設定します。
 getDefaultAllowUserInteraction
getDefaultAllowUserInteraction
public static boolean getDefaultAllowUserInteraction()
allowUserInteraction フィールドのデフォルト値を返します。
 デフォルト値は「sticky」( URLConnection の静的な状態の一部) です。このフラグは、以降に作成されるすべての URLConnection オブジェクトに適用されます。
allowUserInteraction フィールドのデフォルト値
     setUseCaches
setUseCaches
public void setUseCaches(boolean usecaches)
URLConnection の useCaches フィールドを指定の値に設定します。
 一部のプロトコルは、ドキュメントをキャッシュします。しかし、場合によってはキャッシュを無視して情報を転送する (ブラウザの「再読込」ボタン) ことが重要なこともあります。接続の UseCaches フラグが true の場合、その接続ではキャッシュを使用することができます。このフラグが false の場合、キャッシュは無視されます。デフォルト値は DefaultUseCaches の値によって決まりますが、 DefaultUseCaches のデフォルト値は true です。
 getUseCaches
getUseCaches
public boolean getUseCaches()
URLConnection の useCaches フィールド値を返します。
URLConnection の useCaches フィールド値
     setIfModifiedSince
setIfModifiedSince
public void setIfModifiedSince(long ifmodifiedsince)
URLConnection の ifModifiedSince フィールド値を指定した値に設定します。
 getIfModifiedSince
getIfModifiedSince
public long getIfModifiedSince()
ifModifiedSince フィールド値を返します。
ifModifiedSince フィールド値
     getDefaultUseCaches
getDefaultUseCaches
public boolean getDefaultUseCaches()
URLConnection の
 useCaches フラグのデフォルト値を返します。
 デフォルト値は「sticky」( URLConnection の静的な状態の一部) です。このフラグは、以降に作成されるすべての URLConnection オブジェクトに適用されます。
URLConnection の useCaches フラグのデフォルト値
     setDefaultUseCaches
setDefaultUseCaches
public void setDefaultUseCaches(boolean defaultusecaches)
useCaches フィールドのデフォルト値を指定の値に設定します。
 setRequestProperty
setRequestProperty
  public void setRequestProperty(String key,
                                 String value)
accept」など)
     getRequestProperty
getRequestProperty
public String getRequestProperty(String key)
 setDefaultRequestProperty
setDefaultRequestProperty
  public static void setDefaultRequestProperty(String key,
                                               String value)
URLConnection は、作成時にこれらの値を使って初期化されます。
accept」など)
     getDefaultRequestProperty
getDefaultRequestProperty
public static String getDefaultRequestProperty(String key)
 setContentHandlerFactory
setContentHandlerFactory
public static synchronized void setContentHandlerFactory(ContentHandlerFactory fac)
ContentHandlerFactory を設定します。アプリケーションでは最大で 1 回呼び出すことができます。
 
 内容の種類をもとに ContentHandler を作成する際には ContentHandlerFactory が使用されます。
 guessContentTypeFromName
guessContentTypeFromName
protected static String guessContentTypeFromName(String fname)
getContentType  メソッドをオーバーライドするサブクラスで使用すると便利です。
 guessContentTypeFromStream
guessContentTypeFromStream
public static String guessContentTypeFromStream(InputStream is) throws IOException
getContentType メソッドをオーバーライドするサブクラスで使用することができます。
 
 理想的な状態ではこのルーチンは必要ありません。しかし、内容の種類として不正な値を返す http サーバは数多くあります。さらに、標準的ではない拡張子もたくさんあります。このため、http サーバーが返す内容の種類をうのみにするよりも、データをもとに内容の種類を直接推測した方が正確なことがよくあります。
null 
    全パッケージ クラス階層 このパッケージ 前項目 次項目 インデックス