struts2返回json数据配置

struts2要想返回json数据那么需要用到struts2-json-plugin.jar

在配置action类的父包时需继承json-default。

默认情况下,action类是选择继承struts-default,这时action会进行页面转发,action中的数据会被struts2处理返回给前端,可以通过EL表达式,或者ognl表达式获取,但是使用ajax是拿不到数据的。

当action类继承了json-default,action返回的数据类型是json时,ajax才能拿到返回的数据。

struts.xml继承配置如下:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
	"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
	"http://struts.apache.org/dtds/struts-2.3.dtd">

<struts>
	<include file="struts-default.xml"> </include>
	<package name="basePackage" extends="struts-default"></package>
	<constant name="struts.objectFactory" value="spring"></constant>
	<constant name="struts.i18n.encoding" value="utf-8"></constant>
	<constant name="struts.locale" value="zh_CN"></constant>
	<constant name="struts.convention.action.suffix" value="Action"> </constant>
	<constant name="struts.enable.DynamicMethodInvocation" value="true" /> 
	<constant name="struts.convention.result.path" value="/WEB-INF/jsp/"> </constant>
	<constant name="struts.convention.action.name.lowercase" value="true"> </constant>
	<constant name="struts.convention.exclude.packages" value="org.apache.struts.*,org.apache.struts2.*,org.springframework.web.struts.*,org.springframework.web.struts2.*,org.hibernate.*"> </constant>
	<constant name="struts.convention.action.mapAllMatches" value="true"> </constant>
	<constant name="struts.action.extension" value="htm,do"> </constant>
	<constant name="struts.convention.default.parent.package" value="default"></constant>
	<constant name="struts.convention.action.disableScanning" value="false"></constant>

	<constant name="struts.multipart.maxSize" value="4194304"></constant>
	<constant name="struts.multipart.saveDir" value="/tmp"></constant>
	<package name="default" extends="struts-default,json-default"></package>
</struts>
其中的重点为:

<constant name="struts.convention.default.parent.package" value="default"></constant>

<package name="default" extends="struts-default,json-default"></package>

action类返回类型配置如下:

package com.student.system.action;

import javax.annotation.Resource;

import org.apache.struts2.convention.annotation.Action;
import org.apache.struts2.convention.annotation.Namespace;
import org.apache.struts2.convention.annotation.Result;
import org.springframework.context.annotation.Scope;

import com.opensymphony.xwork2.ActionSupport;
import com.student.system.dto.UserDto;
import com.student.system.entity.user.TUser;
import com.student.system.service.UserService;


/**
 * @author a
 *
 */

@Namespace(value="/user")
@Scope("prototype")
@Action(value="userCtrl",results={
		@Result(name="page",location="/WEB-INF/jsp/user/user.jsp"),
		@Result(name="json",type="json",params={"root","dto.user"})
		
})
public class UserAction extends ActionSupport{
	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	@Resource
	private UserService userService;
	private UserDto dto;
	
	
	/**
	 * @return the dto
	 */
	public UserDto getDto() {
		return dto;
	}


	/**
	 * @param dto the dto to set
	 */
	public void setDto(UserDto dto) {
		this.dto = dto;
	}

	public String toPage(){
		return "page";
	}
	
	public String findUserById(){
		String id = dto.getUser().getId();
		TUser user = userService.findUserById(id);
		dto.setUser(user);
		return "json";
	}
	
}

当不指定返回类型时,默认的type=“dispatcher”,为转发页面,loaction是指定转发的页面路径。
当type=json时,会返回json格式的数据到前端。params是为了指定需要返回的数据。
params是一个字符串数据,一般存放2个字段,即key,value。至少是一对值。第一个字段是说明返回的json数据内容限制。第二个字段是要返回的数据对象。

params的key有如下取值。
root:只返回指定的对象。如上,只返回dto.user的json数据。

excludeProperties:除了指定内容的其他集合。
例如:dto.user.userName,返回除了userName的其他数据

includeProperties:包含指定类容的集合。
例如:dto.*,返回dto下的所以属性

warpPrefix:json结果开头添加符号。
例如:[,在json格式前添加[。

warpSuffix:在json结果后添加符号。
例如:],在接送格式后添加]。

ignoreHierarchy:是否忽略继承关系
enumAsBean:是否将枚举当作一个bean处理
excludeNullProperties:是否转换输出null值
noCache:是否缓存
enableGZIP:是否支持gzip压缩输出
statusCode:设置响应代码号
callbackParameter:json跨域访问回调设置
contentType:输出类型

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值