Struts2一个Action内包含多个请求处理方法的处理,method的使用方法,struts2中

struts2的关于method=“{1}"意思详解

<action   name= "Login_* "   method= "{1} "   class= "mailreader2.Login ">
中Login_*带*是什么意思?method= "{1} "带{}这个是什么意思?
====================================================
name= "Login_* "
代表这个action处理所有以Login_开头的请求
method= "{1} "
根据前面请求Login_methodname,调用action中的以methodname命名的方法
class= "mailreader2.Login "
action的类名称

如jsp文件中请求Login_validateUser的action名称,根据上面配置,调用action类mailreader2.Login类中方法validateUser()
又如:
对于Login_update请求,将会调用mailreader2.Login的update()方法。

它的用法同webwork中的!符号的作用,相当于是一个通配符。

+++++++++++++++++++++++++++++++++++++++++++++++++++++++

Struts2 学习笔记4--Action Method--接收参数
文章分类:Java编程
struts2中的路径问题
注意:在jsp中”/”表示tomcat服务器的根目录,在struts.xml配置文件中”/”表示webapp的根路径,即MyEclipse web项目中的WebRoot路径。
总结:
struts2中的路径问题是根据action的路径而不是jsp路径来确定,所以尽量不要使用相对路径 。
虽然可以用redirect方式解决,但redirect方式并非必要。
解决办法非常简单,统一使用绝对路径。(在jsp中用request.getContextRoot方式来拿到webapp的路径)
或者使用myeclipse经常用的,指定basePath。

Action Method
配置:
    <package name="user" extends="struts-default" namespace="/user">
        <action name="userAdd" class="com.bjsxt.struts2.user.action.UserAction" method="add">
            <result>/user_add_success.jsp</result>
        </action>
       
        <action name="user" class="com.bjsxt.struts2.user.action.UserAction">
            <result>/user_add_success.jsp</result>
        </action>
    </package>
总结:
Action执行的时候并不一定要执行execute方法
1、可以在配置文件中配置Action的时候用method=来指定执行哪个方法(前者方法)
2、也可以在url地址中动态指定(动态方法调用DMI )(推荐)(后者方法)
<a href="<%=context %>/user/userAdd">添加用户</a>
<br />
<a href="<%=context %>/user/user!add">添加用户</a>
<br />
前者会产生太多的action,所以不推荐使用。(注:<% String context = request.getContextPath(); %>)

再给个案例,大概介绍!使用动态调用DMI的方法,即通过!+方法名的指定方法:

UserAction.java

import com.opensymphony.xwork2.ActionContext;

import java.util.Map;

public class UserAction {
private String userName;
private String password;
 
public String getUserName() {
  return userName;
 }

public void setUserName(String userName) {
  this.userName = userName;
 }

public String getPassword() {
  return password;
 }

public void setPassword(String password) {
  this.password = password;
 }

public String execute(){
  if(!userName.equals("aa")||!password.equals("aa")){
   return "error";
  }else{
   Map session=(Map)ActionContext.getContext().getSession();
   session.put("userName", userName);
   return "success";
  }
 }
 
public String loginOther(){
  if(!userName.equals("bb")||!password.equals("bb")){
   return "error";
  }else{
   Map session=(Map)ActionContext.getContext().getSession();
   session.put("userName", userName);
   return "success";
  }
 }
}

struts.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
 <package name="default" extends="struts-default">
  <action name="struts" class="org.action.StrutsAction">
   <result name="success">/welcome.jsp</result>
   <result name="error">/hello.jsp</result>
   <result name="input">/hello.jsp</result>
  </action>
  <action name="user" class="org.action.UserAction">
   <result name="success">/login_welcome.jsp</result>
   <result name="error">/login_error.jsp</result>
  </action>
  <!--<action name="loginOther" class="org.action.UserAction" method="loginOther">
   <result name="success">/login_welcome.jsp</result>
   <result name="error">/login_error.jsp</result>
  </action>
 -->

</package>

</struts>

login_welcome.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>欢迎</title>

<meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">   
 <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
 <meta http-equiv="description" content="This is my page">
 <!--
 <link rel="stylesheet" type="text/css" href="styles.css">
 -->

