最近由于工作原因,没时间更新,开始吧~~

关于json的返回需要用到一个工具包来将书转换为json格式,在此用到的jar包为:

 import net.sf.json.JSONArray;  //将数据转换为JSON数组
import net.sf.json.JSONObject;  //将数据转换为JSON对象

dao层的代码

 public class ProInfomaDao extends HibernateDaoSupport {
private Logger logger = Logger.getLogger(ProInfomaDao.class);
  /**
* 查询所有数据
* @return
*/
@SuppressWarnings("unchecked")
public List<BanknameDto> selBankList() {
String sql = "SELECT DISTINCT ENAME FROM PM_PROINFO";            //填写对应的SQL语句
List<String> queryList = getSession().createSQLQuery(sql).list();
List<BanknameDto> bankList = new ArrayList<BanknameDto>();
queryList.add(0, "--请选择--");
BanknameDto bankDto = null;
if(queryList.size() == 0){
logger.info("查不到相关信息!");
}else{
for(int i = 0;i < queryList.size();i++){
bankDto = new BanknameDto();
if(i == 0){
bankDto.setId(String.valueOf(i+1));
bankDto.setText(queryList.get(i));
bankDto.setSelected("true");
}else{
bankDto.setId(String.valueOf(i+1));
bankDto.setText(queryList.get(i));
}
bankList.add(bankDto);
}
}
return bankList;                    //此处用到hibernate来查询数据,返回结果为一个[demo1,demo2,demo3]的List集合
}
}

service层代码

 public class ProInfomaService {
private ProInfomaDao proInfomaDao;
public void setProInfomaDao(ProInfomaDao proInfomaDao) {
this.proInfomaDao = proInfomaDao;
} /**
* 查询数据
* @return
*/
public List<BanknameDto> selBankList(){
return proInfomaDao.selBankList();
}
}

web层

 public class ProInfomaAction extends ActionSupport implements ServletRequestAware{
private static final long serialVersionUID = 1L;
private ProInfomaService proInfomaService;
private Map<String, Object> resultMap = new HashMap<String, Object>();
private JSONObject dataroot;   
private JSONArray bankroot; //此处要返回的属性名称,以bankroot为例,要与struts中
private JSONArray projroot; //<param name="root">bankroot</param>且提供get set方法
private HttpServletRequest request; /**
* 查询银行名称
* @return
*/
public String selBankList() {
List<BanknameDto> selBank = proInfomaService.selBankList();
bankroot = JSONArray.fromObject(selBank);
return SUCCESS;
} public JSONArray getBankroot() {
return bankroot;
} public void setBankroot(JSONArray bankroot) {
this.bankroot = bankroot;
}
@Override
public void setServletRequest(HttpServletRequest request) {
this.request = request;
}
}

struts2中action的配置

 <?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
<package name="proInfo" namespace="/" extends="json-default">
   <!--此处返回json只可以用json-default result结果集可以改变返回参数的名称 -->
<action name="query" class="noticeAction" method="selBankList">
<result name="success" type="json">
</result>
<result name="returnMap" type="json">
<param name="root">bankroot</param>              
</result>
</action>
</struts>
 
 
 
 
 
 

