在JFinal的Controller中接收json数据

简介:

JFinal中接收URL中的参数或者model中的参数是很方便的,但是对于web2.0的网站来说,经常会以json方式提交比较复杂的数据,比如一个查询,包含了各种过滤条件和排序分页,前端脚本可能提交的数据是这样的:

1
2
3
4
5
6
7
8
9
10
11
12
{
     "type" :1,
     "key" : "keyword" ,
     "paging" :{
         "size" :50,
         "index" :0
     },
     "sort" :{
         "field" : "time" ,
         "type" : "desc"
     }
}


像SpringMVC就提供了@RequestBody将数据绑定到json对象上,但是jFinal不支持,需要自己从POST中读取并解析这个json数据,先定义一个与请求同结构的Java对象,比如起名叫QueryRequest:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
packagecom.demo;
 
import  com.demo.Paging;
import  com.demo.Sort;
 
public  class  QueryRequest {
     private  int  type;
     private  String key;
     private  Paging paging;
     private  Sort sort;
 
     public  int  getType() {
         return  type;
     }
     public  void  setType( int  type) {
         this .type = type;
     }
     public  String getKey() {
         return  key;
     }
     public  void  setKey(String key) {
         this .key = key;
     }
     public  Paging getPaging() {
         return  paging;
     }
     public  void  setPaging(Paging paging) {
         this .paging = paging;
     }
     public  Sort getSort(){
         return  sort;
     }
     public  void  setSort(Sort sort){
         this .sort = sort;
     }
}


其中用到了Paging和Sort两个类:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
package  com.demo;
 
public  class  Paging {
     private  int  size;
     private  int  index;
     
     public  int  getSize() {
         return  size;
     }
     public  void  setSize( int  size) {
         this .size = size;
     }
     public  int  getIndex() {
         return  index;
     }
     public  void  setIndex( int  index) {
         this .index = index;
     }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
package  com.demo;
 
public  class  Sort {
     private  String field;
     private  String type;
     
     public  String getField() {
         return  field;
     }
     public  void  setField(String field) {
         this .field = field;
     }
     public  String getType() {
         return  type;
     }
     public  void  setType(String type) {
         this .type = type;
     }
}


然后在Controller里就从request中读取json字符串,然后调用fastjson解析提交的数据了,:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
@Before (POST. class )
public  void  getData(){
     try {
         //从requst中读取json字符串
         StringBuilder json =  new  StringBuilder(); 
         BufferedReader reader =  this .getRequest().getReader();
         String line =  null ;
         while ((line = reader.readLine()) !=  null ){
             json.append(line);
         }
         reader.close();
 
         //调用fastjson解析出对象
         QueryRequest request = JSONObject.parseObject(json.toString(), QueryRequest. class );
         
         //然后就可以使用request得到请求的所有数据了
         //下略
         //.......
     }
     catch (Exception ex){
         //异常处理,略
     }
     
     renderText( "测试" );
}


转换部分会经常使用,可以提出来:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
/**
  * 取Request中的数据对象
  * @param valueType
  * @return
  * @throws Exception 
  */
protected  <T> T getRequestObject(Class<T> valueType)  throws  Exception {
     StringBuilder json =  new  StringBuilder();
     BufferedReader reader =  this .getRequest().getReader();
     String line =  null ;
     while ((line = reader.readLine()) !=  null ){
         json.append(line);
     }
     reader.close();
     
     return  JSONObject.parseObject(json.toString(), valueType);
}


使用的时候一句就行了:

1
QueryRequest requst = getRequestObject(QueryRequest. class );



另外附上前端ajax调用的脚本:

1
2
3
4
5
6
7
8
9
10
11
12
13
$.ajax({
     "url" "/home/getDate" ,       //路径
     "cache" false ,               //不缓存
     "async" true ,                //异步
     "type" "POST" ,               //POST方式提交
     "dataType" "json" ,           //json格式,重要
     "contentType" "application/json" ,       //json格式
     "data" : {},                   //要提交的数据对象
     success:  function  (json) {  //成功处理
     },
     error:  function  (x, e) {   //异常处理
     }
});


PS:很喜欢jFinal,相比于SpringMVC庞大的体积,jFinal真是的很小巧。

PPS:使用的是jFinal-2.0,配合fastjson-1.2.3,之前用fastjson-1.2.4时会有问题。