</head>
 
  <body>
  <s:set value="#session.userName" name="userName" />
   你好!<s:property value="#userName"/>
  </body>
</html>

login_error.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>登陆失败</title>

<meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">   
 <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
 <meta http-equiv="description" content="This is my page">
 <!--
 <link rel="stylesheet" type="text/css" href="styles.css">
 -->

</head>
 
  <body>
    很抱歉!你的登陆失败了!请重新<a href="login.jsp">登陆</a>
  </body>
</html>

login.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ taglib uri="/struts-tags" prefix="s" %>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
   
    <title>struts 2应用</title>
 <meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">   
 <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
 <meta http-equiv="description" content="This is my page">
 <!--
 <link rel="stylesheet" type="text/css" href="styles.css">
 -->

</head>

<body>
    <s:form  action="user!loginOther" method="post"> 红色部分,你如果想调用userAction中的loginOther方法而不想调用execute方法, 直接通过!+方法名即可,那你就不用再设置struts.xml中注释掉的部分了,这样可以不产生太多的action
<s:textfield name="userName" label="请输入姓名" ></s:textfield> <s:textfield name="password" label="请输入密码"></s:textfield>
 <s:submit value="提交"></s:submit>
 </s:form>
  </body>
</html>

Action Wildcard(Action 通配符)
配置:
    <package name="actions" extends="struts-default" namespace="/actions">
        <action name="Student*" class="com.bjsxt.struts2.action.StudentAction" method="{1}">
            <result>/Student{1}_success.jsp</result>
        </action>
       
        <action name="*_*" class="com.bjsxt.struts2.action.{1}Action" method="{2}">
            <result>/{1}_{2}_success.jsp</result>
            <!-- {0}_success.jsp -->
        </action>
</package>
{1}、{2}表示第一第二个占位符
*为通配符

通过action name的通配匹配,获得占位符,可以使用占位符放在result和method、class中替代匹配的字符。
总结:
使用通配符,将配置量降到最低。
<a href="<%=context %>/actions/Studentadd">添加学生</a>
<a href="<%=context %>/actions/Studentdelete">删除学生</a>
不过,一定要遵守"约定优于配置"的原则。
<a href="<%=context %>/actions/Teacher_add">添加老师</a>
<a href="<%=context %>/actions/Teacher_delete">删除老师</a>
<a href="<%=context %>/actions/Course_add">添加课程</a>
<a href="<%=context %>/actions/Course_delete">删除课程</a>

接收参数值
1、使用action属性接收参数

只需在action加入getter/setter方法,如参数name=a,接受到参数必须有getName/setName方法。

链接:<a href="user/user!add?name=a&age=8">

public class UserAction extends ActionSupport {
   
    private String name;
    private int age;
   
    public String add() {
        System.out.println("name=" + name);
        System.out.println("age=" + age);
        return SUCCESS;
    }

public String getName() {
        return name;
    }

public void setName(String name) {
        this.name = name;
    }

public int getAge() {
        return age;
    }

public void setAge(int age) {
        this.age = age;
    }
}

2、使用Domain Model接收参数
将之前的属性放入到POJO ,并设置属性的setter/getter方法

链接:使用Domain Model接收参数<a href="user/user!add?user.name=a&user.age=8">添加用户</a>

public class UserAction extends ActionSupport {
   
    private User user;
    //private UserDTO userDTO;
    public String add() {
        System.out.println("name=" + user.getName());
        System.out.println("age=" + user.getAge());
        return SUCCESS;
    }

public User getUser() {
        return user;
    }

public void setUser(User user) {
        this.user = user;
    }
   
}
public class User {
    private String name;
    private int age;
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
}

3、使用ModelDriven接收参数
Action实现ModelDriven接口,实现getModel()方法。
这样user需要自己new出来,getModel返回user。

链接:使用ModelDriven接收参数<a href="user/user!add?name=a&age=8">添加用户</a>

public class UserAction extends ActionSupport implements ModelDriven<User> {
   
    private User user = new User();
   
    public String add() {
        System.out.println("name=" + user.getName());
        System.out.println("age=" + user.getAge());
        return SUCCESS;
    }

@Override
    public User getModel() {
        return user;
    }
}

