1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
|
---
title: nsIChannel
slug: nsIChannel
tags:
- páginas_a_traducir
translation_of: Mozilla/Tech/XPCOM/Reference/Interface/nsIChannel
---
<p>La interfaz <code>nsIChannel</code> permite a los clientes construir peticiones "GET" para protocolos específicos y manejarlos de forma uniforme.</p>
<p><br>
<code><a href="/es/docs/Mozilla/Tech/XPCOM/Reference/Interface/nsIChannel" title="">nsIChannel</a></code> is defined in <a class="external" href="http://mxr.mozilla.org/mozilla/source/netwerk/base/public/nsIChannel.idl" rel="freelink">http://mxr.mozilla.org/mozilla/sourc...nsIChannel.idl</a> .</p>
<p>Una vez que se crea un canal (via nsIIOService::newChannel), pueden presentarse parámetros para esa petición usando los atributos de canal, o poniéndose en cola (QI'ing) de una subclase de nsIchannel para los parámetros específicos del protocolo. Entonces, puede buscarse la URI llamando nsIChannel::open o nsIChannel::asyncOpen. Después de que una petición se ha completado, el canal está aún disponible para acceder a resultados específicos del protocolo. Por ejemplo, poniéndose en cola (QI'ing) a nsIHttpChannel permite que se puedan leer las correspondientes cabeceras de respuesta de una transacción http.</p>
<h3 id="M.C3.A9todos" name="M.C3.A9todos">Métodos</h3>
<h4 id="open.28.29" name="open.28.29">open()</h4>
<pre class="eval">nsIInputStream open();
</pre>
<p>Abre un canal de forma síncrona.</p>
<p>@return blocking input stream to the channel's data.</p>
<p>NOTA: las implementaciones nsIChannel no requieren implementar este método. Aún más, ya que este método puede llegar a bloquear el proceso de la llamada, no debería usarse en el transcurso del proceso de eventos UI.</p>
<p>NOTA: Las implementaciones deberían devolver NS_ERROR_IN_PROGRESS si se re-abre el canal.</p>
<h4 id="asyncOpen.28.29" name="asyncOpen.28.29">asyncOpen()</h4>
<pre class="eval">void asyncOpen(in nsIStreamListener aListener, in nsISupports aContext);
</pre>
<p>Abre este canal de forma asíncrona. Los datos son enviados al canal de escucha en cuanto están disponibles. El método de escucha es llamado en el mismo hilo en que se encuentra la operación de llamada asyncOpen y no es llamado hasta después del retorno de la función asyncOpen. Si asyncOpen devuelve con éxito, el canal prometo llamar al menos a onStartRequest y onStopRequest.</p>
<p>Si el objeto nsIRequest pasado al método de escucha no está en este canal, es necesario enviar una notificación onChannelRedirect antes de llamar a onStartRequest.</p>
<p>Si llamada de retorno del canal y del grupo de carga no ofrecen un nsIChannelEventSink al hacer la llamada a onChannelRedirect, esto es equivalente a haber llamado a onChannelRedirect.</p>
<p>Si asyncOpen retorna con éxito, el canal es responsable de mantenerse vivo hasta que reciba una llamada onStopRequest en la escucha o se lame a onChannelRedirect.</p>
<p>Las implementaciones tienen permitido añadirse por sí mismas, de forma síncrona, al grupo de carga asociado (si lo hay).</p>
<p>NOTA: Las implementaciones deberían devolver NS_ERROR_ALREADY_OPENED si un canal es re-abierto.</p>
<p>@param aListener the nsIStreamListener implementation @param aContext an opaque parameter forwarded to aListener's methods @see nsIChannelEventSink for onChannelRedirect</p>
<h3 id="Atributos" name="Atributos">Atributos</h3>
<table class="standard-table">
<tbody>
<tr>
<td class="header">Atributo</td>
<td class="header">Tipo</td>
<td class="header">Descripción</td>
</tr>
<tr>
<td><code>originalURI</code></td>
<td><code><a href="es/NsIURI">nsIURI</a></code></td>
<td>La URI original usada para construir el canal. Esto se usa en el caso de una "resolución" de una URI re-dirigida (p.e. resolviendo un recurso: URI a archivo: URI) de forma que la URI original (antes de la redireción) esté disponible.
<p>NOTA: esto es notablemente distinto del Referer de http (URI referente) que es usualmente la página que contenía la URI original (accesible desde nsIHttpChannel).</p>
</td>
</tr>
<tr>
<td><code>URI</code></td>
<td>readonly <code><a href="es/NsIURI">nsIURI</a></code></td>
<td>La URI correspondienter al canal. Su valor es inmutable.</td>
</tr>
<tr>
<td><code>owner</code></td>
<td><code><a href="es/NsISupports">nsISupports</a></code></td>
<td>El dueño, correspondiendo a la entidad que es responsable por este canal. Lo usa el agente de seguridad para otorgar o denegar privilegios al código cargado a través de este canal.
<p>NOTA: esto es una fuerte referencia al dueño, de forma que si este está también manteniendo una fuerte referencia al canal, hay que tener mucho cuidado de cortar explícitamente la referencia al canal.</p>
</td>
</tr>
<tr>
<td><code>notificationCallbacks</code></td>
<td><code><a href="es/NsIInterfaceRequestor">nsIInterfaceRequestor</a></code></td>
<td>Las llamadas de notificación devueltas al canal. Estas son realizadas por el cliente, que quiere ofrecer una forma de recibir notificaciones de progreso, estado o específicas del protocolo. Si este valor es NULL, la implementación del canal puede usar las llamadas devueltas a su grupo de carga. El canal también puede interrogar las llamadas desde su grupo de carga, si las notificaciones que le llegan no ofrecen el interfaz requerido.
<p>Los interfaces usualmente requeridos incluyen: nsIProgressEventSink, nsIPrompt, y nsIAuthPrompt/nsIAuthPrompt2.</p>
<p>Cuando el canal ha terminado, no debe mantener ninguna referencia a estos objetos.</p>
<p>NOTA: Una implementación de un canal debe tener cuidado cuando almacena ("caching") el puntero de un interfaz llamado en una notificación. Si la notificación cambia, el puntero almacenado puede ser invalido y por tanto debería ser buscado de nuevo.</p>
</td>
</tr>
<tr>
<td><code>securityInfo</code></td>
<td>readonly <code><a href="es/NsISupports">nsISupports</a></code></td>
<td>Información de seguridad a nivel transporte (si la hay) correspondiente al canal.</td>
</tr>
<tr>
<td><code>contentType</code></td>
<td>readonly <code><a href="es/ACString">ACString</a></code></td>
<td>El tipo MIME del contenido del canal, si está disponible.
<p>NOTA: el tipo de contenido está, a menudo, incorrectamente especificado (p.e. extensión incorrecta del archivo, tipo MIME incorrecto, tipo de documento equivocado en el servidor, etc.) y es aconsejeble que el llamante verifique los datos propiamente.</p>
<p>Establecer contentType antes de que el canal esté abierto, da una pista al canal sobre que tipo de MIME se va a encontrar. El canal puede ignorar esta pista y decidir el tipo MIME que va a reportar.</p>
<p>Establecer contentType despues de que onStartRequest sea llamado o despues de llamar a open(), sobre escribirá el tipo determinado por el canal.</p>
<p>Establecer contentType en el momento entre que asyncOpen() es llamada y el momento en que se lanza onStartRequest tendrá resultados inpredecibles en este momento.</p>
<p>El valor del atributo contentType es una cadena en minúsculas. El valor asignado a este atributo será analizado y nomalizado de la siguiente forma:</p>
<p>1- cualquier parámetro (delimitado con ';') será desnudado. 2- si se da un parámetro del tipo charset, su valor reemplazará el atributo contentCharset del canal. 3- el valor desnudado será convertido a minúsculas. cualquier implementación de nsIChannel debe seguir estas reglas.</p>
</td>
</tr>
<tr>
<td><code>contentCharset</code></td>
<td>readonly <code><a href="es/ACString">ACString</a></code></td>
<td>El juego de caracteres del contenido del canal si está disponible y es aplicable. Este atributo solo se aplica a datos tipo texto.
<p>El valor del atributo contentCharset es una cadena de mayúsculas y minúsculas.</p>
</td>
</tr>
<tr>
<td><code>contentLength</code></td>
<td>readonly <code><a href="es/Long">long</a></code></td>
<td>La longitud de los datos asociados con el canal si está disponible. Un valor de -1 indica que la longitud es desconocida.
<p>Los llamantes deberían escoger leer la propiedad "content-length" como un valor de 64 bit pasando a través de nsIPropertyBag2, si esta interfaz está disponible al canal.</p>
</td>
</tr>
</tbody>
</table>
<h3 id="Constantes" name="Constantes">Constantes</h3>
<p>Flags de carga específicos del canal:</p>
<p>Los bit 22 a 31 están reservados para un uso futuro de esta interfaz o una de sus derivadas (ejem. ver nsICachingChannel).</p>
<p> </p>
<table class="standard-table">
<tbody>
<tr>
<td class="header">Constante</td>
<td class="header">Valor</td>
<td class="header">Descripción</td>
</tr>
<tr>
<td><code>LOAD_DOCUMENT_URI</code></td>
<td><code>16</code></td>
<td>Establecer (p.e. a través de docshell) para indicar si el canal corresponde o no a un documento URI.</td>
</tr>
<tr>
<td><code>LOAD_RETARGETED_DOCUMENT_URI</code></td>
<td><code>17</code></td>
<td>Si el consumidor final de esta carga ha sido cambiado tras conocer su contenido, este flag será establecido:</td>
</tr>
<tr>
<td><code>LOAD_REPLACE</code></td>
<td><code>18</code></td>
<td>Este flag se establece a para indicar que este canal está reemplazando a otro canal. Esto significa que:
<p>1) se pasó al método asyncOpen la escucha en la que este canal sería notificado, de algún otro canal</p>
<p>y</p>
<p>2) la URI de este canal es un mejor identificador del recurso que está siendo accedido que la URI original del canal.</p>
<p>Este flag puede ser establecido, por ejemplo, por redirectores o en casos en que un solo canal tiene múltiples partes (y por tanto pueden seguir onStopRequest con otro par onStartRequest/onStopRequest, cada par para una petición distinta).</p>
</td>
</tr>
<tr>
<td><code>LOAD_INITIAL_DOCUMENT_URI</code></td>
<td><code>19</code></td>
<td>Establecer (p.e. a través de docshell) para indicar si el canal corresponde o no a la URI original de la carga (e.g., link click).</td>
</tr>
<tr>
<td><code>LOAD_TARGETED</code></td>
<td><code>20</code></td>
<td>Establecer (p.e. por el URILoader) para indicar si el consumidor final para esta carga ha sido determinado.</td>
</tr>
<tr>
<td><code>LOAD_CALL_CONTENT_SNIFFERS</code></td>
<td><code>21</code></td>
<td>Si este flag está establecido, el canal debería llamar al analizador de contenidos según se describe en nsNetCID.h acerca NS_CONTENT_SNIFFER_CATEGORY.
<p>Nota: Los canales pueden ignorar este flag. Sin embargo, la implementación de nuevos canales deberían hacer esto sólo por una buena razón.</p>
</td>
</tr>
</tbody>
</table>
|