HttpServletRequest
オブジェクトがあります。
この呼び出しがサーブレットに着信する原因となった完全で正確なURLを取得する方法
あるいは、少なくともできる限り正確に、おそらく再生成できるもの(おそらくパラメーターの順序)があるためです。
HttpServletRequest
には以下のメソッドがあります。
getRequestURL()
- クエリ文字列の区切り文字の前のフルURLの一部を返します?
getQueryString()
- クエリ文字列の区切り文字の後のフルURLの一部を返します?
そのため、完全なURLを取得するには、次のようにします。
public static String getFullURL(HttpServletRequest request) {
StringBuilder requestURL = new StringBuilder(request.getRequestURL().toString());
String queryString = request.getQueryString();
if (queryString == null) {
return requestURL.toString();
} else {
return requestURL.append('?').append(queryString).toString();
}
}
私はこの方法を使います。
public static String getURL(HttpServletRequest req) {
String scheme = req.getScheme(); // http
String serverName = req.getServerName(); // hostname.com
int serverPort = req.getServerPort(); // 80
String contextPath = req.getContextPath(); // /mywebapp
String servletPath = req.getServletPath(); // /servlet/MyServlet
String pathInfo = req.getPathInfo(); // /a/b;c=123
String queryString = req.getQueryString(); // d=789
// Reconstruct original requesting URL
StringBuilder url = new StringBuilder();
url.append(scheme).append("://").append(serverName);
if (serverPort != 80 && serverPort != 443) {
url.append(":").append(serverPort);
}
url.append(contextPath).append(servletPath);
if (pathInfo != null) {
url.append(pathInfo);
}
if (queryString != null) {
url.append("?").append(queryString);
}
return url.toString();
}
// http://hostname.com/mywebapp/servlet/MyServlet/a/b;c=123?d=789
public static String getUrl(HttpServletRequest req) {
String reqUrl = req.getRequestURL().toString();
String queryString = req.getQueryString(); // d=789
if (queryString != null) {
reqUrl += "?"+queryString;
}
return reqUrl;
}
Springプロジェクトではあなたが使うことができます
UriComponentsBuilder.fromHttpRequest(new ServletServerHttpRequest(request)).build().toUriString()
HttpUtilは廃止予定であり、これが正しい方法です。
StringBuffer url = req.getRequestURL();
String queryString = req.getQueryString();
if (queryString != null) {
url.append('?');
url.append(queryString);
}
String requestURL = url.toString();
getRequestURL()
と getQueryString()
の結果を組み合わせると、望ましい結果が得られます。
HttpServletRequestオブジェクトで以下のメソッドを使用します。
Java.lang.String getRequestURI() - このリクエストのURLのうち、プロトコル名からHTTPリクエストの最初の行のクエリ文字列までの部分を返します。
Java.lang.StringBuffer getRequestURL() - クライアントがリクエストに使用したURLを再構築します。
Java.lang.String getQueryString() - パスの後の要求URLに含まれるクエリ文字列を返します。
あなたはフィルタを使用することができます。
@Override
public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2) throws IOException, ServletException {
HttpServletRequest test1= (HttpServletRequest) arg0;
test1.getRequestURL()); it gives http://localhost:8081/applicationName/menu/index.action
test1.getRequestURI()); it gives applicationName/menu/index.action
String pathname = test1.getServletPath()); it gives //menu/index.action
if(pathname.equals("//menu/index.action")){
arg2.doFilter(arg0, arg1); // call to urs servlet or frameowrk managed controller method
// in resposne
HttpServletResponse httpResp = (HttpServletResponse) arg1;
RequestDispatcher rd = arg0.getRequestDispatcher("another.jsp");
rd.forward(arg0, arg1);
}
web.xmlのフィルタマッピングに<dispatcher>FORWARD</dispatcher>
を入れることを忘れないでください
パーティーにはやや遅れましたが、私はこれを私の MarkUtils-Webライブラリ in WebUtils に含めました - Checkstyle承認およびJUnitテスト済み:
import javax.servlet.http.HttpServletRequest;
public class GetRequestUrl{
/**
* <p>A faster replacement for {@link HttpServletRequest#getRequestURL()}
* (returns a {@link String} instead of a {@link StringBuffer} - and internally uses a {@link StringBuilder})
* that also includes the {@linkplain HttpServletRequest#getQueryString() query string}.</p>
* <p><a href="https://Gist.github.com/ziesemer/700376d8da8c60585438"
* >https://Gist.github.com/ziesemer/700376d8da8c60585438</a></p>
* @author Mark A. Ziesemer
* <a href="http://www.ziesemer.com."><www.ziesemer.com></a>
*/
public String getRequestUrl(final HttpServletRequest req){
final String scheme = req.getScheme();
final int port = req.getServerPort();
final StringBuilder url = new StringBuilder(256);
url.append(scheme);
url.append("://");
url.append(req.getServerName());
if(!(("http".equals(scheme) && (port == 0 || port == 80))
|| ("https".equals(scheme) && port == 443))){
url.append(':');
url.append(port);
}
url.append(req.getRequestURI());
final String qs = req.getQueryString();
if(qs != null){
url.append('?');
url.append(qs);
}
final String result = url.toString();
return result;
}
}
おそらくこれまでのところ、Mat Banikよりもはるかに速く、最も堅牢な答えがここにあります - しかし彼でさえ、HTTP/HTTPSを使った潜在的な非標準ポート設定を説明していません。
また見なさい:
.getRequestURL()
のStringBufferのビルダーパターンを利用するならば、あなたは三項で単純な一つのライナーを書くことができます:
private String getUrlWithQueryParms(final HttpServletRequest request) {
return request.getQueryString() == null ? request.getRequestURL().toString() :
request.getRequestURL().append("?").append(request.getQueryString()).toString();
}
しかし、それは単なる構文糖です。