字符编码
配置:
<constant name="struts.i18n.encoding" value="GBK" /> <!-- internationalization -->
在struts2.1.6中不起作用,属于bug,在struts2.1.7中修改。
解决方案:
修改web.xml 中:
  <filter>
      <filter-name>struts2</filter-name>
      <!-- struts2.1中使用filter -->
<!--<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>-->
      <!-- struts2.0中使用的filter -->
<filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
  </filter>

=============================================================

Struts2一个Action内包含多个请求处理方法的处理(三种方式)

Struts1提供了DispatchAction,从而允许一个Action内包含多个请求处理方法。Struts2也提供了类似的功能。处理方式主要有以下三种方式:

1.1. 动态方法调用:

DMI:Dynamic Method Invocation 动态方法调用。

动态方法调用是指:表单元素的action不直接等于某个Action的名字,而是以如下形式来指定对应的动作名:

<form method="post" action="userOpt!login.action">

则用户的请求将提交到名为”userOpt”的Action实例,Action实例将调用名为”login”方法来处理请求。同时login方法的签名也是跟execute()一样,即为public String login() throws Exception。

注意:要使用动态方法调用,必须设置Struts2允许动态方法调用,通过设置struts.enable.DynamicMethodInvocation常量来完成,该常量属性的默认值是true。

1.1.1.    示例:

修改用户登录验证示例,多增加一个注册用户功能。

1.    修改Action类:

package org.qiujy.web.struts2.action;

import com.opensymphony.xwork2.ActionContext;

import com.opensymphony.xwork2.ActionSupport;

publicclass LoginAction extends ActionSupport{

private String userName;

private String password;

private String msg; //结果信息属性

public String getMsg() {

returnmsg;

}

publicvoid setMsg(String msg) {

this.msg = msg;

}

public String getUserName() {

returnuserName;

}

publicvoid setUserName(String userName) {

this.userName = userName;

}

public String getPassword() {

returnpassword;

}

publicvoid setPassword(String password) {

this.password = password;

}

public String login() throws Exception{

if("test".equals(this.userName) && "test".equals(this.password)){

msg = "登录成功,欢迎" + this.userName;

//获取ActionContext实例,通过它来访问Servlet API

ActionContext context = ActionContext.getContext();

//看session中是否已经存放了用户名,如果存放了:说明已经登录了;

//否则说明是第一次登录成功

if(null != context.getSession().get("uName")){

msg = this.userName + ":你已经登录过了!!!";

}else{

context.getSession().put("uName", this.userName);

}

returnthis.SUCCESS;

}else{

msg = "登录失败,用户名或密码错";

returnthis.ERROR;

}

}

public String regist() throws Exception{

//将用户名,密码添加到数据库中

//...

msg = "注册成功。";

returnthis.SUCCESS;

}

}

2.    struts.xml文件:没有什么变化,跟以前一样配置

<!DOCTYPE struts PUBLIC

"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"

"http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

<package name="my" extends="struts-default" namespace="/manage">

<!-- 定义处理请求URL为login.action的Action -->

<action name="userOpt" class="org.qiujy.web.struts2.action.LoginAction">

<!-- 定义处理结果字符串和资源之间的映射关系 -->

<result name="success">/success.jsp</result>

<result name="error">/error.jsp</result>

</action>

</package>

</struts>

3.    页面:

index.jsp

<%@ page language="java" pageEncoding="UTF-8"%>

<html>

<head>

<title>用户登录页面</title>

</head>

<body>

<h2>用户入口</h2>

<hr>

<form action="manage/userOpt!login.action" method="post">

<table border="1">

<tr>

<td>用户名:</td>

<td><input type="text" name="userName"/></td>

</tr>

<tr>

<td>密码:</td>

<td><input type="password" name="password"/></td>

</tr>

<tr>

<td colspan="2">

<input type="submit" value=" 确定 "/>

</td>

</tr>

</table>

</form>

</body>

</html>

regist.jsp

<%@ page language="java" pageEncoding="UTF-8"%>

<html>

<head>

<title>用户注册页面</title>

</head>

<body>

<h2>用户注册</h2>

<hr>

<form action="manage/userOpt!regist.action" method="post">

<table border="1">

<tr>

<td>用户名:</td>

