一、绝对路径和相对路径

①开发时建议使用据对路径,使用绝对路径肯定没有问题,但是用相对路径可能会有问题。

在由Servlet转发到JSP页面时,此时在浏览器地址栏显示Sevvlet路径,若JSP页面的超链接还是相对与该JSP页面的地址,

则可能会出现路径混乱的问题。

例如: A.jsp———>B.jsp———>C.jsp


(子目录)/Demo7_RelativePathAndAbsolutePath/A.jsp
:<a href="B.jsp">To B Page</a> (子目录)/Demo7_RelativePathAndAbsolutePath/B.jsp
:<a href="../C.jsp">To C Page</a> (根目录)/C.jsp
:<a href="Demo7_RelativePathAndAbsolutePath/A.jsp">To A Page</a>

一般开发过程中页面之间不会进行跳转,都使用Servlet进行中转之后在选择跳转的页面

(子目录)
<a href="<%=request.getContextPath()%>/Demo7_RelativePathAndAbsolutePath/B.jsp">To B Page</a>
(子目录)<a href="<%=request.getContextPath() %>/C.jsp">To C Page</a>
(根目录)<a href="<%=request.getContextPath()%>/pathServlet">To A Page</a>
Servlet:
@WebServlet("/pathServlet")
public class PathServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { List<String> cities = Arrays.asList("北京","上海","广州");
request.setAttribute("cities", cities); //通过转发的方式响应C.jsp
request.getRequestDispatcher("/Demo7_RelativePathAndAbsolutePath/A.jsp").
forward(request, response);
} }

②绝对路径:相对与当前web应用的根路径的路径。即任何路径都要带上ContextPath

例如http://localhost:8080/Demo7_Cookie_Session/C.jsp,C.jsp就可以说是绝对路径

③如何使用绝对路径:

若/代表的是站点的根目录,在其前面加上contextPath()即可,而contextPath可以由request或

application的getContextPath()方法获取。

例如:

        <a href="<%=request.getContextPath()%>/Demo7_RelativePathAndAbsolutePath/B.jsp">
To B Page</a>
<a href="<%=request.getContextPath() %>/C.jsp">To C Page</a>
<a href="<%=request.getContextPath()%>/pathServlet">To A Page</a>
    request.getRequestDispatcher("/Demo7_RelativePathAndAbsolutePath/A.jsp").
forward(request, response);

2.JavaWeb开发过程中/代表什么

①当前web应用的根路径:http://localhost:8080/Demo7_Cookie_Session/容器

其中/交由Servlet来处理

1).request请求转发时:
request.getRequestDispatcher("/Demo7_RelativePathAndAbsolutePath/A.jsp").
forward(request, response);
2).web.xml文件中Servlet-mapping: <servlet-mapping>
<serlet-name>step2Servlet</servlet-name>
<url-pattern>/step2Servlet</url-pattern>
</servlet-mapping> 3).各种定制标签

②web站点的根路径:http://localhost:8080/

其中交由浏览器处理

        1).超链接
<a href="/pathServlet">To A Page</a>
2).表单中的action
<form action="/index.jsp" method="post"></form>
3).做请求重定向的时候
response.sendRedirect("/step-2.jsp");

二、Servlet注解和Servlet配置文件

在Servlet3.0之前使用Servlet都需要在web.xml中配置Servlet,Servlet3.0之后可以使用@WebServlet注解的方式进行配置,使用方便。所以不管是在超链接或者form表单的action中都可以使用这两种方式,但是还是action中使用多一点,一般不会页面之间互相访问,而且action中同时也使用绝对路径,以免造成混乱。

方式一在web.xml中配置:

 <servlet>
<display-name>step1Servlet</display-name>
<servlet-name>step1Servlet</servlet-name>
<servlet-class>com.shopCart.Servelt.Step1Servlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>step1Servlet</servlet-name>
<url-pattern>/step1Servlet</url-pattern>
</servlet-mapping>

方式二:使用@WebServlet注解


@WebServlet("/pathServlet")
public class PathServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { List<String> cities = Arrays.asList("北京","上海","广州");
request.setAttribute("cities", cities); //通过转发的方式响应C.jsp
request.getRequestDispatcher("/Demo7_RelativePathAndAbsolutePath/A.jsp").
forward(request, response);
} }

注意:这两种方式不能同时使用,否则会出现异常:

Server Tomcat v7.0 Server at localhost failed to start.

Caused by: java.lang.IllegalArgumentException: The servlets named [step1Servlet] and [com.shopCart.Servelt.Step1Servlet] are both mapped to the url-pattern [/step1Servlet] which is not permitted

