1 /* Copyright 2004, 2005, 2006 Acegi Technology Pty Limited 2 * 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS, 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 16 package org.springframework.security.util; 17 18 import javax.servlet.ServletRequest; 19 20 21 /** 22 * A <code>PortResolver</code> determines the port a web request was received 23 * on. 24 * 25 * <P> 26 * This interface is necessary because 27 * <code>ServletRequest.getServerPort()</code> may not return the correct port 28 * in certain circumstances. For example, if the browser does not construct 29 * the URL correctly after a redirect. 30 * </p> 31 * 32 * @author Ben Alex 33 * @version $Id: PortResolver.java 2217 2007-10-27 00:45:30Z luke_t $ 34 */ 35 public interface PortResolver { 36 //~ Methods ======================================================================================================== 37 38 /** 39 * Indicates the port the <code>ServletRequest</code> was received on. 40 * 41 * @param request that the method should lookup the port for 42 * 43 * @return the port the request was received on 44 */ 45 int getServerPort(ServletRequest request); 46 }