<td><input type="text" name="userName"/></td>

</tr>

<tr>

<td>密码:</td>

<td><input type="password" name="password"/></td>

</tr>

<tr>

<td colspan="2">

<input type="submit" value=" 注册 "/>

</td>

</tr>

</table>

</form>

</body>

</html>

1.2. 为Action配置method属性:

将Action类中的每一个处理方法都定义成一个逻辑Action方法。

<!DOCTYPE struts PUBLIC

"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"

"http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

<package name="my" extends="struts-default" namespace="/manage">

<action name="userLogin" class="org.qiujy.web.struts2.action.LoginAction" method="login">

<result name="success">/success.jsp</result>

<result name="error">/error.jsp</result>

</action>

<action name="userRegist" class="org.qiujy.web.struts2.action.LoginAction" method="regist">

<result name="success">/success.jsp</result>

<result name="error">/error.jsp</result>

</action>

</package>

</struts>

如上,把LoginAction中的login和regist方法都配置成逻辑Action。要调用login方法,则相应的把index.jsp中表单元素的action设置为"manage/userLogin.action";要调用regist方法,把regist.jsp中表单元素的action设置为"manage/userRegist.action"。

1.3. 使用通配符映射(wildcard mappings)方式:

在struts.xml文件中配置<action…>元素时,它的name、class、method属性都可支持通配符,这种通配符的方式是另一种形式的动态方法调用。

当我们使用通配符定义Action的name属性时,相当于用一个元素action定义了多个逻辑Action:

<action name="user_*"

class="org.qiujy.web.struts2.action.UserAction" method="{1}">

<result name="success">/success.jsp</result>

<result name="error">/error.jsp</result>

</action>

如上,<action name=”user_*”>定义一系列请求URL是user_*.action模式的逻辑Action。同时method属性值为一个表达式{1},表示它的值是name属性值中第一个*的值。例如:用户请求URL为user_login.action时,将调用到UserAction类的login方法;用户请求URL为user_regist.action时,将调用到UserAction类的regist方法。

---------------------------=========================--------------------------------------

Struts2中路径问题是一个棘手的问题,初学时经常被路径问题搞得很烦,通过网上查找资料和自己实战中遇到的问题今天来对Struts2中的路径问题来一个总结,当然可能不会很完整,不过后续会进行补充:

1.  Struts2 一个要匹配路径的地方就是在处理完请求之后对页面进行分发的时候,也就是 result 元素里面的内容。

假设项目名为Struts2

在地址栏中访问action时URL基本是以 http://localhost:8080/Struts 开头

比如<action name="home"class="test.HomeAction" namespace="/">

<result name="success">要访问的jsp页面/result>

</action>

这里有两种方式来写要访问的jsp页面,一种加“/”,另一种是不加“/”。

1)jsp页面写成/Pages/path.jsp,那么就会从项目的根路径中开始找也就是,也就是Struts所在的根目录,在一层一层的下去找。

2)jsp页面写成Pages/path.jsp,那么就会从当前路径开始找(注意当前路径是指当前访问者请求的目录),在这个例子中的我们是通过请求action,进而间接访问到jsp文件的,所以当前路径应该就是action所在的路径,在本例中也就是http://localhost:8080/Struts,从这里可以看到当前路径就是根路径,所以两种方式都可以访问到jsp页面,如果当前路径不是根路径那么情况就不同了。

总结:为了不出错,建议加上“/”。

2. 在页面中涉及到匹配路径的问题,在这里我们要弄清楚一个小知识点:在jsp页面中“/”指的是整个站点根路径也就是这里的“http://localhost:8080/”,而不是webapps所在的根路径。

在页面中涉及到的路径问题,看似很复杂,但是解决起来很简单。就是统一用绝对路径,

在jsp文件中可以这样写来统一路径:

<%

StringcontextPath=request.getContextPath();

StringbasePath=requset.getScheme()+"://"+requset.getServerName()+":"+

request.getServerPort()+path+"/";

%>

在<head></head>中写成这样

<baseherf="<%=basePath>">

这说明在该页面中的所有路径都是于项目的WebRoot为相对路径,如项目的WebRoot下的Images/xxx.jpg ,在页面中就直接这样访问。

