Programing

URL을 완성하기위한 HttpServletRequest

lottogame 2020. 4. 18. 09:28
반응형

URL을 완성하기위한 HttpServletRequest


나는이 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;
}

HttpUtil은 더 이상 사용되지 않습니다. 올바른 방법입니다.

StringBuffer url = req.getRequestURL();
String queryString = req.getQueryString();
if (queryString != null) {
    url.append('?');
    url.append(queryString);
}
String requestURL = url.toString();

Spring 프로젝트에서 사용할 수 있습니다

UriComponentsBuilder.fromHttpRequest(new ServletServerHttpRequest(request)).build().toUriString()

의 결과를 결합 getRequestURL()하고하는 것은 getQueryString()당신에게 원하는 결과를 얻을 수 있습니다.


filter를 사용할 수 있습니다.

@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);





    }

<dispatcher>FORWARD</dispatcher>web.xml에 필터 매핑 을 넣는 것을 잊지 마십시오


HttpServletRequest 객체에서 다음 메소드를 사용하십시오.

java.lang.String getRequestURI ()- 이 요청의 URL 부분을 프로토콜 이름에서 HTTP 요청의 첫 번째 행에있는 쿼리 문자열까지 리턴합니다.

java.lang.StringBuffer getRequestURL ()- 클라이언트가 요청을하는 데 사용한 URL을 재구성합니다.

java.lang.String getQueryString ()- 경로 뒤의 요청 URL에 포함 된 쿼리 문자열을 리턴합니다.


다소 늦게 파티에,하지만 난 내이 포함 MarkUtils - 웹 라이브러리 에서 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.">&lt;www.ziesemer.com&gt;</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로 잠재적 인 비표준 포트 구성을 설명하지는 않습니다.

또한보십시오:


삼항으로 간단한 하나의 라이너를 작성할 수 있고 다음에서 StringBuffer의 빌더 패턴을 사용하는 경우 .getRequestURL():

private String getUrlWithQueryParms(final HttpServletRequest request) { 
    return request.getQueryString() == null ? request.getRequestURL().toString() :
        request.getRequestURL().append("?").append(request.getQueryString()).toString();
}

그러나 그것은 단지 구문 설탕입니다.

참고 URL : https://stackoverflow.com/questions/2222238/httpservletrequest-to-complete-url

반응형