java smartcare,Spring MVC 3.2.2 +easyui 返回JSON数据格式

本文介绍了如何在SpringMVC 3.2.2版本中利用EasyUI实现前端系统,并详细讲解了如何通过@Controller注解的@Controllerpublic class MemberShipController配置,包括messageConverters属性和@ResponseBody注解,以返回JSON数据,解决乱码问题和数据转换。

最近花了很多时间,研究Spring MVC 3.2.2 +easyui,实现了这个,前端页面实现个系统就很简单了。

Spring MVC 返回JSON数据的方法

1). 直接 PrintWriter 输出

2). 使用 JSP 视图

3). 使用Spring内置的支持

本文介绍的是第3种方法,方法如下:

1:首先下载JSON的包

这是spring MVC处理json数据时,所必须的jar依赖。

2:spring mvc的配置文件中加入配置

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"

xmlns:context="http://www.springframework.org/schema/context"

xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd

http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd

http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">

说明:

org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter的Bean配置中,我们加入了messageConverters属性,在该属性中我们有配置jsonHttpMessageConverter这个Bean,它就是用来处理json数据转换的。

在jsonHttpMessageConverter的Bean配置中,有一个supportedMediaTypes属性,在这个属性可以添加了text/html;charset=UTF-8这个值,它是为了处理返回的json数据的编码,默认是ISO-88859-1的,如果出现乱码,可以把它设置为UTF-8,参考如下:

text/html;charset=UTF-8

3:控制器Controller的注解

package com.kingmed.jusmartcare.health.web;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpSession;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Controller;

import org.springframework.ui.Model;

import org.springframework.web.bind.annotation.ModelAttribute;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RequestMethod;

import org.springframework.web.bind.annotation.RequestParam;

import org.springframework.web.bind.annotation.ResponseBody;

@Controller

public class MemberShipController {

public static final String LOGIN_SUCCESS = "vipcontent";//Index";// 登陆成功

public static final String LOGIN_FAIL = "../../index";//"LoginFail";// 登陆失败

public static final String LOGOUT = "../../index";//

public static final String REGISTER_SUCCESS = "RegisterSuccess";// 注册成功

public static final String REGISTER_FAIL = "RegisterFail";// 注册成功

private static final Logger logger=LoggerFactory.getLogger(MemberShipController.class);

@Autowired

private HealthconsultService healthconsultService;

@RequestMapping("jsp/welcome.do")

public String welcom(@RequestParam(value = "ln", required = false) String ln) {

String en = ln==null?"":ln+'/';

return en+"welcome";

}

@RequestMapping(value="user/list.do",method=RequestMethod.GET)

public String list(Model model) throws Exception {

return "user/list";

}

@RequestMapping(value="jsp/user/queryList.do")

@ResponseBody

public Map queryList(HttpSession session,@RequestParam(value = "pageNo", required = false) Integer pageNo,@RequestParam(value = "ln", required = false) String ln) throws Exception{

//spring太方便了,可以自动装配两个对象  会自动的装返回的Map转换成JSON对象

Map result = new HashMap(2);

String en = ln==null?"":ln+'/';

pageNo = pageNo==null?1:pageNo;

Page healths=healthconsultService.getPageList("cardno","1001", pageNo,2);

int total=healths.getTotalCount();

result.put("total", total);

result.put("rows", healths.getResult());

return result;

}

@RequestMapping(value="jsp/welcome1.do")

@ResponseBody

public Object test(HttpSession session){

System.out.println("test....................");

MemberInfo logined=(MemberInfo)session.getAttribute("USER_INFO");

if(logined ==null){

logined=new MemberInfo();

logined.setCardNo("999999");

System.out.println("test1....................");

}

System.out.println("test2....................");

return  logined;

}

}

说明:使用了一个@ResponseBody的注解,Spring3.0 MVC @ResponseBody的作用是把返回值直接写到HTTP response body里,

返回json数据的可以是一个类(看test),或者list(看queryList)。

C语言-光伏MPPT算法:电导增量法扰动观察法+自动全局搜索Plecs最大功率跟踪算法仿真内容概要:本文档主要介绍了一种基于C语言实现的光伏最大功率点跟踪(MPPT)算法,结合电导增量法与扰动观察法,并引入自动全局搜索策略,利用Plecs仿真工具对算法进行建模与仿真验证。文档重点阐述了两种经典MPPT算法的原理、优缺点及其在不同光照和温度条件下的动态响应特性,同时提出一种改进的复合控制策略以提升系统在复杂环境下的跟踪精度与稳定性。通过仿真结果对比分析,验证了所提方法在快速性和准确性方面的优势,适用于光伏发电系统的高效能量转换控制。; 适合人群:具备一定C语言编程基础和电力电子知识背景,从事光伏系统开发、嵌入式控制或新能源技术研发的工程师及高校研究人员;工作年限1-3年的初级至中级研发人员尤为适合。; 使用场景及目标:①掌握电导增量法与扰动观察法在实际光伏系统中的实现机制与切换逻辑;②学习如何在Plecs中搭建MPPT控制系统仿真模型;③实现自动全局搜索以避免传统算法陷入局部峰值问题,提升复杂工况下的最大功率追踪效率;④为光伏逆变器或太阳能充电控制器的算法开发提供技术参考与实现范例。; 阅读建议:建议读者结合文中提供的C语言算法逻辑与Plecs仿真模型同步学习,重点关注算法判断条件、步长调节策略及仿真参数设置。在理解基本原理的基础上,可通过修改光照强度、温度变化曲线等外部扰动因素,进一步测试算法鲁棒性,并尝试将其移植到实际嵌入式平台进行实验验证。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值