• struts2 命名空间 namespace 学习


     默认的命名空间“ namespace="" ”。 根命名空间  namespace="/" ”。   

        <package name="test" extends="struts-default"> ,假设未指定命名空间,则命名空间默觉得  namespace="" ”。

        默认命名空间里的Action能够处理不论什么命名空间下的Action请求。

    比如,假设存在URL为/barspace/bar.action的请求,而且/barspace的命名空间下没有名为bar的Action,则默认命名空间下名为bar的Action也会处理用户请求。但根命名空间下的Action仅仅处理根命名空间下的Action的请求,这是根命名空间和默认命名空间的差别。

        命名空间仅仅有一个级别。假设请求的URL是/bookservice/search/get.action。系统将先在/bookservice/search的命名空间下查找名为get的Action,假设在该命名空间内找到名为get的Action。则由该Action处理用户的请求。假设未找到。系统将直接进入默认的命名空间中查找名为get的Action,而不会在/bookservice的命名空间下查找名为get的Action 。


    在struts2中,Action的名称的搜索时遵循一定原则的。以下就是struts2在请求到来后。怎么去找到合适的action进行调用。总结例如以下 (获得请求路径的URI。比如url是:http://server/struts2/path1/path2/path3/test.action):
          1.首先寻找namespace为/path1/path2/path3的package。假设不存在这个package则运行步骤2;假设存在这个 package,则在这个package中寻找名字为test的action,当在该package下寻找不到action 时就会直接跑到默认namaspace的package里面去寻找action(默认的命名空间为空字符串""),假设在默认namaspace的 package里面还寻找不到该action,页面提示找不到action。
          2.寻找namespace为/path1/path2的package,假设不存在这个package。则转至步骤3;假设存在这个package,则在这个package中寻找名字为test的action,当在该package中寻找不到action 时就会直接跑到默认namaspace的package里面去找名字为test的action ,在默认namaspace的package里面还寻找不到该action,页面提示找不到action。
          3.寻找namespace为/path1的package。假设不存在这个package则运行步骤4;假设存在这个package。则在这个 package中寻找名字为test的action,当在该package中寻找不到action 时就会直接跑到默认namaspace的package里面去找名字为test的action ,在默认namaspace的package里面还寻找不到该action。页面提示找不到action。
          4.寻找namespace为/的package,假设存在这个package,则在这个package中寻找名字为test的action。当在 package中寻找不到action或者不存在这个package时,都会去默认namaspace的package里面寻找action,假设还是找不到。页面提示找不到action。
        总的来说。就是相当于是最大匹配原则。假设一直没有匹配的。则一级一级往上找。直至根文件夹。假设在某处出现了匹配路径。则去那个名称空间下找 action。这个时候假设找不到,就直接跳到默认package中去找了。假设仍然找不到。那就仅仅能报错了。

    所以说,这个寻找过程是先匹配大的名称空间,有匹配了才去找对应的action,假设在匹配的名称空间没有须要的action,则直接跳到默认包中找,不会再次跳回去匹配名称空间

  • 相关阅读:
    shell 中的expect 用法
    Python下安装protobuf
    google protobuf 中的proto文件编写规则
    ubuntu 16.04 安装grpc
    python 常见的错误类型 和 继承关系
    倒排索引
    python 调用c函数
    python中的re模块,常用函数介绍
    leecode第二十二题(括号生成)
    leecode第十九题(删除链表的倒数第N个节点)
  • 原文地址:https://www.cnblogs.com/liguangsunls/p/6747574.html
Copyright © 2020-2023  润新知