<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>绿色记忆 &#187; JacksonJSON</title>
	<atom:link href="https://blog.gmem.cc/tag/jacksonjson/feed" rel="self" type="application/rss+xml" />
	<link>https://blog.gmem.cc</link>
	<description></description>
	<lastBuildDate>Fri, 17 Apr 2026 09:20:32 +0000</lastBuildDate>
	<language>en-US</language>
		<sy:updatePeriod>hourly</sy:updatePeriod>
		<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.9.14</generator>
	<item>
		<title>JacksonJson知识集锦</title>
		<link>https://blog.gmem.cc/jacksonjson-faq</link>
		<comments>https://blog.gmem.cc/jacksonjson-faq#comments</comments>
		<pubDate>Sat, 22 Dec 2012 04:42:57 +0000</pubDate>
		<dc:creator><![CDATA[Alex]]></dc:creator>
				<category><![CDATA[Java]]></category>
		<category><![CDATA[JacksonJSON]]></category>
		<category><![CDATA[JSON]]></category>

		<guid isPermaLink="false">http://blog.gmem.cc/?p=1237</guid>
		<description><![CDATA[<p>基础知识 Jackson JSON 提供了一系列API，便于Java程序读写JSON字符串。它具有强大对数据绑定能力，可以方便的在Java对象和JSON字符串之间进行转换。 创建JSON 从Java对象创建（绑定） 代码示例： [crayon-69e29a8710ab3973930852/] 从JsonNode树创建 示例代码： [crayon-69e29a8710ab9228418071/] 构建JSON流 这种方式很不直观，但是节约内存： [crayon-69e29a8710abb692420501/] 解析JSON 解析JSON流 Jackson提供了一种底层API，允许逐符号的处理JSON： [crayon-69e29a8710abe491043479/] 解析为JsonNode树 [crayon-69e29a8710ac0005878873/] 解析为Java对象（绑定）  [crayon-69e29a8710ac3840334729/] <a class="read-more" href="https://blog.gmem.cc/jacksonjson-faq">[...]</a></p>
<p>The post <a rel="nofollow" href="https://blog.gmem.cc/jacksonjson-faq">JacksonJson知识集锦</a> appeared first on <a rel="nofollow" href="https://blog.gmem.cc">绿色记忆</a>.</p>
]]></description>
				<content:encoded><![CDATA[<div class="wri_content_clear_both"><div class="blog_h1"><span class="graybg">基础知识</span></div>
<p>Jackson JSON 提供了一系列API，便于Java程序读写JSON字符串。它具有强大对数据绑定能力，可以方便的在Java对象和JSON字符串之间进行转换。</p>
<div class="blog_h2"><span class="graybg">创建JSON</span></div>
<div class="blog_h3"><span class="graybg">从Java对象创建（绑定）</span></div>
<p>代码示例：</p>
<pre class="crayon-plain-tag">ObjectMapper mapper = new ObjectMapper();
// 启用缩进，更易读
mapper.configure(SerializationFeature.INDENT_OUTPUT, true);
// 输出Map类型时，以键排序
mapper.configure(SerializationFeature.ORDER_MAP_ENTRIES_BY_KEYS, true);
// 日期对象的默认输出格式
mapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd"));

/**
 * Java字段名/属性名到JSON字段的映射策略
 */
mapper.setPropertyNamingStrategy( new PropertyNamingStrategy() {
    public String nameForField( MapperConfig config, AnnotatedField field, String defaultName ) {
        if ( field.getFullName().equals( "cc.gmem.vo.Entity#name" ) )
            return "Entity-Name";
        return super.nameForField( config, field, defaultName );
    }

    public String nameForGetterMethod( MapperConfig config, AnnotatedMethod method, String defaultName ) {
        if ( method.getAnnotated().getDeclaringClass().equals( Entity.class ) &amp;&amp; defaultName.equals( "no" ) )
            return "Entity-No";
        return super.nameForGetterMethod( config, method, defaultName );
    }
} );
// 忽略空属性/字段
mapper.setSerializationInclusion(Include.NON_EMPTY);
// 把entity转换为JSON然后写入标准输出
mapper.writeValue(System.out, entity);</pre>
<div class="blog_h3"><span class="graybg">从JsonNode树创建</span></div>
<p>示例代码：</p>
<pre class="crayon-plain-tag">// 此工厂用于创建JsonNode对象
JsonNodeFactory factory = new JsonNodeFactory( false );
// 此工厂用于创建JSON的生成器、解析器
JsonFactory jsonFactory = new JsonFactory();
// 写入到标准输出
JsonGenerator generator = jsonFactory.createGenerator( System.out );
ObjectMapper mapper = new ObjectMapper();
// 根节点
ObjectNode entity = factory.objectNode();
entity.put( "name", "entityname" );
mapper.writeTree( generator, entity );</pre>
<div class="blog_h3"><span class="graybg">构建JSON流</span></div>
<p>这种方式很不直观，但是节约内存：</p>
<pre class="crayon-plain-tag">JsonFactory factory = new JsonFactory();
JsonGenerator generator = factory.createGenerator(new FileWriter(new File("entity.json")));


generator.writeStartObject();
generator.writeFieldName("name");
generator.writeString("Alex");
generator.writeFieldName("dataset");

generator.writeStartArray();
generator.writeStartObject();
generator.writeStringField("zip", "223442");
generator.writeEndObject();
generator.writeEndArray();
generator.writeEndObject();

generator.close();</pre>
<div class="blog_h2"><span class="graybg">解析JSON</span></div>
<div class="blog_h3"><span class="graybg">解析JSON流</span></div>
<p>Jackson提供了一种底层API，允许逐符号的处理JSON：</p>
<pre class="crayon-plain-tag">JsonFactory factory = new JsonFactory();
JsonParser parser = factory.createParser( "{ addresses: [ { zip: 223442 } ] }" );
// 允许非标准的JSON格式：不带引号的字段名
parser.configure( JsonParser.Feature.ALLOW_UNQUOTED_FIELD_NAMES, true );
while ( !parser.isClosed() ) {
    // 获取下一个解析得到的记号
    JsonToken token = parser.nextToken();
    // 没有下一个记号，说明解析完毕
    if ( token == null ) break;
    // 寻找名为addresses的字段
    if ( JsonToken.FIELD_NAME.equals( token ) &amp;&amp; "addresses".equals( parser.getCurrentName() ) ) {
        // 期望下一个符号是数组开始
        token = parser.nextToken();
        if ( !JsonToken.START_ARRAY.equals( token ) ) break;
        // 期望下一个符号是对象开始
        token = parser.nextToken();
        if ( !JsonToken.START_OBJECT.equals( token ) ) break;
        while ( true ) {
            token = parser.nextToken();
            if ( token == null ) break;
            if ( JsonToken.FIELD_NAME.equals( token ) &amp;&amp; "zip".equals( parser.getCurrentName() ) ) {
                token = parser.nextToken();
                System.out.println( parser.getText() );
            }

        }

    }

}</pre>
<div class="blog_h3"><span class="graybg">解析为JsonNode树</span></div>
<pre class="crayon-plain-tag">ObjectMapper mapper = new ObjectMapper();
mapper.configure( JsonParser.Feature.ALLOW_UNQUOTED_FIELD_NAMES, true )

JsonNode node = mapper.readTree( "{ addresses: [ { zip: 223442 } ] }" );
Iterator&lt;String&gt; fieldNames = node.fieldNames();
while ( fieldNames.hasNext() ) {
    String fieldName = fieldNames.next();
    System.out.println( fieldName );
    JsonNode el = node.get( fieldName );
    if ( el instanceof ArrayNode ) {
        ArrayNode ael = (ArrayNode) el;
        ael.forEach( n -&gt; {
            System.out.println( n );
        } );
    }
}</pre>
<div class="blog_h3"><span class="graybg">解析为Java对象（绑定） </span></div>
<pre class="crayon-plain-tag">ObjectMapper mapper = new ObjectMapper();
// 缩进（漂亮输出pretty-printing
mapper.enable(SerializationFeature.INDENT_OUTPUT);
// 禁止把日期类型串行化为数字时间戳
mapper.disable( SerializationFeature.WRITE_DATES_AS_TIMESTAMPS );
// 遇到里面没有任何可访问字段/属性的对象时怎么办，禁用后将这种对象串行化为{}
mapper.disable( SerializationFeature.FAIL_ON_EMPTY_BEANS );
// 遇到不可映射的属性时，是否报错
mapper.disable( DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES );
// 允许把空串绑定到null值
mapper.enable( DeserializationFeature.ACCEPT_EMPTY_STRING_AS_NULL_OBJECT );
// 允许非标准的JSON格式：使用单引号
mapper.configure( JsonParser.Feature.ALLOW_SINGLE_QUOTES, true );
// 允许非标准的JSON格式：不带引号的字段名
mapper.configure( JsonParser.Feature.ALLOW_UNQUOTED_FIELD_NAMES, true );
// 允许JSON中的C/C++风格的注释
mapper.configure(JsonParser.Feature.ALLOW_COMMENTS, true);
// 启用非ASCI字符（默认启用）
mapper.configure( JsonGenerator.Feature.ESCAPE_NON_ASCII, false );

// 绑定为特定类型
Entity entity = mapper.readValue(json, Entity.class);
// 默认自动转换为Map或者List之类集合对象
Map entity = mapper.readValue(json);</pre>
<div class="blog_h2"><span class="graybg">类型转换</span></div>
<p>Jackson有时可以用来进行数据类型的转换，例如：</p>
<pre class="crayon-plain-tag">// 在包装类型和基本类型的集合之间进行转换
List&lt;Integer&gt; sourceList = ...;
int[] ints = mapper.convertValue(sourceList, int[].class);
// 在POJO和Map之间进行转换
Map&lt;String,Object&gt; propertyMap = mapper.convertValue(pojoValue, Map.class);
PojoType pojo = mapper.convertValue(propertyMap, PojoType.class);
// 将Base64转换为字节数组
String base64 = "TWFuIGlzIGRpc3Rpbmd1aXNoZWQsIG5vdCBvbmx5IGJ5IGhpcyByZWFzb24sIGJ1dCBieSB0aGlz";
byte[] binary = mapper.convertValue(base64, byte[].class);</pre>
<div class="blog_h2"><span class="graybg">数据绑定</span></div>
<p>JSON到Java对象的数据绑定，主要依赖于注解</p>
<div class="blog_h3"><span class="graybg">注解列表</span></div>
<table class="full-width fixed-word-wrap">
<thead>
<tr>
<td style="width: 20%; text-align: center;">注解</td>
<td style="text-align: center;">说明</td>
</tr>
</thead>
<tbody>
<tr>
<td>@JsonProperty</td>
<td>
<p>用于字段/setter/getter上，指定该字段映射到的JSON字段名</p>
<p>属性：<br />defaultValue  指定默认值，核心绑定模块没有使用该属性</p>
</td>
</tr>
<tr>
<td>@JsonIgnore</td>
<td>用于字段/setter上，指定该字段不进行数据绑定</td>
</tr>
<tr>
<td>@JsonIgnoreType</td>
<td>用于类上，指定哪些类型的字段都被忽略</td>
</tr>
<tr>
<td>@JsonAutoDetect</td>
<td>用于类上，指定哪些类型的方法用于属性的自动发现。示例：<br />
<pre class="crayon-plain-tag">@JsonAutoDetect(fieldVisibility = Visibility.ANY)
public class PrivateBean {
    private int id;
    private String name;
}</pre>
</td>
</tr>
<tr>
<td>@JsonIgnoreProperties</td>
<td>用于类上，指定哪些字段不进行数据绑定</td>
</tr>
<tr>
<td>@JsonInclude</td>
<td>用于类或字段上，指定哪些“无值“（null、空）需要包含在串行化过程中</td>
</tr>
<tr>
<td>@JsonFormat</td>
<td>指定如何格式化某个字段，例如：<br />
<pre class="crayon-plain-tag">// 格式化为带毫秒的
@JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss.SSSZ", locale = "zh", timezone = "GMT+8")
// 格式化为数字时间戳
@JsonFormat(shape = JsonFormat.Shape.NUMBER)
private Date date;</pre>
</td>
</tr>
<tr>
<td>@JsonUnwrapped</td>
<td>在串行化时，展开一个嵌入式对象，在反串行化时，包装对应的几个字段为对象</td>
</tr>
<tr>
<td>@JsonView</td>
<td>用于定义视图，每个POJO可以定义多个视图，这些视图包含不同的属性</td>
</tr>
<tr>
<td>@JsonNaming</td>
<td>
<p>用于指定JSON与POJO转换时的名称映射策略：<br />LOWER_CAMEL_CASE  JSON使用小写开头的驼峰式<br />KEBAB_CASE  JSON使用短横线连接式，例如kebab-case<br />SNAKE_CASE  JSON使用下划线连接时，snake_case<br />UPPER_CAMEL_CASE  JSON使用大写开头的驼峰式，UpperCamelCase</p>
<p>示例：</p>
<pre class="crayon-plain-tag">@JsonNaming( PropertyNamingStrategy.SnakeCaseStrategy.class )
public class FaceRecogResult {} </pre>
</td>
</tr>
<tr>
<td colspan="2"><strong><em>反串行化注解</em></strong></td>
</tr>
<tr>
<td>@JacksonInject</td>
<td>
<p>指示属性通过注入得到，而不是从JSON解析到
<p>示例：</p>
<pre class="crayon-plain-tag">public class BeanWithInject {
    @JacksonInject
    public int key;
}

// 注入的上下文对象
InjectableValues inject = new InjectableValues.Std()
                .addValue( int.class, 1 ).addValue( "key", "value" );
new ObjectMapper().reader(inject).forType(BeanWithInject.class).readValue(json);</pre>
</td>
</tr>
<tr>
<td>@JsonAnySetter</td>
<td>定义一个具有两个参数的方法为通配的Setter，用于绑定未成功映射的JSON属性</td>
</tr>
<tr>
<td>@JsonCreator</td>
<td>Jackson JSON不需要默认构造器。在公共/私有的构造器上加上此注解，则Jackson在绑定时自动调用此构造器来创建对象：<br />
<pre class="crayon-plain-tag">@JsonCreator
private CtorBean(@JsonProperty("name") String name, @JsonProperty("age") int age)
{
    this.name = name;
    this.age = age;
}</pre>
<p>或者，你也可以注解在静态的工厂方法上：</p>
<pre class="crayon-plain-tag">@JsonCreator
public static FactoryBean create(@JsonProperty("name") String name) {
    // construct and return an instance
} </pre>
</td>
</tr>
<tr>
<td><span style="color: #24292e;">@JsonSetter</span></td>
<td>用于指定任意方法为Setter</td>
</tr>
<tr>
<td><span style="color: #24292e;">@JsonEnumDefaultValue</span></td>
<td>2.8新增。反串行化未知枚举值时，给出默认值</td>
</tr>
<tr>
<td><span style="color: #24292e;">@JsonDeserialize</span></td>
<td>指定一个自定义的反串行化器：<br />
<pre class="crayon-plain-tag">public class Event {
    @JsonDeserialize(using = CustomDateDeserializer.class)
    public Date eventDate;
}</pre>
</td>
</tr>
<tr>
<td colspan="2"><strong><em>串行化注解</em></strong></td>
</tr>
<tr>
<td><span style="color: #24292e;">@JsonAnyGetter</span></td>
<td>指定一个用作通配Getter的方法，调用该方法应该获得一个Map，其中所有键会作为JSON的额外属性</td>
</tr>
<tr>
<td><span style="color: #24292e;">@JsonGetter</span></td>
<td>用于指定任意方法为Getter</td>
</tr>
<tr>
<td>@JsonPropertyOrder</td>
<td>用于指定属性的串行化顺序</td>
</tr>
<tr>
<td>@JsonRawValue</td>
<td>
<p>指示一个属性的值应该原样的放置到产生的JSON中，不进行任何转义
<p>在属性值是预先准备好的JSON格式时，使用该注解</p>
</td>
</tr>
<tr>
<td>@JsonValue</td>
<td>在POJO的某个方法上标注，当此POJO被串行化时，调用此方法得到的值作为串行化结果 </td>
</tr>
<tr>
<td>@JsonRootName </td>
<td>给串行化后的POJO加上一个外套：<br />
<pre class="crayon-plain-tag">@JsonRootName(value = "user")
public class UserWithRoot {
    public int id;
    public String name;
}</pre></p>
<p>导致串行化为：</p>
<pre class="crayon-plain-tag">{
    "user": {
        "id": 1,
        "name": "John"
    }
}</pre>
</td>
</tr>
<tr>
<td>@JsonAppend</td>
<td>在串行化时添加额外字段，而不需要改变类。示例：<br />
<pre class="crayon-plain-tag">@JsonAppend(attrs = { 
  @JsonAppend.Attr(value = "version") 
})
public class BeanWithAppend {
    private int id;
    private String name;
}
ObjectWriter writer = mapper.writerFor(BeanWithAppend.class).withAttribute("version", "1.0");
System.out.println( writer.writeValueAsString(bean) );
// 输出如下：
{
    "id": 2,
    "name": "Bean With Append Annotation",
    "version": "1.0"
}</pre>
</td>
</tr>
<tr>
<td>@JsonSerialize</td>
<td>指定一个自定义的串行化器：<br />
<pre class="crayon-plain-tag">public class Event {
    @JsonSerialize(using = CustomDateSerializer.class)
    public Date eventDate;
}</pre>
</td>
</tr>
<tr>
<td colspan="2"><strong><em>类型处理</em></strong></td>
</tr>
<tr>
<td>@JsonSubTypes</td>
<td>
<p>用于类上，指示该类型的子类型，反串行化多态类时如果基于逻辑类型名称，则可以使用
<p>示例一：</p>
<pre class="crayon-plain-tag">@JsonTypeInfo( 
    use = JsonTypeInfo.Id.CLASS, include = JsonTypeInfo.As.PROPERTY, property = "@class" 
)
@JsonSubTypes( {
        @JsonSubTypes.Type( value = Lion.class, name = "lion" ),
        @JsonSubTypes.Type( value = Elephant.class, name = "elephant" )
} )
abstract class Animal {}
class Lion extends Animal {}
class Elephant extends Animal {}</pre>
<p> 串行化结果为：</p>
<pre class="crayon-plain-tag">// mapper.writeValue( System.out, new Lion() );
{
  "@class" : "cc.gmem.study.jackson.Lion"
}</pre>
<p> 示例二：</p>
<pre class="crayon-plain-tag">@JsonTypeInfo( 
    use = JsonTypeInfo.Id.MINIMAL_CLASS, include = JsonTypeInfo.As.PROPERTY, property = "@class" 
)
abstract class Animal {}</pre>
<p> 串行化结果为：</p>
<pre class="crayon-plain-tag">{
  "@class" : ".Lion"
}</pre>
<p>类似的：</p>
<pre class="crayon-plain-tag">@JsonTypeInfo( use=JsonTypeInfo.Id.CLASS, include=JsonTypeInfo.As.PROPERTY, property="@class" )
// 串行化结果：
{
  "@class" : "com.kingsmartsi.pems.fr.stport.vo.Lion"
}

@JsonTypeInfo( use=JsonTypeInfo.Id.NAME, include=JsonTypeInfo.As.PROPERTY, property="@class" )
abstract class Animal {}
// 串行化结果：
{
  "@class" : "Lion"
} </pre>
</td>
</tr>
<tr>
<td>@JsonTypeId</td>
<td>用于类上，指示该字段的值用作类型标识</td>
</tr>
<tr>
<td>@JsonTypeName</td>
<td>用于类上，定义一个逻辑类名。示例：<br />
<pre class="crayon-plain-tag">@JsonTypeInfo( use=JsonTypeInfo.Id.NAME, include=JsonTypeInfo.As.PROPERTY, property="@class" )
abstract class Animal {}
@JsonTypeName("LION")
class Lion extends Animal {}

// 串行化结果：
{
  "@class" : "LION"
}</pre>
</td>
</tr>
<tr>
<td colspan="2"><strong><em>对象引用和标识符</em></strong></td>
</tr>
<tr>
<td>
<p>@JsonManagedReference
<p>@JsonBackReference</p>
</td>
<td>
<p>这一对注解用于指示、处理父子关系。可以用来处理对象循环引用</p>
<p>示例：</p>
<pre class="crayon-plain-tag">class Hotel {
    // 管理方，负责输出JSON
    @JsonManagedReference
    private List&lt;Room&gt; rooms;
}
class Room {
    // 被管理方，属性被忽略
    @JsonBackReference
    private Hotel hotel;
}

// mapper.writeValue( System.out, hotel );
{
  "rooms" : [ { }, { } ]
} </pre>
</td>
</tr>
<tr>
<td>@JsonIdentityInfo</td>
<td>
<p>类/属性注解，用于指定对象标识符，这样，指向单个POJO的多个引用可以被正确的反串行化。可以用于处理对象循环引用
<p>示例：</p>
<pre class="crayon-plain-tag">@JsonIdentityInfo(
        generator = ObjectIdGenerators.PropertyGenerator.class,
        property = "id"
)
class Hotel {
    private int id;
    private List&lt;Room&gt; rooms;
}
@JsonIdentityInfo(
        generator = ObjectIdGenerators.PropertyGenerator.class,
        property = "id"
)
class Room {
    private int id;
    private Hotel hotel;
}

// 串行化Hotel的结果为：
{
  "id" : 1,
  "rooms" : [ {
    "id" : 100,
    "hotel" : 1
  }, {
    "id" : 101,
    "hotel" : 1
  } ]
} </pre>
</td>
</tr>
</tbody>
</table>
<div class="blog_h1"><span class="graybg">常见问题</span></div>
<div class="blog_h3"><span class="graybg">JacksonJson把JSON绑定为对象出错</span></div>
<p>报错信息：Unrecognized field "***" (Class ***), not marked as ignorable<br /> 报错原因：JSON中包含对象没有的属性<br /> 解决办法：
<pre class="crayon-plain-tag">#方法一
@Entity
@Table ( name = "T_USER" )
@JsonIgnoreProperties ( ignoreUnknown = true )
public class User implements java.io.Serializable

#方法二
ObjectMapper objectMapper = getObjectMapper();
objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);</pre>
<div>
<div class="blog_h3"><span class="graybg">JacksonJson把对象转换为JSON，导致StackOvewFlowError</span></div>
</div>
<p>报错信息：存在循环引用<br /> 解决办法：设置@JsonIgnore。JacksonJson 2.x版本中有专门处理循环引用的注解</p>
</div><p>The post <a rel="nofollow" href="https://blog.gmem.cc/jacksonjson-faq">JacksonJson知识集锦</a> appeared first on <a rel="nofollow" href="https://blog.gmem.cc">绿色记忆</a>.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.gmem.cc/jacksonjson-faq/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Spring配置：集成Hibernate、JacksonJSON、AspectJ等框架</title>
		<link>https://blog.gmem.cc/spring-config-with-hibernate-jacksonjson-aspectj</link>
		<comments>https://blog.gmem.cc/spring-config-with-hibernate-jacksonjson-aspectj#comments</comments>
		<pubDate>Mon, 26 Nov 2012 08:39:24 +0000</pubDate>
		<dc:creator><![CDATA[Alex]]></dc:creator>
				<category><![CDATA[Java]]></category>
		<category><![CDATA[AspectJ]]></category>
		<category><![CDATA[Cache]]></category>
		<category><![CDATA[Hibernate]]></category>
		<category><![CDATA[JacksonJSON]]></category>
		<category><![CDATA[Log4jdbc]]></category>
		<category><![CDATA[Scheduler]]></category>
		<category><![CDATA[Spring]]></category>
		<category><![CDATA[配置文件]]></category>

		<guid isPermaLink="false">http://blog.gmem.cc/?p=1110</guid>
		<description><![CDATA[<p>本文提及的该套配置文件，覆盖了JavaEE项目开发的最常见需求，包括：依赖注入、事务控制、AOP、任务调度、缓存、MVC框架等方面的内容。 容易改变的配置项独立到属性文件中： [crayon-69e29a87113f6622397956/] Spring配置文件部分： [crayon-69e29a87113fa376526827/] Spring MVC配置文件部分： [crayon-69e29a8711400571514889/] ehcache配置部分： [crayon-69e29a8711404096952224/] Web.xml配置（使用了Spring的JavaConfig）： [crayon-69e29a8711407127867423/] Java Config类： [crayon-69e29a871140a872502621/] [crayon-69e29a871140c383166483/] Maven依赖包列表： [crayon-69e29a871140e195136539/] Maven插件配置（支持AspectJ）： [crayon-69e29a8711412023138659/]</p>
<p>The post <a rel="nofollow" href="https://blog.gmem.cc/spring-config-with-hibernate-jacksonjson-aspectj">Spring配置：集成Hibernate、JacksonJSON、AspectJ等框架</a> appeared first on <a rel="nofollow" href="https://blog.gmem.cc">绿色记忆</a>.</p>
]]></description>
				<content:encoded><![CDATA[<div class="wri_content_clear_both">本文提及的该套配置文件，覆盖了JavaEE项目开发的最常见需求，包括：依赖注入、事务控制、AOP、任务调度、缓存、MVC框架等方面的内容。<br />
容易改变的配置项独立到属性文件中：<br />
<pre class="crayon-plain-tag">hibernateDialect=org.hibernate.dialect.MySQL5Dialect
#启用了log4jdbc支持
jdbcDriver=net.sf.log4jdbc.DriverSpy
jdbcDriverUrl=jdbc:log4jdbc:mysql://192.168.0.201:3306/initpemsdb1.1.1
jdbcUserName=root
jdbcPassword=root</pre><br />
Spring配置文件部分：<br />
<pre class="crayon-plain-tag">&lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;beans 
    xmlns="http://www.springframework.org/schema/beans" 
    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" 
    xmlns:util="http://www.springframework.org/schema/util" 
    xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:tx="http://www.springframework.org/schema/tx" 
    xmlns:task="http://www.springframework.org/schema/task" 
    xmlns:cache="http://www.springframework.org/schema/cache"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-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/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
        http://www.springframework.org/schema/task  http://www.springframework.org/schema/task/spring-task-3.0.xsd
        http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache-3.1.xsd
    "&gt;
    &lt;!-- 定义属性，在后面的配置中可以使用#{appCfg.xxx}引用 --&gt;
    &lt;util:properties id="appCfg" location="classpath:applicationConfig.properties" /&gt;
    &lt;!-- 包扫描配置 --&gt;
    &lt;context:component-scan base-package="cc.gmem.demo"&gt;
        &lt;!-- 去除Java Config类 --&gt;
        &lt;context:exclude-filter type="annotation" expression="org.springframework.context.annotation.Configuration" /&gt;
        &lt;!-- 去除Spring MVC类 --&gt;
        &lt;context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" /&gt;
        &lt;!-- 匹配AspectJ Pattern的类被去除 --&gt;
        &lt;context:exclude-filter type="aspectj" expression="cc.gmem.demo.aop.web.*" /&gt;
    &lt;/context:component-scan&gt;
    &lt;!-- 启用注解支持 --&gt;
    &lt;context:annotation-config /&gt;
    &lt;!-- 支持@Configurable注解 --&gt;
    &lt;context:spring-configured /&gt;
    &lt;!--  启用注解方式的事务：基于AspectJ织入 --&gt;
    &lt;tx:annotation-driven transaction-manager="txManager" mode="aspectj" /&gt;
    &lt;!--  启用注解方式的缓存配置：基于AspectJ织入 --&gt;
    &lt;cache:annotation-driven cache-manager="cacheManager" mode="aspectj" /&gt;
    &lt;!--  启用注解方式的任务执行(例如@Async)：基于AspectJ织入 --&gt;
    &lt;task:annotation-driven executor="taskExecutor" mode="aspectj" /&gt;
    
    &lt;!--  任务调度器配置，pool-size为线程池大小，限制了同时最多被调度的任务 --&gt;
    &lt;task:scheduler pool-size="100" id="scheduler" /&gt;
    &lt;!-- 任务计划列表，支持固定频率、固定延迟、Cron表达式等 --&gt;
    &lt;task:scheduled-tasks scheduler="scheduler"&gt;
        &lt;task:scheduled fixed-rate="120000" method="run" ref="hibernateStatisticsMonitor" /&gt;
    &lt;/task:scheduled-tasks&gt;
    &lt;!-- 任务执行器，用于异步执行任务 --&gt;
    &lt;task:executor id="taskExecutor" keep-alive="3600" pool-size="10-100" queue-capacity="10000" rejection-policy="CALLER_RUNS" /&gt;
    &lt;!-- 引入其它Spring配置文件 --&gt;
    &lt;import resource="report-and-etl.xml" /&gt;  
    &lt;!-- Hibernate配置  --&gt;
    &lt;bean id="dataSource" class="org.logicalcobwebs.proxool.ProxoolDataSource"&gt;
        &lt;property name="alias" value="connectionPool" /&gt;
        &lt;property name="driver" value="#{appCfg.jdbcDriver}" /&gt;
        &lt;property name="driverUrl" value="#{appCfg.jdbcDriverUrl}" /&gt;
        &lt;property name="user" value="#{appCfg.jdbcUserName}" /&gt;
        &lt;property name="password" value="#{appCfg.jdbcPassword}" /&gt;
        &lt;property name="statistics" value="10s" /&gt;
        &lt;property name="minimumConnectionCount" value="10" /&gt;
        &lt;property name="maximumConnectionCount" value="100" /&gt;
        &lt;property name="simultaneousBuildThrottle" value="10" /&gt;
        &lt;property name="maximumActiveTime" value="3600000" /&gt;
    &lt;/bean&gt;
    &lt;bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" autowire="byName" /&gt;
    &lt;bean id="nativeJdbcExtractor" class="org.springframework.jdbc.support.nativejdbc.CommonsDbcpNativeJdbcExtractor" lazy-init="true" /&gt;
    &lt;bean id="sessionFactory" p:dataSource-ref="dataSource" class="cc.gmem.demo.hibernate.AnnotationSessionFactoryBean" depends-on="appCfg" &gt;
        &lt;property name="packagesToScan"&gt;
            &lt;list&gt;
                &lt;value&gt;cc.gmem.demo.**.domain&lt;/value&gt;
            &lt;/list&gt;
        &lt;/property&gt;
        &lt;property name="hibernateProperties"&gt;
            &lt;value&gt;
                hibernate.dialect=#{appCfg.hibernateDialect}
                hibernate.jdbc.batch_size=30
                hibernate.show_sql=false
                hibernate.format_sql=true
                hibernate.generate_statistics=true
                hibernate.transaction.factory_class=org.hibernate.transaction.JDBCTransactionFactory
                hibernate.current_session_context_class=org.springframework.orm.hibernate3.SpringSessionContext
                hibernate.query.factory_class=org.hibernate.hql.ast.ASTQueryTranslatorFactory
                hibernate.hbm2ddl.auto=update
                #启用二级缓存
                hibernate.cache.use_second_level_cache=true
                hibernate.cache.use_query_cache=true
                hibernate.cache.region.factory_class=org.hibernate.cache.SingletonEhCacheRegionFactory
            &lt;/value&gt;
        &lt;/property&gt;
    &lt;/bean&gt;
    &lt;!-- Spring缓存配置 --&gt;
    &lt;bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager"&gt;
        &lt;property name="cacheManager" ref="ehcache" /&gt;
    &lt;/bean&gt;
    &lt;bean id="ehcache" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean"&gt;
        &lt;property name="configLocation"&gt;
            &lt;value&gt;classpath:ehcache.xml&lt;/value&gt;
        &lt;/property&gt;
        &lt;property name="shared" value="true" /&gt;
    &lt;/bean&gt;
    &lt;bean id="hibernateStatisticsMonitor" class="cc.gmem.demo.hibernate.HibernateStatisticsMonitor" /&gt;
    &lt;bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager" p:sessionFactory-ref="sessionFactory" /&gt;
    &lt;!-- Velocity引擎配置 --&gt;
    &lt;bean id="velocityEngine" class="org.apache.velocity.app.VelocityEngine"&gt;
        &lt;constructor-arg type="java.util.Properties"&gt;
            &lt;value&gt;
                &lt;![CDATA[
                #{T(org.apache.velocity.runtime.RuntimeConstants).RUNTIME_LOG_LOGSYSTEM_CLASS}=org.apache.velocity.runtime.log.Log4JLogChute
                runtime.log.logsystem.log4j.logger=velocityLogger
                #{T(org.apache.velocity.runtime.RuntimeConstants).INPUT_ENCODING}=UTF-8
                #{T(org.apache.velocity.runtime.RuntimeConstants).OUTPUT_ENCODING}=UTF-8
                #{T(org.apache.velocity.runtime.RuntimeConstants).VM_PERM_ALLOW_INLINE}=true
                #{T(org.apache.velocity.runtime.RuntimeConstants).RESOURCE_LOADER}=class
                #{T(org.apache.velocity.runtime.RuntimeConstants).PARSER_POOL_SIZE}=100
                class.resource.loader.class=org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
                ]]&gt;
            &lt;/value&gt;
        &lt;/constructor-arg&gt;
    &lt;/bean&gt;
    &lt;!--国际化支持--&gt;
    &lt;bean id="messageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource"&gt;
         &lt;property name="basenames"&gt;
             &lt;list&gt;
                 &lt;value&gt;classpath:message.gmemdemo&lt;/value&gt;
             &lt;/list&gt;
         &lt;/property&gt;
         &lt;property name="defaultEncoding" value="UTF-8" /&gt;
         &lt;property name="cacheSeconds" value="5" /&gt;
    &lt;/bean&gt;
    &lt;!--Jackson JSON --&gt;
    &lt;bean id="objectMapper" class="com.fasterxml.jackson.databind.ObjectMapper" autowire="byType" /&gt;
    &lt;!-- Spring类型转换服务，特别是用于时间日期格式转换 --&gt;
    &lt;bean id="conversionService" class="org.springframework.format.support.FormattingConversionServiceFactoryBean"&gt;
        &lt;property name="converters"&gt;
            &lt;set&gt;
                &lt;bean class="net.greenmemory.spring.converter.DateTimeConvertor"&gt;
                    &lt;constructor-arg&gt;
                        &lt;array&gt;
                            &lt;value&gt;yyyy-MM-dd&lt;/value&gt;
                            &lt;value&gt;yyyy-MM-dd HH:mm:ss&lt;/value&gt;
                            &lt;value&gt;yyyy-MM-dd HH:mm:ss.SSS&lt;/value&gt;
                       &lt;/array&gt;
                    &lt;/constructor-arg&gt;
                &lt;/bean&gt;
            &lt;/set&gt;
       &lt;/property&gt;
       &lt;property name="formatters"&gt;
           &lt;set&gt;
               &lt;bean class="org.springframework.format.datetime.DateFormatter"&gt;
                   &lt;constructor-arg&gt;
                       &lt;value&gt;yyyy-MM-dd&lt;/value&gt;
                   &lt;/constructor-arg&gt;
               &lt;/bean&gt;
           &lt;/set&gt;
       &lt;/property&gt;
       &lt;property name="formatterRegistrars"&gt;
           &lt;set&gt;
           &lt;/set&gt;
       &lt;/property&gt;
    &lt;/bean&gt;
&lt;/beans&gt;</pre><br />
Spring MVC配置文件部分：<br />
<pre class="crayon-plain-tag">&lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;beans 
    xmlns="http://www.springframework.org/schema/beans" 
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
    "&gt;
    &lt;context:component-scan base-package="cc.gmem.demo.**.ctrl"&gt;
        &lt;context:exclude-filter type="annotation" expression="org.springframework.context.annotation.Configuration" /&gt;
    &lt;/context:component-scan&gt;
    &lt;context:component-scan base-package="cc.gmem.demo.aop.web" /&gt;

    &lt;context:annotation-config /&gt;

    &lt;mvc:annotation-driven&gt;
        &lt;mvc:message-converters&gt;
            &lt;bean class="org.springframework.http.converter.json.jacksonjson.MappingJackson2HttpMessageConverter"&gt;
                &lt;property name="objectMapper" ref="objectMapper" /&gt;
            &lt;/bean&gt;
        &lt;/mvc:message-converters&gt;
    &lt;/mvc:annotation-driven&gt;

    &lt;mvc:interceptors&gt;
        &lt;bean id="openSessionInViewInterceptor" class="org.springframework.orm.hibernate3.support.OpenSessionInViewInterceptor"&gt;
            &lt;property name="sessionFactory" ref="sessionFactory" /&gt;
        &lt;/bean&gt;
            &lt;mvc:interceptor&gt;     
            &lt;mvc:mapping path="/home/*" /&gt; 
            &lt;!-- 自定义MVC拦截器 --&gt;
            &lt;bean class="cc.gmem.demo.spring.LogonInterceptor" /&gt; 
        &lt;/mvc:interceptor&gt;  
        
    &lt;/mvc:interceptors&gt;

    &lt;bean id="viewResolver" class="org.springframework.web.servlet.view.UrlBasedViewResolver"&gt;
        &lt;property name="viewClass" value="org.springframework.web.servlet.view.JstlView" /&gt;
        &lt;property name="prefix" value="/WEB-INF/jsp/" /&gt;
        &lt;property name="suffix" value=".jsp" /&gt;
        &lt;property name="order" value="0" /&gt;
    &lt;/bean&gt;

    &lt;mvc:resources mapping="/css/**" location="/css/" /&gt;
    &lt;mvc:resources mapping="/icons/**" location="/icons/" /&gt;
    &lt;mvc:resources mapping="/images/**" location="/images/" /&gt;
    &lt;mvc:resources mapping="/themes/**" location="/themes/" /&gt;
    &lt;mvc:resources mapping="/js/**" location="/js/" /&gt;
&lt;/beans&gt;</pre><br />
ehcache配置部分：<br />
<pre class="crayon-plain-tag">&lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;ehcache&gt;
    &lt;diskStore path="D:/Temp/ehcache" /&gt;
    &lt;defaultCache eternal="false" /&gt;
    &lt;cache name="entityCache" eternal="false" maxElementsInMemory="1000" timeToIdleSeconds="120" timeToLiveSeconds="3600"
        overflowToDisk="true" memoryStoreEvictionPolicy="LFU" /&gt;
&lt;/ehcache&gt;</pre><br />
Web.xml配置（使用了Spring的JavaConfig）：<br />
<pre class="crayon-plain-tag">&lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"&gt;
    &lt;context-param&gt;
        &lt;param-name&gt;contextClass&lt;/param-name&gt;
        &lt;param-value&gt;org.springframework.web.context.support.AnnotationConfigWebApplicationContext&lt;/param-value&gt;
    &lt;/context-param&gt;
    &lt;context-param&gt;
        &lt;param-name&gt;contextConfigLocation&lt;/param-name&gt;
        &lt;param-value&gt;cc.gmem.demo.spring.SpringBeanDefinitionRegistrar&lt;/param-value&gt;
    &lt;/context-param&gt;
    &lt;listener&gt;
        &lt;listener-class&gt;org.springframework.web.context.ContextLoaderListener&lt;/listener-class&gt;
    &lt;/listener&gt;
    &lt;servlet&gt;
        &lt;servlet-name&gt;springmvc&lt;/servlet-name&gt;
        &lt;servlet-class&gt;org.springframework.web.servlet.DispatcherServlet&lt;/servlet-class&gt;
        &lt;init-param&gt;
            &lt;param-name&gt;contextClass&lt;/param-name&gt;
            &lt;param-value&gt;org.springframework.web.context.support.AnnotationConfigWebApplicationContext&lt;/param-value&gt;
        &lt;/init-param&gt;
        &lt;init-param&gt;
            &lt;param-name&gt;contextConfigLocation&lt;/param-name&gt;
            &lt;param-value&gt;cc.gmem.demo.spring.SpringMVCBeanDefinitionRegistrar&lt;/param-value&gt;
        &lt;/init-param&gt;
    &lt;/servlet&gt;
    &lt;servlet-mapping&gt;
        &lt;servlet-name&gt;springmvc&lt;/servlet-name&gt;
        &lt;url-pattern&gt;/&lt;/url-pattern&gt;
    &lt;/servlet-mapping&gt;

    &lt;servlet-mapping&gt;
        &lt;servlet-name&gt;adminServlet&lt;/servlet-name&gt;
        &lt;url-pattern&gt;/proxool&lt;/url-pattern&gt;
    &lt;/servlet-mapping&gt;

    &lt;session-config&gt;
        &lt;session-timeout&gt;60&lt;/session-timeout&gt;
    &lt;/session-config&gt;

    &lt;error-page&gt;
        &lt;error-code&gt;404&lt;/error-code&gt;
        &lt;location&gt;/WEB-INF/jsp/error-404.jsp&lt;/location&gt;
    &lt;/error-page&gt;
    &lt;error-page&gt;
        &lt;error-code&gt;401&lt;/error-code&gt;
        &lt;location&gt;/WEB-INF/jsp/error-401.jsp&lt;/location&gt;
    &lt;/error-page&gt;
    &lt;error-page&gt;
        &lt;error-code&gt;500&lt;/error-code&gt;
        &lt;location&gt;/WEB-INF/jsp/error-500.jsp&lt;/location&gt;
    &lt;/error-page&gt;
     &lt;welcome-file-list&gt;
        &lt;welcome-file&gt;index.jsp&lt;/welcome-file&gt;
    &lt;/welcome-file-list&gt;
&lt;/web-app&gt;</pre><br />
Java Config类：<br />
<pre class="crayon-plain-tag">@Configuration
/* XML-based bean definitions */
@ImportResource ( "classpath:applicationContext.xml" )
public class SpringBeanDefinitionRegistrar
{

    /* Auto injected spring context */
    @SuppressWarnings ( "unused" )
    @Inject
    private ApplicationContext applicationContext;

    /* Programmatic bean definition */
    @Bean ( name = "helper" )
    public Helper helper()
    {
        Helper helper = new Helper();
        return helper;
    }

}</pre><br />
<pre class="crayon-plain-tag">@Configuration
@ImportResource ( "classpath:spring-mvc.xml" )
public class SpringMVCBeanDefinitionRegistrar
{

}</pre><br />
Maven依赖包列表：<br />
<pre class="crayon-plain-tag">&lt;properties&gt;
    &lt;project.build.sourceEncoding&gt;UTF-8&lt;/project.build.sourceEncoding&gt;
    &lt;spring.version&gt;3.1.2.RELEASE&lt;/spring.version&gt;
    &lt;hibernate.version&gt;3.6.10.Mod&lt;/hibernate.version&gt;
    &lt;aspectj.version&gt;1.6.11&lt;/aspectj.version&gt;
    &lt;jackson.version&gt;2.0.4&lt;/jackson.version&gt;
&lt;/properties&gt;
&lt;dependencies&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;org.springframework&lt;/groupId&gt;
        &lt;artifactId&gt;spring-core&lt;/artifactId&gt;
        &lt;version&gt;${spring.version}&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;org.springframework&lt;/groupId&gt;
        &lt;artifactId&gt;spring-jdbc&lt;/artifactId&gt;
        &lt;version&gt;${spring.version}&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;org.springframework&lt;/groupId&gt;
        &lt;artifactId&gt;spring-beans&lt;/artifactId&gt;
        &lt;version&gt;${spring.version}&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;org.springframework&lt;/groupId&gt;
        &lt;artifactId&gt;spring-webmvc&lt;/artifactId&gt;
        &lt;version&gt;${spring.version}&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;org.springframework&lt;/groupId&gt;
        &lt;artifactId&gt;spring-orm&lt;/artifactId&gt;
        &lt;version&gt;${spring.version}&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;org.springframework&lt;/groupId&gt;
        &lt;artifactId&gt;spring-test&lt;/artifactId&gt;
        &lt;version&gt;${spring.version}&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;org.hibernate&lt;/groupId&gt;
        &lt;artifactId&gt;hibernate-core&lt;/artifactId&gt;
        &lt;version&gt;${hibernate.version}&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;org.aspectj&lt;/groupId&gt;
        &lt;artifactId&gt;aspectjweaver&lt;/artifactId&gt;
        &lt;version&gt;${aspectj.version}&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;org.aspectj&lt;/groupId&gt;
        &lt;artifactId&gt;aspectjrt&lt;/artifactId&gt;
        &lt;version&gt;${aspectj.version}&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;com.fasterxml.jackson.core&lt;/groupId&gt;
        &lt;artifactId&gt;jackson-core&lt;/artifactId&gt;
        &lt;version&gt;${jackson.version}&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;com.fasterxml.jackson.core&lt;/groupId&gt;
        &lt;artifactId&gt;jackson-databind&lt;/artifactId&gt;
        &lt;version&gt;${jackson.version}&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;com.fasterxml.jackson.core&lt;/groupId&gt;
        &lt;artifactId&gt;jackson-annotations&lt;/artifactId&gt;
        &lt;version&gt;${jackson.version}&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;javax.servlet&lt;/groupId&gt;
        &lt;artifactId&gt;servlet-api&lt;/artifactId&gt;
        &lt;version&gt;2.4&lt;/version&gt;
        &lt;scope&gt;provided&lt;/scope&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;javax.servlet.jsp&lt;/groupId&gt;
        &lt;artifactId&gt;jsp-api&lt;/artifactId&gt;
        &lt;version&gt;2.0&lt;/version&gt;
        &lt;scope&gt;provided&lt;/scope&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;javax.servlet&lt;/groupId&gt;
        &lt;artifactId&gt;jstl&lt;/artifactId&gt;
        &lt;version&gt;1.2&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;taglibs&lt;/groupId&gt;
        &lt;artifactId&gt;standard&lt;/artifactId&gt;
        &lt;version&gt;1.1.2&lt;/version&gt;
        &lt;scope&gt;provided&lt;/scope&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;javax.el&lt;/groupId&gt;
        &lt;artifactId&gt;el-api&lt;/artifactId&gt;
        &lt;version&gt;2.2&lt;/version&gt;
        &lt;scope&gt;provided&lt;/scope&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;proxool&lt;/groupId&gt;
        &lt;artifactId&gt;proxool&lt;/artifactId&gt;
        &lt;version&gt;0.9.1&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;org.javassist&lt;/groupId&gt;
        &lt;artifactId&gt;javassist&lt;/artifactId&gt;
        &lt;version&gt;3.15.0-GA&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;net.sf.log4jdbc&lt;/groupId&gt;
        &lt;artifactId&gt;log4jdbc3&lt;/artifactId&gt;
        &lt;version&gt;1.2-ext-3&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;com.sqlinform&lt;/groupId&gt;
        &lt;artifactId&gt;sqlinform&lt;/artifactId&gt;
        &lt;version&gt;0.0.1&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;javax.annotation&lt;/groupId&gt;
        &lt;artifactId&gt;jsr250-api&lt;/artifactId&gt;
        &lt;version&gt;1.0&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
        &lt;groupId&gt;javax.inject&lt;/groupId&gt;
        &lt;artifactId&gt;javax.inject&lt;/artifactId&gt;
        &lt;version&gt;1&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;joda-time&lt;/groupId&gt;
        &lt;artifactId&gt;joda-time&lt;/artifactId&gt;
        &lt;version&gt;2.1&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;cglib&lt;/groupId&gt;
        &lt;artifactId&gt;cglib&lt;/artifactId&gt;
        &lt;version&gt;2.2.2&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
        &lt;groupId&gt;org.apache.poi&lt;/groupId&gt;
        &lt;artifactId&gt;poi&lt;/artifactId&gt;
        &lt;version&gt;3.9&lt;/version&gt;
    &lt;/dependency&gt;
    
    &lt;dependency&gt;
        &lt;groupId&gt;opensymphony&lt;/groupId&gt;
        &lt;artifactId&gt;quartz-all&lt;/artifactId&gt;
        &lt;version&gt;1.6.3&lt;/version&gt;
    &lt;/dependency&gt;
&lt;/dependencies&gt;</pre><br />
Maven插件配置（支持AspectJ）：<br />
<pre class="crayon-plain-tag">&lt;plugin&gt;
    &lt;groupId&gt;org.codehaus.mojo&lt;/groupId&gt;
    &lt;artifactId&gt;aspectj-maven-plugin&lt;/artifactId&gt;
    &lt;version&gt;1.4&lt;/version&gt;
    &lt;executions&gt;
        &lt;execution&gt;
            &lt;id&gt;compile&lt;/id&gt;
            &lt;configuration&gt;
                &lt;XnoInline&gt;true&lt;/XnoInline&gt;
                &lt;forceAjcCompile&gt;true&lt;/forceAjcCompile&gt;
                &lt;showWeaveInfo&gt;true&lt;/showWeaveInfo&gt;
                &lt;source&gt;1.5&lt;/source&gt;
                &lt;target&gt;1.5&lt;/target&gt;
                &lt;encoding&gt;UTF-8&lt;/encoding&gt;
                &lt;verbose&gt;true&lt;/verbose&gt;
                &lt;outxml&gt;true&lt;/outxml&gt;
                &lt;aspectLibraries&gt;
                    &lt;aspectLibrary&gt;
                        &lt;groupId&gt;org.springframework&lt;/groupId&gt;
                        &lt;artifactId&gt;spring-aspects&lt;/artifactId&gt;
                    &lt;/aspectLibrary&gt;
                &lt;/aspectLibraries&gt;
            &lt;/configuration&gt;
            &lt;goals&gt;
                &lt;goal&gt;compile&lt;/goal&gt;
            &lt;/goals&gt;
        &lt;/execution&gt;
    &lt;/executions&gt;
&lt;/plugin&gt;</pre>
</div><p>The post <a rel="nofollow" href="https://blog.gmem.cc/spring-config-with-hibernate-jacksonjson-aspectj">Spring配置：集成Hibernate、JacksonJSON、AspectJ等框架</a> appeared first on <a rel="nofollow" href="https://blog.gmem.cc">绿色记忆</a>.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.gmem.cc/spring-config-with-hibernate-jacksonjson-aspectj/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