JSP(2)—绝对路径与相对路径、配置Servlet与Servlet注解的更多相关文章

  1. Struts 之 通配符 路径匹配 常量用法 配置默认值

    Struts 框架学习 Action的开发的几种方式 方式1 : 继承ActionSupport     如果使用Struts校验功能,必须继承此类 方式2 : 实现Action接口 方式3 :不继承 ...

  2. java web中servlet、jsp、html 互相访问的路径问题

    java web中servlet.jsp.html 互相访问的路径问题 在java web种经常出现 404找不到网页的错误,究其原因,一般是访问的路径不对. java web中的路径使用按我的分法可 ...

  3. jsp和java获取文件或路径

    1.如何获得当前文件路径常用:(1).Test.class.getResource("")得到的是当前类FileTest.class文件的URI目录.不包括自己!(2).Test. ...

  4. postgresql pgsql最新版安装指南及数据存储路径更改及主从配置

    postgresql pgsql最新版安装指南及数据存储路径更改及主从配置 安装指南 首先在apt的list添加你当前系统版本对应的apt列表 目前官网有16.04,14.04,12.04 分别对应下 ...

  5. xcode配置绝对路径与相对路径

     一般我们在xcode里面配置包含工程目录下头文件的时候,都要关联着相对路径和绝对路径,如果只是自己用这个项目,用绝对路径的问题不大,但是如果你把工程发给别人,别人就要在改这个绝对路径,这时候绝对路径 ...

  6. IIS7错误:不能在此路径中使用此配置节。如果在父级别上锁定了该节,便会出现这种情况。锁定是默认设置的(overrideModeDefault="Deny")......

    不能在此路径中使用此配置节.如果在父级别上锁定了该节,便会出现这种情况.锁定是默认设置的(overrideModeDefault="Deny")...... 解决方案: 因为 II ...

  7. IIS关于“ 配置错误 不能在此路径中使用此配置节”的解决办法

    IIS关于“ 配置错误 不能在此路径中使用此配置节”的解决办法 原文链接:http://www.cnblogs.com/200325074/p/3679316.html 今天刚安装好IIS8.5, 我 ...

  8. 【转】JSP中的相对路径和绝对路径

    1.首先明确两个概念: 服务器路径:形如:http://192.168.0.1/的路径 Web应用路径:形如:http://192.168.0.1/yourwebapp的路径 2.关于相对路径与绝对路 ...

  9. jsp中如何获得url路径和绝对路径

    jsp中如何获得url路径 request.getHeader("referer") JSP中获得当前应用的相对路径和绝对路径 根目录所对应的绝对路径:request.getReq ...

随机推荐

  1. angular 4 开发环境下打包文件过大

    angular 4本地开发环境下,ng server -- port 8080 -o 之后在在浏览器中查看数据请求,其中vendor.bundle.js有8.3mb,而整个传输数据大小为16.3mb ...

  2. nginx 301重定向一种实现方法

    假设要使用的域名是b.com,以前的老域名是a.com,则以下设置让nginx把a.com的请求访问转发到b.com,并返回301给浏览器. server { listen 80; server_na ...

  3. 解决背景图文字盖住html里面的dom元素

    width:100%; background: url('../images/res.jpg') no-repeat 0 0px; background-attachment:fixed; backg ...

  4. springmvc+ajax——第三讲(post请求)

    在ajax01.html中增加个input标签: 在ajax的js中增加: 在controller中仍然使用getParamter():

  5. systemd创建自定义服务(Ubuntu)

    /lib/systemd/system下创建test.service文件 vim /lib/systemd/system/test.service [Unit] Description=test [S ...

  6. CodeForces 433C Ryouko's Memory Note (中位数定理)

    <题目链接> 题目大意:给你一堆数字,允许你修改所有相同的数字成为别的数字,不过只能修改一次,问你修改后序列相邻数字的距离和最小是多少. 解题分析: 首先,修改不是任意的,否则那样情况太多 ...

  7. SpringBoot使用JdbcTemplate

    前言 本文是对SpringBoot使用JdbcTemplate操作数据库的一个介绍,,提供一个小的Demo供大家参考. 操作数据库的方式有很多,本文介绍使用SpringBoot结合JdbcTempla ...

  8. vscode那些事儿

    2015年,微软发布了Visual Studio Code 一.编辑器配置 下面介绍两种方案. 1.设置文件 文件 -> 首选项 -> 设置vscode的字体大小,缩进. { " ...

  9. 如何在github上搭建网站?

    3年前就想写这篇文章了,一直没写,拖到现在,迟到总比不到好,哈哈.github pages只支持静态博客(html,css,js),不支持服务端(php,physon). 一.尝试一下 1.在电脑上安 ...

  10. Vuejs学习笔记(一)

    1)    vue.js 的 主要功能 1.模板渲染 2.模块化 3.扩展功能:路由,Ajax 2)    vue.js 模板渲染之双向绑定示例 message 绑定到了 input 对象,所有在in ...