// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
//
-#if NET_2_0 && SECURITY_DEP
+#if SECURITY_DEP
using System.Collections;
using System.Collections.Generic;
if (lp.Path.IndexOf ('%') != -1)
throw new HttpListenerException (400, "Invalid path.");
- if (lp.Path.IndexOf ("//") != -1) // TODO: Code?
+ if (lp.Path.IndexOf ("//", StringComparison.Ordinal) != -1) // TODO: Code?
throw new HttpListenerException (400, "Invalid path.");
- // Always listens on all the interfaces, no matter the host name/ip used.
- EndPointListener epl = GetEPListener (IPAddress.Any, lp.Port, listener, lp.Secure);
+ // listens on all the interfaces if host name cannot be parsed by IPAddress.
+ EndPointListener epl = GetEPListener (lp.Host, lp.Port, listener, lp.Secure);
epl.AddPrefix (lp, listener);
}
- static EndPointListener GetEPListener (IPAddress addr, int port, HttpListener listener, bool secure)
+ static EndPointListener GetEPListener (string host, int port, HttpListener listener, bool secure)
{
+ IPAddress addr;
+ if (host == "*")
+ addr = IPAddress.Any;
+ else if (IPAddress.TryParse(host, out addr) == false){
+ try {
+ IPHostEntry iphost = Dns.GetHostByName(host);
+ if (iphost != null)
+ addr = iphost.AddressList[0];
+ else
+ addr = IPAddress.Any;
+ } catch {
+ addr = IPAddress.Any;
+ }
+ }
Hashtable p = null; // Dictionary<int, EndPointListener>
if (ip_to_endpoints.ContainsKey (addr)) {
p = (Hashtable) ip_to_endpoints [addr];
if (lp.Path.IndexOf ('%') != -1)
return;
- if (lp.Path.IndexOf ("//") != -1)
+ if (lp.Path.IndexOf ("//", StringComparison.Ordinal) != -1)
return;
- EndPointListener epl = GetEPListener (IPAddress.Any, lp.Port, listener, lp.Secure);
+ EndPointListener epl = GetEPListener (lp.Host, lp.Port, listener, lp.Secure);
epl.RemovePrefix (lp, listener);
}
}