作者归档:Rick

复杂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

网站缓存技术

  

文章转自:http://dcross.iteye.com/blog/721468

  网站技术高速发展的今天,缓存技术已经成为大型网站的一个关键技术,缓存设计好坏直接关系的一个网站访问的速度,以及购置服务器的数量,甚至影响到用户的体验。

网站缓存按照存放的地点不同,可以分为客户端缓存、服务端缓存。

客户端缓存

客户端缓存又可分为:浏览器缓存、网关或代理服务器缓存
网关或代理服务器缓存是将网页缓存中网关服务器上,多用户访问同一个页面时,将直接从网关服务器把页面传送给用户。
浏览器缓存是最靠近用户的缓存,如果启用缓存,用户在访问同一个页面时,将不再从服务器下载页面,而是从本机的缓存目录中读取页面,然后再浏览器中展现这个页面。
浏览器缓存的控制,可以设置meta标签,可以设置数字,也可以设置时间,如下:
<Meta http-equiv=”Expires” Content=”3600″>
<Meta http-equiv=”Expires” Content=”Wed, 26 Feb 1997 08:21:57 GMT”>
HTTP头信息如下:
HTTP/1.1 200 OK
Date: Fri, 30 Oct 1998 13:19:41 GMT
Server: Apache/1.3.3 (Unix)
Cache-Control: max-age=3600, must-revalidate
Expires: Fri, 30 Oct 1998 14:19:41 GMT
Last-Modified: Mon, 29 Jun 1998 02:28:12 GMT
不过现在的网站为了保证用户访问到最新的内容,一般很少采用浏览器缓存,取而代之的是更加灵活的服务器缓存。

服务端缓存

服务端缓存分为:页面缓存、数据缓存、数据库缓存

1、页面缓存

页面缓存是将动态页面直接生成静态的页面放在服务器端,用户调取相同页面时,静态页面将直接下载到客户端,不再需要通过程序的运行和数据库的访问,大大节约了服务器的负载。
早期的网站很多使用发布系统来完成这个功能,在后台发布时将数据和页面模板整合成静态页面,存放在硬盘中。但这样的缺陷很明显,一是后台的程序的编写很复杂,二是缓存的控制只能通过人为的方式来控制,这对一些更新十分频繁的网站就是一个噩梦,网站可能在不停的做缓存的删除和重建。当然后来出现了一些自动更新这些缓存的框架,比如PHP的SMARTY模板技术,可以定义缓存过期的时间,自动去更新这些缓存。这对一些信息发布类网站已经确实适用了。
除了整个页面的缓存技术,还有一种技术叫做“网页片段缓存技术”,将页面的部分而不是全部进行缓存。代表作有ESI cache。

2、数据缓存

但是当WEB2.0兴起的今天,信息的发布已经不再是管理员统一发布的了,而是所有的用户都在发布信息,用户发布完信息后当然是想看到这些信息,而不是等到缓存时间到刷新后才看到这些数据,于是数据缓存的相关技术也就应运而生了。
比较有名的数据缓存框架有ehcache和 memcached。
ehcache有很多缓存的分支(包括页面缓存的模块),但最核心的模块还是它的数据缓存部分,比如,当ehcache和hibernate进行整合时,能将查询出的对象集合放入内存中,下次如果再查询这个查询,将直接从内存中返回这个数据集合,不需要再进行数据库的查询,同时,你可以配置缓存的刷新模式,有read-only,nonstrict-read-write,read-write 几种模式,其中read-only表示缓存是不刷新的(要刷新就只有重启了),nonstrict-read-write表示刷新是不及时的,你可以设置超时的时间去刷新,read-write表示在数据发生变化时缓存都会发生刷新,具体怎么配置可能就要根据具体业务了。
Memcached大致的原理也和ehcache 相同,将数据采用键值的形式存放在内存中,使用时可以将查询的md5作为键,查询的结果作为值。相对ehcache而言,memcached是一个工具,ehcache是一个框架,memcached更加底层更加灵活,当然你也要写相应的代码去使用它。
这是一张网上的memcached图,说明了memcached在系统中的位置。


近几年兴起的NOSQL技术,虽然现在归于数据库的一种,但其本质也是缓存技术和数据库技术的一种融合产物。
目前缓存的做法分为两种模式:
内存缓存:缓存数据存放在服务器的内存空间中。
优点:速度快 缺点:资源有限
文件缓存:缓存数据存放在服务器的硬盘空间中。
优点:容量大 缺点:速度偏慢,尤其在缓存数量巨大时

数据库缓存

数据库的缓存一般由数据库提供,比如ORACLE,可以对表建立高速缓存,提高对经常访问的数据的访问速度。

总结

究竟怎样去使用缓存,使用哪一层次的缓存,是由网站本身的具体业务来决定的。缓存技术的一个原则是:让数据更靠近用户。缓存技术是一门博大精深的艺术,我也是只知些皮毛。