复杂JSON提交SpringMVC参数接收

简单json:

{"username":"zhangsan"}

复杂json

{
[{"username":"zhangsan"},
{"username":"lisi"}
]
}

简单json提交数据

前端:

var param = {"username":"zhangsan"};   

 $.ajax({
        type : 'POST',
        url : '${pageContext.request.contextPath}/shop/sku/skumgr/',
        data: param,
        success : function(result) {
               
        }
    });

controller:

 public String getUserData(User user) {

 }

复杂jsont提交数据

前端:

var param = {"users":[
{"username":"zhangsan"},
{"username":"lisi"}
]
}
    $.ajax({
        type : 'POST',
        url : '${pageContext.request.contextPath}/shop/sku/skumgr/', 
        contentType : "application/json",
        data: JSON.stringify(param), 
        success : function(result) {
                
        }
    });

controller:

public class VO {
   List<User> users;
   getter();
   setter();
}

 public void updateSku(@RequestBody VO vo) {

 }

Json数组映射到java的List或者数组

至此:有可能会报错,media not support,那就需要Spring对Content-Type支持

    <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
        <property name="supportedMediaTypes">
            <list>
                <value>text/html;charset=UTF-8</value>
                <value>application/json;charset=UTF-8</value>
            </list>
        </property>
    </bean>

相关资料:

http://www.cnblogs.com/dayou123123/p/3443939.html

  •  Content-Type,内容类型,一般是指网页中存在的Content-Type,用于定义网络文件的类型和网页的编码,决定浏览器将以什么形式、什么编码读取这个文件,这就是经常看到一些Asp网页点击的结果却是下载到的一个文件或一张图片的原因。

 ContentType属性指定响应的 HTTP内容类型。如果未指定 ContentType,默认为TEXT/HTML。

  •  ajax请求默认是application/x-www-form-urlencoded.Form Data
  •  get方式,参数是跟在url后边,与Content-Type无关。
  •  如果Content-Type : “application/json; charset=utf-8″,Request Paload提交JSON字符串。

JSON对象与字符串的转换

什么是JSON

  JSON(JavaScript Object Notation)是一种优美的JavaScript对象创建方法。JSON也是一种轻量级数据交换格式。JSON非常易于人阅读与编写,同时利于机器解析与生成。JSON是在AJAX中代替XML交换数据的更佳方案。

JSON格式与语法

var jsonobject= {

      //对象内的属性语法(属性名与属性值是成对出现的)

      propertyname:value,

      //对象内的函数语法(函数名与函数内容是成对出现的)

      functionname:function(){…;}

};

jsonobject — JSON对象名称

propertyname — 属性名称

functionname — 函数名称

一对大括号,括起多个”名称/值”的集合

JSON使用”名称/值”对的集合表示,也可以被理解为数组(Array)

属性名或函数名可以是任意字符串,甚至是空字符串(见下面示例)

逗号用于隔开每对”名称/值”对

标准JSON字符串

{test: 1}  (test 没有包围双引号)