Struts2 返回 json 格式数据的更多相关文章

  1. Struts2返回json格式数据踩坑记录

    事件起因 昨天提测修改冻结/解冻银行卡样式的功能,微姐测试过程中发现调用ajax请求耗时过长,今天来排查,发现浏览器请求/finance/ajax/freeze/ajaxGetShopLists时,对 ...

  2. 使用jQuery发送POST,Ajax请求返回JSON格式数据

    问题: 使用jQuery POST提交数据到PHP文件, PHP返回的json_encode后的数组数据,但jQuery接收到的数据不能解析为JSON对象,而是字符串{"code" ...

  3. Spring MVC 学习笔记11 —— 后端返回json格式数据

    Spring MVC 学习笔记11 -- 后端返回json格式数据 我们常常听说json数据,首先,什么是json数据,总结起来,有以下几点: 1. JSON的全称是"JavaScript ...

  4. 返回json格式数据乱码

    本文为博主原创,未经允许不得转载: 原本返回json格式数据的代码: @ResponseBody @RequestMapping(value = "getListByTime", ...

  5. WebService返回json格式数据供苹果或者安卓程序调用

    1.新建一个WebService. 2. /// <summary> /// DemoToJson 的摘要说明 /// </summary> [WebService(Names ...

  6. Django 1.8.11 查询数据库返回JSON格式数据

    Django 1.8.11 查询数据库返回JSON格式数据 和前端交互全部使用JSON,如何将数据库查询结果转换成JSON格式 环境 Win10 Python2.7 Django 1.8.11 返回多 ...

  7. ajax请求后台,返回json格式数据,模板!

    添加一个用户的时候,需要找出公司下所有的部门,和相应部门下的角色,利用ajax请求,实现联动技术.将返回的json格式数据,添加到select标签下. <script type="te ...

  8. 如何让webapi只返回json格式数据

    最近脑子不好用,总记不住事,以前搞过让webapi只返回json格式的数据,今天有人问我又突然想不起了,后来总结一下,备忘一下,大概有下面几种处理方式 1.在WebApiConfig类的Registe ...

  9. springmvc通过ajax异步请求返回json格式数据

    jsp 首先创建index.jsp页面 <script type="text/javascript"> $(function () { $("#usernam ...

随机推荐

  1. 简单的shell命令

    grep echo 重定向与管道 tr 特殊文件:/dev/null,/dev/tty 基本命令查找 访问shell脚本的参数 简单的执行跟踪: set -x set +x

  2. mssql sqlserver with cte表达式(递归)找出最顶值的方法分享

    摘要: 下文通过递归的方式找出最顶级部门的方法分享,如下所示: 实验环境:sql server 2008 R2 下文通过cte-with表达式实现递归,获取一个公司的顶级部门,如下所示 例:部门表 c ...

  3. sqlserver简便创建用户并授权

    很多研发人员程序连接SQL Server直接用的就是SA帐号.如果对数据库管理稍微严格一点的话,就不应该给应用程序这种权限,通常应用程序只需要进行增删改查,而很少有DDL操作,因此配置帐号时应该遵循“ ...

  4. Redis与Memocache的区别

    转载地址:http://gnucto.blog.51cto.com/3391516/998509 Redis与Memcached的区别 传统MySQL+ Memcached架构遇到的问题 实际MySQ ...

  5. Web前端教程2-CSS教程

    目录 1. CSS基本语法 1.1. CSS基本定义 1.2. CSS布局属性 1.3. CSS文本常用属性 2.CSS选择器 2.1. 标签选择器 2.2. id选择器 2.3. 类选择器 2.4. ...

  6. 浏览器仿EXCEL表格插件 版本更新 - 智表ZCELL产品V1.3.2更新

    智表(zcell)是一款浏览器仿excel表格jquery插件.智表可以为你提供excel般的智能体验,支持双击编辑.设置公式.设置显示小数精度.下拉框.自定义单元格.复制粘贴.不连续选定.合并单元格 ...

  7. Linux新手随手笔记

    RPM通过将安装规则与源代码打包到一起,来降低软件的安装难度 yum 通过将大量的常用RPM软件存放在一起,解决软件包之间的依赖关系,进一步降低软件的安装难度 rhel 5\6 init rhel 7 ...

  8. 【转】Android Hook框架Xposed详解

    1 Introduction 1.1  概述 Xposed 是 GitHUB 上 rovo89 大大设计的一个针对 Android 平台的动态劫持项目,通过替换 /system/bin/app_pro ...

  9. rank() partition by 排名次

    rank()排名 partition by分组与group by相比各有优势,在这里就省略100字.... 以下为案例: create table student -- 学生表(sid integer ...

  10. VUE 安装及项目创建

    Vue.js 安装cnpm npm install -g 镜像 cnpm --registry=https://registry.npm.taobao.org 安装 vue.js cnpm insta ...