zoukankan      html  css  js  c++  java
  • struts2.5+框架使用通配符与动态方法

     概述:struts2.5以后加强了安全性,下面就是安全配置引发的问题

    1. 通配符:

    在学习struts框架时经常会使用到通配符调用方法,如下:

    <package name="usercrud" namespace="/" extends="struts-default">
            <action name="test-*" class="com.gitee.dgwcode.action.UserCrudAction" method="{1}">
                <result name="query">/view/success.jsp</result>
                <!-- <allowed-methods>query,delete,update,insert</allowed-methods> -->
            </action>
        </package>

    其中的action name="user_*"中*这个符号代表的值会传入method=“{1}”中,并对应action类的一个方法名,这样就能很大程度地减少配置文档中action的数目。

    但是在使用这种通配符方法的时候,经常会看到这样的映射错误提示

    Struts Problem Report
    Struts has detected an unhandled exception:
    
    Messages:    
    There is no Action mapped for namespace [/] and action name [test-update] associated with context path [/Struts2_01].

    如果看到提示的是映射问题,你可以按照映射路线排除一遍,

    第一步:先排查访问的链接有没有问题(细节问题)

    第二步:查看struts.xml的配置(仔细排查,出现问题几率很大)

    第三步:查看相关的action类及方法(比如return的值是不是跟配置文件中的result对应得上等)

    第四步:查看结果响应页面是否存在问题(出现问题的几率比较小)

    2.动态方法

    当使用动态调用方法时(action名 + 感叹号 + 方法名进行方法调用),需要将其属性改为true,

    如:query为类中的方法名

        <a href="${pageContext.request.contextPath }/test!query">DynamicMethodInvocation</a><br>

    当使用通配符调用语法时,建议将其属性改为false(struts2.5.2中默认是false)

    当我们需要将其属性改成false时,

    只在struts.xml配置文件中加入此句即可修改属性

    <constant name="struts.enable.DynamicMethodInvocation" value="false" />
    <!-- 动态方法调用 -->
            <action name="test"
                class="com.gitee.dgwcode.action.UserCrudAction">
                <result name="query">/view/success.jsp</result>
                <allowed-methods>query,delete,update,insert</allowed-methods>
            </action>

    总结:<allowed-methods>方法名1,方法名2…</allowed-methods>代码

  • 相关阅读:
    电商平台开发笔记5.nuxt项目中深度选择器解决el-input高度设置无效
    电商平台开发笔记4.css选择器之~波浪号使用
    电商平台开发笔记3.nuxt全局css的引入
    电商平台开发笔记2.Nuxt增加对less支持,解决This relative module was not found报错
    电商平台开发笔记1.Nuxt项目创建+Eslint代码保存自动格式化
    vue-cli 4.x 发布前的一些优化
    VueCli 4.x npm run build后主页空白的原因及解决方案
    VSCode 保存时自动ESlint格式化
    git 常用操作笔记
    VSCode下手动构建webpack项目
  • 原文地址:https://www.cnblogs.com/dgwblog/p/9638045.html
Copyright © 2011-2022 走看看