{‘test': 1} (使用了单引号而不是双引号)

{“test”:1} 合法,key要用双引号表示

字符串格式json转化成json对象有3种方式:

1. js下用eval生成JSON对象  —通过eval() 函数可以将JSON字符串转化为对象。
2. 使用函数方式
3. 使用js的json库或者jQuery提供的js库  — 如果基于安全的考虑的话,最好是使用一个 JSON 解析器。 一个 JSON 解析器将只接受 JSON 文本。所以是更安全的。所谓接收JSON文本,就是合法的json字符串!!!

方法1:正常文本

//方法1:js下用eval生成JSON对象
        function strJsonToJsonByEval(jsonData){  
              var json = eval("(" + jsonData +")");//转换为json对象    
              return json;
        }

方法2:正常文本

//方法2:使用函数方式
      function strJsonToJsonByFunction(jsonData){
           return ( new Function("return "+jsonData) )();
      }

方法3:标准格式的 JSON 字符串

//json2或浏览器自带函数
var param = JSON.parse(data )
/*
jquery-1.9.1.js 提供的方法。
jQuery.parseJSON( json ) 返回: Object
接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript 对象。

传入格式有误的 JSON 字符串可能导致抛出异常。例如,下面这些 JSON 字符串格式都不对:
{test: 1} (test 没有使用双引号包裹).
{'test': 1} ('test' 用了单引号而不是双引号包裹).
另外,如果你什么都不传入,或者传入空字符串、null、undefined 等,parseJSON 都会返回 null 。如果浏览器原生实现了 JSON.parse, jQuery 则会使用它来解析字符串。
*/

Jquery中$.data()

结合html,经常做控件配置,如EasyUI

html

<input id="test" data-options="min:0,precision:2">

javascript

$(function() { var data = "{" + $("#test").data("options") + "}";
  alert(strJsonToJsonByFunction(data).min);
});

由于不是标准JSON格式,只能用方法1、2解析。

其他示例

$("#btn1").click(function(){
$("div").data("greeting", "Hello World");
});
$("#btn2").click(function(){
alert($("div").data("greeting"));
});

在执行过程中,存取临时数据,用处很大。

Java使用缓存memcached-HelloWorld

maven:

 <dependency>
	<groupId>com.whalin</groupId>
	<artifactId>Memcached-Java-Client</artifactId>
	<version>3.0.0</version>
</dependency>

CacheHelper.java

import com.whalin.MemCached.MemCachedClient;
import com.whalin.MemCached.SockIOPool;

public class CacheHelper {  
    
    /* 单例模式 */  
    protected static MemCachedClient mcc = new MemCachedClient();  
      
    private CacheHelper() {  
    }  
      
    /* 配置服务器组 */  
    static {  
          
        /* 定义IP地址和端口 */  
        String[] servers = {"121.42.151.190:11211"};  
          
        /* 设置缓存大小 */  
        Integer[] weights = { 2 };  
          
        /* 拿到一个连接池的实例 */  
        SockIOPool pool = SockIOPool.getInstance();  
          
        /* 注入服务器组信息 */  
        pool.setServers(servers);  
        pool.setWeights(weights);  
          
        /* 配置缓冲池的一些基础信息 */  
        pool.setInitConn(5);  
        pool.setMinConn(5);  
        pool.setMaxConn(250);  
        pool.setMaxIdle(1000 * 60 * 60 * 6);  
          
        /* 设置线程休眠时间 */  
        pool.setMaintSleep(30);  
          
        /* 设置关于TCP连接 */  
        pool.setNagle(false);// 禁用nagle算法  
        pool.setSocketConnectTO(0);  
        pool.setSocketTO(3000);// 3秒超时  
          
        /* 初始化 */  
        pool.initialize();  
          
        /* 设置缓存压缩 */  
//        mcc.setCompressEnable(true);  
//        mcc.setCompressThreshold(64 * 1024);  
          
    }  
      
    public static boolean set(String arg0, Object arg1) {  
        return mcc.set(arg0, arg1);  
    }  
      
    public static Object get(String arg0) {  
        return mcc.get(arg0);  
    }  
      
    /* 测试 */  
    public static void main(String[] args) {  
        CacheHelper.set("gogo", "gogogogo");  
        System.out.println(CacheHelper.get("gogo"));// gogogogo  
        System.out.println(CacheHelper.get("gogog"));// null  
        /* 如果出现都为null,检查地址和端口。端口可以到Memcached同目录配置文件看。
          相关文章链接http://xhope.top/?p=413 */  
    }  
      
} 

输出:

Centos下memcached安装

memcached下载地址:http://memcached.org/downloads

(无需下载可以在线安装)

安装分为两部分:

安装官方教程

安装libevent

   由于linux系统可能默认已经安装libevent,

   执行命令:rpm -qa|grep libevent查看系统是否带有该安装软件

   如果有执行命令:rpm -e libevent-1.1a-3.2.1 –nodeps(由于系统自带的版本旧,忽略依赖删除)


 如果没有安装

#yum install libevent-devel

安装memcached

#wget http://memcached.org/latest
#tar -zxvf memcached-1.4.22.tar.gz
#cd memcached-1.4.22
#./configure && make && make test && sudo make install

至此memcached安装成功

启动/停止memcached

memcached -d -m 256 -u root -p 11211 -c 1024 –P /tmp/memcached.pid

端口是11211

检查端口:

# netstat -atunlp

停止memcached进程:

#kill 12032

相关文档:

http://xhope.top/wp-content/uploads/2015/02/memcached-黑夜路人.pdf

此去经年

站在犯错的边缘,忽而发现还有几多留恋

梦里泪湿眼帘,是谁拥我在怀里安眠

我相信我的爱情能等到天长地久

除非你选择放手

而这是绝对不可能的理由

我说,我已将你看穿

像个小孩,可怜可爱的小孩

怎么舍得把你分开

 那么

请你牵着我的手,继续走

直路弯路我和你一起走

或许我就是上天欠你的礼物

而你是我一生的归宿

那么

疲惫了,就休息

苦恼了,就哭泣

快乐了,就忘乎所以

记得

此去经年,千种风情