`
Kenny.Lee
  • 浏览: 514904 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

【转】Struts2 result返回类型(type)小结

 
阅读更多

 

struts2的返回结果配置中,我们大部分情况使用默认的或者chain或者redirect,其实struts2还有很多其他类型的,今天我们就来看一下都有哪些类型。

打开struts2的源码中struts-default.xml文件,我们能看到如下配置

< xmlnamespace prefix ="v" ns ="urn:schemas-microsoft-com:vml" />< xmlnamespace prefix ="o" ns ="urn:schemas-microsoft-com:office:office" />

 

 

<package name="struts-default" abstract="true">

 

        <result-types>

            <result-type name="chain"class="com.opensymphony.xwork2.ActionChainResult"/>

            <result-type name="dispatcher"class="org.apache.struts2.dispatcher.ServletDispatcherResult" default="true"/>

            <result-type name="freemarker"class="org.apache.struts2.views.freemarker.FreemarkerResult"/>

            <result-type name="httpheader"class="org.apache.struts2.dispatcher.HttpHeaderResult"/>

            <result-type name="redirect"class="org.apache.struts2.dispatcher.ServletRedirectResult"/>

            <result-type name="redirectAction"class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/>

            <result-type name="stream"class="org.apache.struts2.dispatcher.StreamResult"/>

            <result-type name="velocity"class="org.apache.struts2.dispatcher.VelocityResult"/>

            <result-type name="xslt"class="org.apache.struts2.views.xslt.XSLTResult"/>

            <result-type name="plainText"class="org.apache.struts2.dispatcher.PlainTextResult" />

            <!-- Deprecated name form scheduled for removal in Struts 2.1.0. The camelCase versions are preferred. See ww-1707 -->

            <result-type name="redirect-action"class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/>

            <result-type name="plaintext"class="org.apache.struts2.dispatcher.PlainTextResult" />

        </result-types>

 

类型

chain

描述

用来处理Action链,被跳转的action中仍能获取上个页面的值,如request信息。

使用的类

com.opensymphony.xwork2.ActionChainResult

类型

dispatcher

描述

用来转向页面,通常处理JSP

使用的类

org.apache.struts2.dispatcher.ServletDispatcherResult

类型

freemaker

描述

处理FreeMarker模板

使用的类

org.apache.struts2.views.freemarker.FreemarkerResult

类型

httpheader

描述

控制特殊HTTP行为的结果类型

使用的类

org.apache.struts2.dispatcher.HttpHeaderResult

类型

stream

描述

向浏览器发送InputSream对象,通常用来处理文件下载,还可用于返回AJAX数据

使用的类

org.apache.struts2.dispatcher.StreamResult

类型

velocity

描述

处理Velocity模板

使用的类

org.apache.struts2.dispatcher.VelocityResult

类型

xslt

描述

处理XML/XLST模板

使用的类

org.apache.struts2.views.xslt.XSLTResult

类型

plainText

描述

显示原始文件内容,例如文件源代码

使用的类

org.apache.struts2.dispatcher.PlainTextResult

类型

plaintext

描述

显示原始文件内容,例如文件源代码

使用的类

org.apache.struts3.dispatcher.PlainTextResult

类型

redirect

描述

重定向到一个URL ,被跳转的页面中丢失传递的信息,如request

使用的类

org.apache.struts2.dispatcher.ServletRedirectResult

类型

redirectAction

描述

重定向到一个Action ,跳转的页面中丢失传递的信息,如request

使用的类

org.apache.struts2.dispatcher.ServletActionRedirectResult

类型

redirect-action

描述

重定向到一个Action ,跳转的页面中丢失传递的信息,如request

使用的类

org.apache.struts2.dispatcher.ServletActionRedirectResult

1redirectredirect-action区别

一、使用redirect需要后缀名 使用redirect-action不需要后缀名

二、type="redirect" 的值可以转到其它命名空间下的action,redirect-action只能转到同一命名空下的 action,因此它可以省略.action的后缀直接写action的名称。

如:

<result name="success" type="redirect">yhj.do</result>

<result name="success" type="redirect-action">yhj</result>
2默认的<result>标签的type属性值是“dispatcher”

附录:struts-default源码

<?xml version="1.0" encoding="UTF-8" ?>

<!--

/*

 * $Id: struts-default.xml 694960 2008-09-13 15:01:00Z rgielen $

 *

 * Licensed to the Apache Software Foundation (ASF) under one

 * or more contributor license agreements.  See the NOTICE file

 * distributed with this work for additional information

 * regarding copyright ownership.  The ASF licenses this file

 * to you under the Apache License, Version 2.0 (the

 * "License"); you may not use this file except in compliance

 * with the License.  You may obtain a copy of the License at

 *

 *  http://www.apache.org/licenses/LICENSE-2.0

 *

 * Unless required by applicable law or agreed to in writing,

 * software distributed under the License is distributed on an

 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY

 * KIND, either express or implied.  See the License for the

 * specific language governing permissions and limitations

 * under the License.

 */

-->

 

<!DOCTYPE struts PUBLIC

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

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

 

<struts>

    <bean class="com.opensymphony.xwork2.ObjectFactory" name="xwork" />

    <bean type="com.opensymphony.xwork2.ObjectFactory" name="struts"class="org.apache.struts2.impl.StrutsObjectFactory" />

 

    <bean type="com.opensymphony.xwork2.ActionProxyFactory" name="xwork"class="com.opensymphony.xwork2.DefaultActionProxyFactory"/>

    <bean type="com.opensymphony.xwork2.ActionProxyFactory" name="struts"class="org.apache.struts2.impl.StrutsActionProxyFactory"/>

 

    <bean type="com.opensymphony.xwork2.util.ObjectTypeDeterminer" name="tiger"class="com.opensymphony.xwork2.util.GenericsObjectTypeDeterminer"/>

    <bean type="com.opensymphony.xwork2.util.ObjectTypeDeterminer" name="notiger"class="com.opensymphony.xwork2.util.DefaultObjectTypeDeterminer"/>

    <bean type="com.opensymphony.xwork2.util.ObjectTypeDeterminer" name="struts"class="com.opensymphony.xwork2.util.DefaultObjectTypeDeterminer"/>

 

    <bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="struts"class="org.apache.struts2.dispatcher.mapper.DefaultActionMapper" />

    <bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="composite"class="org.apache.struts2.dispatcher.mapper.CompositeActionMapper" />

    <bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="restful"class="org.apache.struts2.dispatcher.mapper.RestfulActionMapper" />

    <bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="restful2"class="org.apache.struts2.dispatcher.mapper.Restful2ActionMapper" />

 

    <bean type="org.apache.struts2.dispatcher.multipart.MultiPartRequest"name="struts"class="org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest"scope="default" optional="true"/>

    <bean type="org.apache.struts2.dispatcher.multipart.MultiPartRequest"name="jakarta"class="org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest"scope="default" optional="true" />

 

    <bean type="org.apache.struts2.views.TagLibrary" name="s"class="org.apache.struts2.views.DefaultTagLibrary" />

 

    <bean class="org.apache.struts2.views.freemarker.FreemarkerManager"name="struts" optional="true"/>

    <bean class="org.apache.struts2.views.velocity.VelocityManager" name="struts"optional="true" />

 

    <bean class="org.apache.struts2.components.template.TemplateEngineManager" />

    <bean type="org.apache.struts2.components.template.TemplateEngine" name="ftl"class="org.apache.struts2.components.template.FreemarkerTemplateEngine" />

    <bean type="org.apache.struts2.components.template.TemplateEngine" name="vm"class="org.apache.struts2.components.template.VelocityTemplateEngine" />

    <bean type="org.apache.struts2.components.template.TemplateEngine" name="jsp"class="org.apache.struts2.components.template.JspTemplateEngine" />

 

    <bean type="com.opensymphony.xwork2.util.XWorkConverter" name="xwork1"class="com.opensymphony.xwork2.util.XWorkConverter" />

    <bean type="com.opensymphony.xwork2.util.XWorkConverter" name="struts"class="com.opensymphony.xwork2.util.AnnotationXWorkConverter" />

    <bean type="com.opensymphony.xwork2.TextProvider" name="xwork1"class="com.opensymphony.xwork2.TextProviderSupport" />

    <bean type="com.opensymphony.xwork2.TextProvider" name="struts"class="com.opensymphony.xwork2.TextProviderSupport" />

 

    <!--  Only have static injections -->

    <bean class="com.opensymphony.xwork2.ObjectFactory" static="true" />

    <bean class="com.opensymphony.xwork2.util.XWorkConverter" static="true" />

    <bean class="com.opensymphony.xwork2.util.OgnlValueStack" static="true" />

    <bean class="com.opensymphony.xwork2.validator.ValidatorFileParser"static="true" />

    <bean class="org.apache.struts2.dispatcher.Dispatcher" static="true" />

    <bean class="org.apache.struts2.components.Include" static="true" />

    <bean class="org.apache.struts2.dispatcher.FilterDispatcher" static="true" />

    <bean class="org.apache.struts2.views.util.ContextUtil" static="true" />

    <bean class="org.apache.struts2.views.util.UrlHelper" static="true" />

 

    <package name="struts-default" abstract="true">

        <result-types>

            <result-type name="chain"class="com.opensymphony.xwork2.ActionChainResult"/>

            <result-type name="dispatcher"class="org.apache.struts2.dispatcher.ServletDispatcherResult" default="true"/>

            <result-type name="freemarker"class="org.apache.struts2.views.freemarker.FreemarkerResult"/>

            <result-type name="httpheader"class="org.apache.struts2.dispatcher.HttpHeaderResult"/>

            <result-type name="redirect"class="org.apache.struts2.dispatcher.ServletRedirectResult"/>

            <result-type name="redirectAction"class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/>

            <result-type name="stream"class="org.apache.struts2.dispatcher.StreamResult"/>

            <result-type name="velocity"class="org.apache.struts2.dispatcher.VelocityResult"/>

            <result-type name="xslt"class="org.apache.struts2.views.xslt.XSLTResult"/>

            <result-type name="plainText"class="org.apache.struts2.dispatcher.PlainTextResult" />

            <!-- Deprecated name form scheduled for removal in Struts 2.1.0. The camelCase versions are preferred. See ww-1707 -->

            <result-type name="redirect-action"class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/>

            <result-type name="plaintext"class="org.apache.struts2.dispatcher.PlainTextResult" />

        </result-types>

 

 

        <interceptors>

            <interceptor name="alias"class="com.opensymphony.xwork2.interceptor.AliasInterceptor"/>

            <interceptor name="autowiring"class="com.opensymphony.xwork2.spring.interceptor.ActionAutowiringInterceptor"/>

            <interceptor name="chain"class="com.opensymphony.xwork2.interceptor.ChainingInterceptor"/>

            <interceptor name="conversionError"class="org.apache.struts2.interceptor.StrutsConversionErrorInterceptor"/>

            <interceptor name="cookie"class="org.apache.struts2.interceptor.CookieInterceptor"/>

            <interceptor name="createSession"class="org.apache.struts2.interceptor.CreateSessionInterceptor" />

            <interceptor name="debugging"class="org.apache.struts2.interceptor.debugging.DebuggingInterceptor" />

            <interceptor name="externalRef"class="com.opensymphony.xwork2.interceptor.ExternalReferencesInterceptor"/>

            <interceptor name="execAndWait"class="org.apache.struts2.interceptor.ExecuteAndWaitInterceptor"/>

            <interceptor name="exception"class="com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor"/>

            <interceptor name="fileUpload"class="org.apache.struts2.interceptor.FileUploadInterceptor"/>

            <interceptor name="i18n"class="com.opensymphony.xwork2.interceptor.I18nInterceptor"/>

            <interceptor name="logger"class="com.opensymphony.xwork2.interceptor.LoggingInterceptor"/>

            <interceptor name="modelDriven"class="com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor"/>

            <interceptor name="scopedModelDriven"class="com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor"/>

            <interceptor name="params"class="com.opensymphony.xwork2.interceptor.ParametersInterceptor"/>

            <interceptor name="prepare"class="com.opensymphony.xwork2.interceptor.PrepareInterceptor"/>

            <interceptor name="staticParams"class="com.opensymphony.xwork2.interceptor.StaticParametersInterceptor"/>

            <interceptor name="scope"class="org.apache.struts2.interceptor.ScopeInterceptor"/>

            <interceptor name="servletConfig"class="org.apache.struts2.interceptor.ServletConfigInterceptor"/>

            <interceptor name="sessionAutowiring"class="org.apache.struts2.spring.interceptor.SessionContextAutowiringInterceptor"/>

            <interceptor name="timer"class="com.opensymphony.xwork2.interceptor.TimerInterceptor"/>

            <interceptor name="token"class="org.apache.struts2.interceptor.TokenInterceptor"/>

            <interceptor name="tokenSession"class="org.apache.struts2.interceptor.TokenSessionStoreInterceptor"/>

            <interceptor name="validation"class="org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor"/>

            <interceptor name="workflow"class="com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor"/>

            <interceptor name="store"class="org.apache.struts2.interceptor.MessageStoreInterceptor" />

            <interceptor name="checkbox"class="org.apache.struts2.interceptor.CheckboxInterceptor" />

            <interceptor name="profiling"class="org.apache.struts2.interceptor.ProfilingActivationInterceptor" />

            <interceptor name="roles"class="org.apache.struts2.interceptor.RolesInterceptor" />

 

            <!-- Basic stack -->

            <interceptor-stack name="basicStack">

                <interceptor-ref name="exception"/>

                <interceptor-ref name="servletConfig"/>

                <interceptor-ref name="prepare"/>

                <interceptor-ref name="checkbox"/>

                <interceptor-ref name="params"/>

                <interceptor-ref name="conversionError"/>

            </interceptor-stack>

 

            <!-- Sample validation and workflow stack -->

            <interceptor-stack name="validationWorkflowStack">

                <interceptor-ref name="basicStack"/>

                <interceptor-ref name="validation"/>

                <interceptor-ref name="workflow"/>

            </interceptor-stack>

 

            <!-- Sample file upload stack -->

            <interceptor-stack name="fileUploadStack">

                <interceptor-ref name="fileUpload"/>

                <interceptor-ref name="basicStack"/>

            </interceptor-stack>

 

            <!-- Sample model-driven stack  -->

            <interceptor-stack name="modelDrivenStack">

                <interceptor-ref name="modelDriven"/>

                <interceptor-ref name="basicStack"/>

            </interceptor-stack>

 

            <!-- Sample action chaining stack -->

            <interceptor-stack name="chainStack">

                <interceptor-ref name="chain"/>

                <interceptor-ref name="basicStack"/>

            </interceptor-stack>

 

            <!-- Sample i18n stack -->

            <interceptor-stack name="i18nStack">

                <interceptor-ref name="i18n"/>

                <interceptor-ref name="basicStack"/>

            </interceptor-stack>

 

            <!-- An example of the params-prepare-params trick. This stack

                 is exactly the same as the defaultStack, except that it

                 includes one extra interceptor before the prepare interceptor:

                 the params interceptor.

 

                 This is useful for when you wish to apply parameters directly

                 to an object that you wish to load externally (such as a DAO

                 or database or service layer), but can't load that object

                 until at least the ID parameter has been loaded. By loading

                 the parameters twice, you can retrieve the object in the

                 prepare() method, allowing the second params interceptor to

                 apply the values on the object. -->

            <interceptor-stack name="paramsPrepareParamsStack">

                <interceptor-ref name="exception"/>

                <interceptor-ref name="alias"/>

                <interceptor-ref name="params"/>

                <interceptor-ref name="servletConfig"/>

                <interceptor-ref name="prepare"/>

                <interceptor-ref name="i18n"/>

                <interceptor-ref name="chain"/>

                <interceptor-ref name="modelDriven"/>

                <interceptor-ref name="fileUpload"/>

                <interceptor-ref name="checkbox"/>

                <interceptor-ref name="staticParams"/>

                <interceptor-ref name="params"/>

                <interceptor-ref name="conversionError"/>

                <interceptor-ref name="validation">

                    <param name="excludeMethods">input,back,cancel</param>

                </interceptor-ref>

                <interceptor-ref name="workflow">

                    <param name="excludeMethods">input,back,cancel</param>

                </interceptor-ref>

            </interceptor-stack>

 

            <!-- A complete stack with all the common interceptors in place.

                 Generally, this stack should be the one you use, though it

                 may do more than you need. Also, the ordering can be

                 switched around (ex: if you wish to have your servlet-related

                 objects applied before prepare() is called, you'd need to move

                 servlet-config interceptor up.

 

                 This stack also excludes from the normal validation and workflow

                 the method names input, back, and cancel. These typically are

                 associated with requests that should not be validated.

                 -->

            <interceptor-stack name="defaultStack">

                <interceptor-ref name="exception"/>

                <interceptor-ref name="alias"/>

                <interceptor-ref name="servletConfig"/>

                <interceptor-ref name="prepare"/>

                <interceptor-ref name="i18n"/>

                <interceptor-ref name="chain"/>

                <interceptor-ref name="debugging"/>

                <interceptor-ref name="profiling"/>

                <interceptor-ref name="scopedModelDriven"/>

                <interceptor-ref name="modelDriven"/>

                <interceptor-ref name="fileUpload"/>

                <interceptor-ref name="checkbox"/>

                <interceptor-ref name="staticParams"/>

                <interceptor-ref name="params">

                  <param name="excludeParams">dojo\..*</param>

                </interceptor-ref>

                <interceptor-ref name="conversionError"/>

                <interceptor-ref name="validation">

                    <param name="excludeMethods">input,back,cancel,browse</param>

                </interceptor-ref>

                <interceptor-ref name="workflow">

                    <param name="excludeMethods">input,back,cancel,browse</param>

                </interceptor-ref>

            </interceptor-stack>

 

            <!-- The completeStack is here for backwards compatibility for

                 applications that still refer to the defaultStack by the

                 old name -->

            <interceptor-stack name="completeStack">

                <interceptor-ref name="defaultStack"/>

            </interceptor-stack>

 

            <!-- Sample execute and wait stack.

                 Note: execAndWait should always be the *last* interceptor. -->

            <interceptor-stack name="executeAndWaitStack">

                <interceptor-ref name="execAndWait">

                    <param name="excludeMethods">input,back,cancel</param>

                </interceptor-ref>

                <interceptor-ref name="defaultStack"/>

                <interceptor-ref name="execAndWait">

                    <param name="excludeMethods">input,back,cancel</param>

                </interceptor-ref>

            </interceptor-stack>

 

            <!-- Deprecated name forms scheduled for removal in Struts 2.1.0. The camelCase versions are preferred. See ww-1707 -->

            <interceptor name="external-ref"class="com.opensymphony.xwork2.interceptor.ExternalReferencesInterceptor"/>

            <interceptor name="model-driven"class="com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor"/>

            <interceptor name="static-params"class="com.opensymphony.xwork2.interceptor.StaticParametersInterceptor"/>

            <interceptor name="scoped-model-driven"class="com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor"/>

            <interceptor name="servlet-config"class="org.apache.struts2.interceptor.ServletConfigInterceptor"/>

            <interceptor name="token-session"class="org.apache.struts2.interceptor.TokenSessionStoreInterceptor"/>

 

       </interceptors>

 

        <default-interceptor-ref name="defaultStack"/>

    </package>

 

</struts>

 

原文:  http://yhjhappy234.blog.163.com/blog/static/31632832201181154627210/

  • 大小: 162.9 KB
分享到:
评论

相关推荐

    struts2 Result类型

    Struts2 Result类型是Struts2框架中一个关键的概念,它是动作执行完成后跳转到下一个页面或处理逻辑的核心机制。Result类型定义了如何处理动作执行的结果,使得开发者能够灵活地控制应用程序的流程。 首先,我们...

    struts2 result type 介绍

    在Struts2中,Result Type是控制流程的重要部分,用于定义动作执行后如何转发或重定向到特定的视图。这篇博客文章将深入探讨Struts2的Result Type,以及它在实际应用中的工作原理。 首先,我们需要了解Struts2的...

    struts2 result配置详解

    Struts2 框架提供了多种 Result 配置类型,每种类型都有其特定的功能和应用场景。 1. Chain Result 配置 Chain Result 配置用于将一个 Action 的执行结果与另一个 Action 的执行结果链式连接起来。这种配置类型...

    Struts2_result返回类型

    `Struts2_result返回类型`指的是在Action执行成功或失败后,如何将控制权传递到下一个页面或资源。这些返回类型定义了不同的结果处理策略,使得开发者可以根据需求选择合适的方式。 首先,我们来看几个常见的返回...

    struts2 result转向到action

    ### Struts2 Result 转向到 Action 的深入解析 #### 一、基本概念与应用场景 **Struts2** 是一款流行的 Java Web 开发框架,它支持多种开发模式(如 MVC),并提供了一系列用于简化 Web 应用程序开发的功能。在 ...

    Struts2 Result类型

    Struts2 Result类型是Struts2框架中一个关键的概念,它是控制Action执行后响应到何处的重要组件。在处理用户请求并执行相应的业务逻辑后,Action需要将结果返回给客户端,而Result类型就是用来定义这个返回过程的...

    struts2中result类型之redirect

    在Struts2框架中,`Result`类型是动作(Action)执行后的一种处理方式,它定义了动作执行完后页面跳转或者数据处理的行为。`Redirect`是`Result`类型中的一种,它涉及到Web应用程序中的URL重定向概念,对用户浏览器...

    struts2中常用Result类型(type)的用法和出现的问题

    Struts2 中常用 Result 类型(type)的用法和出现的问题 Struts2 中的 Result 类型(type)是指在 Struts2 框架中用于确定 action 执行结果的方式。常用的 Result 类型有 dispatcher、redirect 和 chain 三种。这三...

    Struts2 result和type

    ### Struts2中的Result与Type详解 #### 一、引言 在Struts2框架中,`Result`和`Type`是两个非常重要的概念。它们主要用于控制Action执行完毕后页面的跳转方式以及如何处理Action返回的结果。通过合理配置`Result`与...

    struts2中的result的type类型

    struts2 跳转类型 result type chain dispatcher redirect redirect action

    struts2中result类型之redirectAction

    通过分析`redirectActionTest`文件,我们可以深入理解Struts2中`redirectAction` Result类型的实现和应用场景,包括配置、工作流程以及优缺点。实践这些知识可以帮助我们更有效地构建和维护Struts2驱动的Web应用。

    struts2的action的几种result type说明

    在`struts-default.xml`配置文件中,我们可以看到Struts2支持多种内置的Result Type。 1. **dispatcher** (默认): 这是最常见的Result Type,它使用Servlet Dispatcher将请求转发到指定的JSP页面或Servlet。`class=...

    struts2简单实例(类型转换)

    Struts2是一个强大的Java web框架,它为开发者提供了一种结构化的、声明式的...在深入学习Struts2的过程中,你还会遇到拦截器(Interceptor)、结果类型(Result Type)等概念,这些都是构建复杂应用程序的关键组件。

    struts2自定义数据类型转换练习

    本练习主要关注如何在Struts2中实现自定义的数据类型转换,以满足特定业务需求。 首先,我们需要了解Struts2的数据转换机制。当用户提交表单数据时,Struts2会通过ActionContext获取到这些数据,并尝试将其转换为...

    struts2自定义结果类型demo

    在Struts2中,结果类型(Result Type)是动作执行后处理结果的关键部分,它决定了如何将控制权转移给下一个资源,如JSP、FreeMarker模板或者重定向到其他URL。自定义结果类型允许开发者根据项目需求定制化结果处理...

    struts2返回JSON数据的两种方式

    在本文中,我们将探讨两种在Struts2框架中返回JSON数据的方法。...二是利用Struts2的内置JSON插件,通过返回特定的属性和结果类型自动处理JSON。每种方法都有其适用场景,可以根据项目需求选择合适的方式。

    struts2返回json

    在Struts2中,返回JSON(JavaScript Object Notation)数据类型是一种常见的需求,尤其是在开发AJAX或者前后端分离的应用时。JSON是一种轻量级的数据交换格式,它允许服务器向客户端发送结构化的数据,而无需解析...

    Struts2--result配置的各种视图转发类型

    这篇博文将深入探讨Struts2中的result配置以及各种视图转发类型。 首先,让我们理解Result的基本概念。在Struts2的配置文件(如struts.xml)中,每个Action可以有多个结果,每个结果对应一个特定的视图。Result配置...

    struts2的XSLTResult结果类型

    这篇博文将深入探讨Struts2的XSLTResult结果类型及其工作原理。 XSLT(Extensible Stylesheet Language Transformations)是一种转换XML文档的样式表语言。通过应用XSLT,可以将XML数据转换成HTML、PDF或其他格式,...

Global site tag (gtag.js) - Google Analytics