使用嵌入式tomcat,此代码:
System.out.println("getServletPath: " + request.getServletPath()); System.out.println("getServletContext: " + request.getServletContext().getContextPath()); System.out.println("getServerName: " + request.getServerName()); System.out.println("getServerPort: " + request.getServerPort());
打印输出:
getServletPath: /example getServletContext: getServerName: localhost getServerPort: 9090
这是否意味着:
request.getRequestDispatcher("/example/read.jsp").forward(request, response);
将查看此URL到forward(request, response)JSP:
forward(request, response)
http://localhost:9090/example/read.jsp?
http://localhost:9090/example/read.jsp
有没有办法打印出要寻址的 绝对 URL getRequestDispatcher("relativePath")?
getRequestDispatcher("relativePath")
该Servlet规范解释了这个
该getRequestDispatcher方法采用一个String参数,该参数描述ServletContext范围内的路径。 该路径必须相对于ServletContext的根,并且以’/’开头,或者为空 。该方法使用 第12章“将请求映射到Servlet”中的servlet路径匹配规则 来使用该路径查找servlet,并用RequestDispatcher对象包装它,然后返回结果对象。如果无法根据给定的路径解析servlet,则将提供RequestDispatcher,以返回该路径的内容。
getRequestDispatcher
String
这些规则如下
容器将尝试查找请求路径与Servlet路径的精确匹配。成功匹配将选择servlet。 容器将递归地尝试匹配最长的路径前缀。这是通过使用“ /”字符作为路径分隔符,一次将路径树下移到一个目录来完成的。最长的匹配确定所选的servlet。 3. 如果URL路径中的最后一段包含扩展名(例如.jsp),则servlet容器将尝试匹配处理该扩展名请求的servlet。扩展名定义为最后一个段之后的最后一个段的一部分。字符。 如果前三个规则均未导致servlet匹配,则容器将尝试提供适合于所请求资源的内容。如果为应用程序定义了“默认” servlet,则将使用它。许多容器提供了隐式默认servlet来提供内容。
你问
这是否意味着: request.getRequestDispatcher(“ / example / display.jsp”)。forward(request,response); 将查看此URL以转发(请求,响应)到JSP: http://localhost:9090/example/display.jsp?
request.getRequestDispatcher(“ / example / display.jsp”)。forward(request,response); 将查看此URL以转发(请求,响应)到JSP:
http://localhost:9090/example/display.jsp?
http://localhost:9090/example/display.jsp
不,它不发送HTTP请求,因此该路径与URI无关。Servlet容器将尝试将其与Servlet的各种url映射相匹配,这更多是一条内部路径。
你也问
有没有办法打印出绝对URL getRequestDispatcher(“ relativePath”)正在解决的问题?
不,它也不是绝对URL。Web应用程序上下文中的某些资源可以处理该路径。
编辑后,您addWebapp进入Tomcat实例。
addWebapp
Tomcat
tomcat.addWebapp(null, "/view2/example2", new File("src/com/example/view/example").getAbsolutePath());
然后,您将请求发送给
/view2/example2/read.jsp
我要假设那read.jsp是
read.jsp
src/com/example/view/example/
我相信它在Web应用程序的公共可访问部分中,因此Servlet容器可以呈现它并做出响应。
您还添加了一个Webapp addContext,看起来与addWebapp
addContext
context = tomcat.addContext("", base.getAbsolutePath());
并将servlet映射添加 到此 上下文。
Tomcat.addServlet(context, "example", new ExampleController()); context.addServletMapping("/example/*", "example");
我对/example/*无法处理感到错误/example。
/example/*
/example
当您发送请求至
由于上下文路径为“”,因此Context将使用以上内容,并且映射将匹配ExampleController上面的注册内容。您的Servlet代码将执行并到达
Context
ExampleController
Servlet
request.getRequestDispatcher("/view2/example2/read.jsp").forward(request, response);
注意的javadoc ServletRequest#getRequestDispatcher(String)
ServletRequest#getRequestDispatcher(String)
指定的路径名可以是相对的,尽管它不能扩展到当前servlet上下文之外。
换句话说,本Servlet,ExampleController被登记在ServletContext映射到上下文路径"",即。根。路径/view2/example2/read.jsp是指另一个上下文。由于此上下文没有映射,因此将以404响应。
ServletContext
""
您可以在不同的上下文中获得对另一个Web应用程序的引用。您必须使用ServletContext#getContext(String)。例如
ServletContext#getContext(String)
ServletContext otherContext = request.getServletContext().getContext("/view2/example2");
现在有了ServletContext,您可以RequestDispatcher在 该 上下文中获取资源的。
RequestDispatcher
otherContext.getRequestDispatcher("/read.jsp").forward(request, response);
因为ServletContext#getRequestDispatcher(String)状态
ServletContext#getRequestDispatcher(String)
路径名必须以/开头,并被解释为相对于当前上下文根。
最终答案:
getRequestDispatcher("path")``addWebapp引用JSP文件时,将查看方法中设置的目录。如果NullPointerException显示空白页或,请确保已完成以下操作:
getRequestDispatcher("path")``addWebapp
NullPointerException
addWebApp
ROOT
File base = new File("src/com/example/view"); context = tomcat.addContext("", base.getAbsolutePath()); tomcat.addWebapp(null, "/", base.getAbsolutePath());
"src/com/example/view"