     本文转自 BoyTNT 51CTO博客,原文链接:http://blog.51cto.com/boytnt/1698113,如需转载请自行联系原作者




目录
打赏
0
0
0
0
349
分享
相关文章
淘宝商品评论API接口,json数据示例参考
淘宝开放平台提供了多种API接口来获取商品评论数据,其中taobao.item.reviews.get是一个常用的接口,用于获取指定商品的评论信息。以下是关于该接口的详细介绍和使用方法:
SPL 处理多层 JSON 数据比 DuckDB 方便多了
esProc SPL 处理多层 JSON 数据比 DuckDB 更便捷,尤其在保留 JSON 层次与复杂计算时优势明显。DuckDB 虽能通过 `read_json_auto()` 将 JSON 解析为表格结构,但面对深层次或复杂运算时,SQL 需频繁使用 UNNEST、子查询等结构,逻辑易变得繁琐。而 SPL 以集合运算方式直接处理子表,代码更简洁直观,无需复杂关联或 Lambda 语法,同时保持 JSON 原始结构。esProc SPL 开源免费,适合复杂 JSON 场景,欢迎至乾学院探索!
PHP技巧:解析JSON及提取数据
这就是在PHP世界里探索JSON数据的艺术。这场狩猎不仅仅是为了获得数据,而是一种透彻理解数据结构的行动,让数据在你的编码海洋中畅游。通过这次冒险,你已经掌握了打开数据宝箱的钥匙。紧握它,让你在编程世界中随心所欲地航行。
115 67
配置Nginx根据IP地址进行流量限制以及返回JSON格式数据的方案
最后,记得在任何生产环境部署之前,进行透彻测试以确保一切运转如预期。遵循这些战术,守卫你的网络城堡不再是难题。
49 3
如何在 Postman 中上传文件和 JSON 数据
如果你想在 Postman 中同时上传文件和 JSON 数据,本文将带你一步一步地了解整个过程,包括最佳实践和技巧,让你的工作更轻松。
如何在 Postman 中发送 JSON 数据
我们将深入探讨使用 Postman 发送 JSON 数据这一主题,Postman 是一款强大的 API 测试和开发工具。无论您是经验丰富的开发人员还是新手,掌握这项技能对于高效的 API 测试和开发都至关重要。
怎样用 esProc 计算来自 Restful 的多层 json 数据
esProc 是一款强大的数据处理工具,可简化 Java 处理 Restful 接口返回的复杂多层 JSON 数据的难题。通过 esProc,不仅能轻松访问和解析 Restful 数据,还能高效完成复杂计算任务,并可无缝嵌入 Java 应用中作为计算引擎使用。例如,筛选特定分类订单或计算金额,esProc 的脚本简洁直观,远优于传统 SQL 或纯 Java 实现。此外,esProc 支持安全认证(如 Cookie 和 Token)及 JDBC 集成,为开发者提供灵活高效的解决方案。
JFinal框架中防止表单重复提交的方法
每种方法都有其优势和局限性。Token机制能提供较为稳定可靠的保护,但增加了服务器端的处理负担。锁定机制在处理并发请求时更有效,但可能导致用户体验的下降。JavaScript客户端控制提供了良好的用户体验,但依赖于客户端的执行环境。在实际应用中,可以根据具体的场景和需求,选择最适合的方法,或者将多种方法组合使用,以达到最佳的效果。
99 10
JFinal框架单文件、多文件上传详解
版权声明:本文为博主原创文章,如需转载,请标明出处。 https://blog.csdn.net/alan_liuyue/article/details/79386540 简介  ...
2875 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等