在页面中的路径问题看似很复杂,但是解决起来相当的简单。

注意:路径最后有“/”。

比如

在地址栏中输入http://localhost:8080/Struts2/path/path.action访问到了my.jsp

在my.jsp的页面中有这样的一个链接:< ahref="index.jsp">并且两者在同一个目录下,按道理说直接点就可以访问的,但是事实上访问不到,地址栏中变成

http://localhost:8080/Struts2/path/index.jsp,为什么为变成这样呢?因为:在my.jsp页面里它不会去看jsp的真正路径在哪里,它只会去看这个jsp映射到我们的服务器的URL地址。

所以访问就不成功。

总之,用了struts2来实现跳转的话想对的就是地址栏中action的访问地址,是以这个地址为标准的。这里强调一下

Html代码  

  1. <base href=”<%=basePath%>”/>

这个意思是指这个jsp页面里所有的<a href=“”/>连接都会在前面加上basePath,不仅仅是这对于<head></head>中的:

Html代码  

  1. <link rel="stylesheet" href="style/css/index.css" type="text/css"

  2. media="screen" charset="utf-8" />

  3. <script src="style/js/jquery.js" type="text/javascript"></script>

也是起作用的。

我在网上看到有个使用这样解决的,这里也记录一下:

Java代码  

  1. 结构:

  2. WebRoot

  3. |

  4. common

  5. |

  6. css

  7. |

  8. common.css

  9. |js

  10. |common.js

  11. <link rel="stylesheet" type="text/css"

  12. href="<c:url value='/common/css/common.css' />" />

  13. <script language="javascript" type="text/javascript"

  14. src="<c:url value='/common/js/common.js'/>"></script>

  15. 然后在jsp 页面中用<c:url>的方式导入css 就永远没有存在跳转后css 无效了,同理js 也一样

=========================================================

用Java开发Web应用时,无论是Jsp页面、Servlet或是web.xml配置文件中都涉及到路径的问题,而这又是初学者较容易混淆的地方,往往不知道如何写路径。其实服务器端和客户端在处理路径的方式上不一致,因此需要根据不同的情况写出正确的路径。下面通过例子来说明。

假设Web应用road中,应用的根路径下有一个dir1文件夹和dir2文件夹。c.jsp在dir1中,a.jsp和b.jsp在dir2中。Web应用的结构如图所示。

+ root
           -dir1
               c.jsp
           -dir2
               a.jsp
               b.jsp

  1. JSP页面中正确的路径表示

假设在a.jsp页面中有两个链接,分别链接到b.jsp和c.jsp页面。

  • 直接写路径表示和页面在同一个文件夹下面,如<a href="b.jsp">b.jsp</a>

  • "../"表示当前文件夹的上一级文件夹(相对路径),如:

<a href="../dir2/b.jsp">b.jsp</a>,
     <a href="../dir1/c.jsp">c.jsp</a>

  • "/"表示 http://机器IP:8080(绝对路径),如:

<a href="/road/dir2/b.jsp">b.jsp</a>
     <a href="/road/dir1/c.jsp">c.jsp</a>

  • Servlet中正确的路径表示

  • 转发请求时:"/"表示“http://服务器IP:8080/Web应用名”,例如:

String forward = "/dir1/c.jsp";
    RequestDispatcher rd = request.getQRequestDispatcher(forward);

  • 重定向时:“/”  表示“http://机器IP:8080”,而通过request.getContextPath()得到的是:“http://机器IP:8080/Web应用名”,例如:

String str =  request.getContextPath();
     response.sendRedirect(str + "/dir1/c.jsp");

  • 配置文件web.xml中

url-mapping中,"/"表示“http://IP地址:8080/Web应用名”

××总结××

  • 在浏览器端:“/”表示的是一台WEB服务器,“http://机器IP:8080”

  • 在服务器端(请求转发):“/”表示的是一个WEB服务器端的应用,“http://机器IP:8080/Web应用”

  • 在服务器端(重定向):“/”表示的是一个WEB服务器,“http://机器IP:8080”

=========================================================

要在/jsp/index.jsp文件使用图片,如何计算相对路径? 经过Servlet,struts转发后又如何计算相对路径

目录结构:

------------------------------------------------------------------------------

第一种情况 :直接访问JSP文件

URL是 http://localhost/Context path/jsp/index.jsp

要在index.jsp引用go.gif文件:

1、使用决对路径

<img src='<%=request.getContextPath() %>/images/go.gif'/>

浏览器寻找方式: 域名+/Context path/images/go.gif   ,可找到。

2、使用相对路径

<img src='../images/go.gif'/>

浏览器寻找方式:通过地址栏分析,index.jsp所在目录(jsp)的上一层目录(WebRoot)下的images/go.gif文件 。

3、使用base href

写<%=request.getContextPath() %>太麻烦,可以在每一个jsp文件顶部加入以下代码

<% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <base href="<%=basePath%>">

<img src='images/go.gif'/>

浏览器寻找方式: basePath的值http://localhost/Context path/再加上images/go.gif,可找到。

------------------------------------------------------------------------------

第二种情况: servlet转发到jsp

1、使用相对路径

URL是http://localhost/Context path/servlet_2   (转发到/jsp/index.jsp)

错误:

根据/jsp/index.jsp路径计算,得到 <img src='../images/go.gif'/>

正确:

<img src='images/go.gif'/>

原因:

index.jsp是保存在服务器端的/jsp/index.jsp目录下面,但通过转发后浏览器并不知道/jsp/目录的存在,因为地址栏中没有体现出来。所以服务器端/jsp/目录并不会对相对路径产生影响

浏览器寻找方式:通过地址栏分析http://localhost/Context path/servlet_2 ,相对于servlet_2所在目录(/)下面找到images/go.gif文件

2、使用相对路径

URL是http://localhost/Context path/servlet/ser/ser/servlet_1 (转发到/jsp/index.jsp)

“/servlet/ser/ser/servlet_1 是在web.xml文件配置的

错误:

根据/jsp/index.jsp路径计算,得到 <img src='../images/go.gif'/>

正确:

<img src='../../../images/go.gif'/>

原因:

index.jsp是保存在服务器端的/jsp/index.jsp目录下面,但通过转发后浏览器并不知道/jsp/目录的存在,因为地址栏中没有体现出来。所以服务器端/jsp/目录并不会对相对路径产生影响

浏览器寻找方式:通过地址栏分析http://localhost/Context path/servlet/ser/ser/servlet_1,相对于servlet_1所在目录(ser)的上一层目录的上一层目录的上一层目录(/)下的images/go.gif文件

 

3、使用决对路径

<img src='<%=request.getContextPath() %>/images/go.gif'/>

------------------------------------------------------------------------------

总结:相对路径是由浏览器通过地址栏分析出来的,与服务器端文件的存放路径没有关系,由其是使用Servlet,struts转发到某jsp文件后,某jsp在服务器端存放的位置是/a/b/c/d/f/g.jsp , 但经过Servlet,struts转发后,浏览器的地址栏可不一定是/a/b/c/d/f/这样的层次。所以相对路径的计算以浏览器地址栏为准。原创地址:http://elf8848.iteye.com/

struts2中可以使用命名空间,来保证浏览器地址栏中的目录层次与服务器端目录层次的一致性,这样程序员通过服务器端的目录层次计算相对路径,在浏览器中也是正常的。

但我们理解了原理,就算不使用命名空间,自己也有强大的控制力。

strut2以及路径的一些问题的更多相关文章

  1. Strut2 spring hibernate 整合

    一.创建web项目工程 wzz 点击finish 2.添加spring Jar包   AOP,Core,Persistence Core ,web jar 点击next 点击Finish 3.配置Da ...

  2. Strut2第一章

    一.Struts2的执行流程: 用户提交一个请求,服务器接收,交给Struts2的核心过滤器进行处理,Struts2的过滤器调用Struts2的一系列处理器来处理(如:解析struts.xml配置文件 ...

  3. mapreduce中一个map多个输入路径

    package duogemap; import java.io.IOException; import java.util.ArrayList; import java.util.List; imp ...

  4. Akka.net路径里的user

    因为经常买双色球,嫌每次对彩票号麻烦,于是休息的时候做了个双色球兑奖的小程序,做完了发现业务还挺复杂的,于是改DDD重做设计,拆分服务,各种折腾...,不过这和本随笔没多大关系,等差不多了再总结一下, ...

  5. java中servlet的各种路径

    1. web.xml中<url-pattern>路径,(叫它Servlet路径!) > 要么以“*”开关,要么为“/”开头 2. 转发和包含路径 > *****以“/”开头:相 ...

  6. 【C#代码实战】群蚁算法理论与实践全攻略——旅行商等路径优化问题的新方法

    若干年前读研的时候,学院有一个教授,专门做群蚁算法的,很厉害,偶尔了解了一点点.感觉也是生物智能的一个体现,和遗传算法.神经网络有异曲同工之妙.只不过当时没有实际需求学习,所以没去研究.最近有一个这样 ...

  7. 使用JavaScript为一张图片设置备选路径

    在做网页开发的时候,有时候希望给图片设置一个备选路径,即,当src属性对应的主路径加载失败的时候,图片可以马上切换到备选路径.这样,即使主路径失效了,显示备用路径也不会影响网页的正常体验. 注意到网页 ...

  8. iOS之开发中一些相关的路径以及获取路径的方法

    模拟器的位置: /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs ...

  9. Android中访问sdcard路径的几种方式

    以前的Android(4.1之前的版本)中,SDcard路径通过"/sdcard"或者"/mnt/sdcard"来表示,而在JellyBean(安卓4.1)系统 ...

随机推荐

  1. 解决 vuex mapGetters 语法报错 (Unexpected token )

    在使用vuex2的mapGetters 和 mapActions 的方法时,借助 stage2 的 Object Rest Operator 特性,可以写出下面代码:  computed: { ... ...

  2. No.10_分数分配

    C#队一共有7名成员,因此团队贡献分一共350分. 分配方式应当反映绝大部分组员的真实贡献情况,即由贡献决定分数. 另外保证一定的奖惩措施,充分调动组员的积极性,鞭策团队向前迈进. 对于团队贡献分数的 ...

  3. 奔跑吧DKY——团队Scrum冲刺阶段-Day 5

    今日完成任务 谭鑫:继续解决背景音乐的问题,修改游戏中的bug. 黄宇塘:背景图片需重做,开始制作人物图片和背景图. 赵晓海:制作人物图及背景图. 方艺雯:制作人物图,编写博客. 王禹涵:继续解决背景 ...

  4. 20162328蔡文琛 week11 大二

    20162328 2017-2018-1 <程序设计与数据结构>第十一周学习总结 教材学习内容总结 在无向图中,表示边的顶点对是无序的. 如果图中的两个顶点之间有边链接,则称它们是领接的. ...

  5. 1、数据库与excel表格的数据导入导出

    1.居民用户界面中,excel数据导入导出: 2.其他5张表数据显示到本角色主页的container容器中.

  6. IIs8 svc

    IIS8中添加WCF支持几种方法小结[图文] 方法一 最近在做Silverlight,Windows Phone应用移植到Windows 8平台,在IIS8中测试一些传统WCF服务应用,发现IIS8不 ...

  7. TCP/IP,HTTP,HTTPS,WEBSocket协议

    我看看着挺多的,我暂时没时间自己写,有需要的请借鉴 http://mp.weixin.qq.com/s?__biz=MzI0MDQ4MTM5NQ==&mid=2247486927&id ...

  8. SGU 223 little kings BSOJ2772 状压DP

    1896 [SCOI2005]互不侵犯King [问题描述]在n*n(1<=n<=10)的棋盘上放k(0<=k<=n*n)个国王(可攻击相邻的8 个格子),求使它们无法互相攻击 ...

  9. 51单片机,keilc51,如何使用data变量超过128怎么办

    将堆栈指针SP指向128之后.如果你定义了数组.将数组定义为Idata.很难想象单个变量使用,你能用尽128个data类内存单元.如果真的用尽了,那只有将访问频率低的内存单元放到idata类去.总之, ...

  10. SQL语句中order_by_、group_by_、having的用法区别

    order by 从英文里理解就是行的排序方式,默认的为升序. order by 后面必须列出排序的字段名,可以是多个字段名. group by 从英文里理解就是分组.必须有“聚合函数”来配合才能使用 ...