2016-12-29 升级到spring-boot1.4 neo4j 使用自带的rest 进行图数据库的维护与引擎的调度;
2016-12-27 增加druid监控; http://127.0.0.1:9006/form/rest/druid/index.html
2016-12-20 菜单调整 http://192.168.1.119:9006/form/rest/resource/search/findAllByPidOrderByModuleAsc?pid=resource
2016-11-29 完成java 动态脚本调用groovy json 示例,作为flume 插件的规则脚本使用。
2016-10-28 增加extjs 文件浏览示例 http://127.0.0.1:9006/form/rest/public/file-browser.html http://127.0.0.1:9006/form/rest/logviewer/files
2016-10-18 菜单编辑界面 http://127.0.0.1:9006/form/rest/public/treegrid.html
2016-10-14 zTree 树形目录; http://127.0.0.1:9006/form/rest/html/ResourceTree.html http://127.0.0.1:9006/form/rest/resource/search/findAllByOrderByModuleAsc http://127.0.0.1:9006/form/rest/resource/search/findTop10ByOrderByModuleDesc
2016-09-21 增加mvc 拦截器;
2016-09-09 spring-boot增加session保存Redis spring-boot-redis 集群测试 OK.
2016-08-19 支持domain 多包扫描; 增加部分注解;
2016-08-05 注销mongo 的异步调用; 注销redis and mongo 的调用; //@Configuration @PropertySource("classpath:application.properties") public class MongoConfiguration {
//@Configuration
public class RedisConfiguration {
用户管理:
http://127.0.0.1:9006/form/rest/user
2016-07-21 domain 元数据 http://127.0.0.1:9006/form/rest/webmetas?domainName=com.supermy.security.domain.Resource
2016-07-20 增加资源数据 权限数据管理; 用户管理 角色管理 群组管理 权限管理 资源管理
2016-07-19 增加健康控制: http://127.0.0.1:9006/form/rest/health http://127.0.0.1:9006/form/rest/trace org.springframework.boot spring-boot-starter-actuator
更新测试方案
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = Application.class)
@WebAppConfiguration
public class MongoDBGeoSpatialTest {
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
------------------------------------
com.supermy.geo已经移植到push-server;代码暂不删除。
完成rbac 权限模型样例数据
2016-07-18 todo: rbac 数据准备与api 准备;
微服务基础框架准备已经完成。
extjs-filter 已经移植到es-query;详见web+app;
清除原有filter的代码改造 ok;
升级spring-boot1.2.7 ok;
升级spring-boot1.3.5 ok;
2016-07-14
{"DATA":
[{"deleted":null,"enabled":null,"createDate":"2016-07-14T00:00:00.000+0800","createBy":"","updateDate":"2016-07-14T09:55:50.000+0800","updateBy":"","name":"xyz","code":"xyz","pwd":"\u79d8\u94a5","tokenExpire":90,"iplist":"bb","ipBindtime":300,"ipTimeout":60,"connectCount":100,"limitBandwidth":"3000","status":false,
"pkId":4,"_links":{"self":{"href":"http://172.16.71.56:9006/form/rest/channel_auth/filter/channel_auth/4","templated":false}},"_embedded":{}},
{"deleted":null,"enabled":null,"createDate":"2016-07-14T00:00:00.000+0800","createBy":"system1","updateDate":"2016-07-14T09:48:29.000+0800","updateBy":"system2","name":"test","code":"test","pwd":"test","tokenExpire":1,"iplist":"192.168.59.103","ipBindtime":300,"ipTimeout":61,"connectCount":100,"limitBandwidth":"100","status":true,
"pkId":1,"_links":{"self":{"href":"http://172.16.71.56:9006/form/rest/channel_auth/filter/channel_auth/1","templated":false}},"_embedded":{}},
{"deleted":null,"enabled":null,"createDate":"2016-07-14T00:00:00.000+0800","createBy":"","updateDate":"2016-07-14T09:55:46.000+0800","updateBy":"","name":"abc","code":"abc","pwd":"\u79d8\u94a5","tokenExpire":90,"iplist":"aa","ipBindtime":300,"ipTimeout":60,"connectCount":100,"limitBandwidth":"2000","status":false,
"pkId":3,"_links":{"self":{"href":"http://172.16.71.56:9006/form/rest/channel_auth/filter/channel_auth/3","templated":false}},"_embedded":{}}],
"PAGE":{"size":23,"totalElements":3,"totalPages":1,"number":0}}
{"DATA":
{"_links":{},"_embedded":{"channel_auth":[{"deleted":null,"code":"test","pkId":1,"pwd":"test","connectCount":100,"enabled":null,"limitBandwidth":"100","ipBindtime":300,"updateBy":"system2","updateDate":"2016-07-14T09:48:29.000+0800","createDate":"2016-07-14T00:00:00.000+0800","tokenExpire":1,"_links":{"self":{"href":"http:\/\/172.16.71.56\/form\/rest\/channel_auth\/1","templated":false}},"name":"test","_embedded":{},"iplist":"192.168.59.103","createBy":"system1","status":true,"ipTimeout":61}]}},
"PAGE":{"page":{"totalElements":30}}}
extjs 要求的返回值
更新:单个记录与总记录数量
删除:result response:......{"DATA":{},"PAGE":{"page":{"totalElements":2}}}
2016-07-13 参数数组查询使用in金勋查询; http://127.0.0.1:9006/form/rest/channel_auth/search/findByIdList?pkId=1&pkId=2 http://172.16.71.56:9006/form/rest/channel_auth/search/findByIdList?pkId=1&pkId=2
2016-07-08 ???fixme 只是filter 通过es-query,返回id-list,再通过rest-idlist 查询返回数据 ***idList 多个同名参数传递获得数组,可以使用hql 的in 语法进行查询; http://127.0.0.1:9006/form/rest/channel_auth/search/findByCodeList?code=test&code=abc
2016-07-07 rest-api 负责增删改; es 负责查询以及全文检索; spark-sql 负责大数据查询;
http://127.0.0.1:9006/form/rest/channel_auth/filter?_dc=1467884593669&sort=name%2CASC&sort=code%2CDESC&page=0&filter=%5B%7B%22type%22%3A%22string%22%2C%22value%22%3A%22test%22%2C%22field%22%3A%22name%22%7D%2C%7B%22type%22%3A%22string%22%2C%22value%22%3A%22test%22%2C%22field%22%3A%22code%22%7D%5D&start=0&size=23
_dc=1467884593669
sort=name,ASC
sort=code,DESC
page=0
filter=[{"type":"string","value":"test","field":"name"},
{"type":"string","value":"test","field":"code"}]
start=0
size=23
2016-07-06 转移到nginx-lua 项目 extjs filter 参数 _dc:1467776408383 sort:name,ASC sort:code,DESC page:0 filter:[{"type":"string","value":"12","field":"name"},{"type":"string","value":"abc1","field":"code"}] start:0 size:23
走extjs[get]->nginx-lua[post]->直接发送到 es;
{
"query": {
"bool": {
"must": {//必须符合以下条件
"term": {
"name": "test"
}
},
"should": {//满足其中某个条件
"term": {
"name": "test"
}
},
"must_not": {//不能符合以下条件
"term": {
"code": "test1"
}
}
}
},
"from": 0, //分页
"size": 1,
"sort": { //排序
"code": {
"order": "desc"
}
}
}
2016-06-20 todo: 基于extjs 的查询从spring-boot 的filter 移植到es;
2016-06-18 增加scala 编译环境 mvn spring-boot:run time curl -v http://127.0.0.1:9006/form/rest/helloscala
2016-05-28 此模块后续主要处理非实时的业务功能交互; 查询附近的司机\乘客网络约车等功能已经移植到GeoEngine 项目;
2016-05-25 mvn dependency:tree
指令采用json 格式传递,不采用POJO 序列化;
redis+lua 进行抢红包/秒杀/抢单的核心实现;
字符串解析成JavaBean:当数据量较少时首选FastJson,数据量较大使用Jackson。但是Jackson无法堆一个对象集合进行解析,只能转成一个Map集合,这点Gson和FastJson处理的比较好。
字符串解析成JSON:当数据量较少时首选FastJson,数据量较大使用Jackson。
JavaBean构造JSON:当数据量较少时选择Gson,数据量较大可使用Jackson。
集合构造JSON:首先Jackson,其次Fastjson。
todo 优化 com.fasterxml.jackson.core 的应用
2016-05-24 引入spring-redis 框架
匹配订单,向司机发送订单信息完成.
订单信息格式
o:流水号
> db.location.save( {_id: "18610586581", position: [0.1, -0.1]} )
> db.location.save( {_id: "18610586582", position: [1.0, 1.0]} )
> db.location.save( {_id: "18610586583", position: [0.5, 0.5]} )
> db.location.save( {_id: "18610586584", position: [-0.5, -0.5]} )
接着指定location索引
> db.location.ensureIndex( {position: "2d"} )
2016-05-23 先实现逻辑,快速开发; 然后迭代改造,加上nginx+mq;
通过单ip 访问频率,控制用户访问频率;
2016-05-18 http://127.0.0.1:9006/form/rest/webgeo/circle?x1=0.1&y1=0.1&bj=1 mongodb 加上验证;
todo:条件组合查询使用es 进行改造;
2016-05-16 ConnectionString uri = new ConnectionString("mongodb://user1:pwd1@host1/?authSource=db1");
geo LBS 服务圆圈查询
http://127.0.0.1:9006/form/rest/webgeo/circle?x1=0.0&y1=0.0&bj=0.7
http://127.0.0.1:9006/form/rest/webgeo/circle?x1=0.0&y1=0.0&bj=0.75
http://127.0.0.1:9006/form/rest/webgeo/near?x1=0.1&y1=0.1&bj=700
http://127.0.0.1:9006/form/rest/webgeo/near?x1=0.1&y1=0.1&bj=750
准备数据
首先定义一个位置集合,给定a,b,c,d节点.
> db.createCollection("location")
{ "ok" : 1 }
> db.location.save( {_id: "A", position: [0.1, -0.1]} )
> db.location.save( {_id: "B", position: [1.0, 1.0]} )
> db.location.save( {_id: "C", position: [0.5, 0.5]} )
> db.location.save( {_id: "D", position: [-0.5, -0.5]} )
接着指定location索引
db.location.ensureIndex( {position: "2d"} )
现在我们可以进行简单的GEO查询
查询point(0,0),半径0.7附近的点
> db.location.find( {position: { $near: [0,0], $maxDistance: 0.7 } } )
{ "_id" : "A", "position" : [ 0.1, -0.1 ] }
查询point(0,0),半径0.75附近的点
> db.location.find( {position: { $near: [0,0], $maxDistance: 0.75 } } )
{ "_id" : "A", "position" : [ 0.1, -0.1 ] }
{ "_id" : "C", "position" : [ 0.5, 0.5 ] }
{ "_id" : "D", "position" : [ -0.5, -0.5 ] }
我们可以看到半径不一样,查询出的点也不一样,因为c点坐标为[0.5,0.5],c至圆点的距离根据勾股定理可得出Math.sqrt(0.25 +0.25) ≈ 0.707,所以最大距离0.7时查找不到你要的点.
查询[0.25, 0.25], [1.0,1.0]区域附近的点
> db.location.find( {position: { $within: { $box: [ [0.25, 0.25], [1.0,1.0] ] } } } )
{ "_id" : "C", "position" : [ 0.5, 0.5 ] }
{ "_id" : "B", "position" : [ 1, 1 ] }
2016-05-12 插入mongodb 一条记录; curl -i -X POST -H "Content-Type:application/json" -d '{ "name" : "张三", "sex" : "男" }' http://127.0.0.1:9006/form/rest/customer curl -i -X POST -H "Content-Type:application/json" -d '{ "name" : "李四", "sex" : "男" }' http://127.0.0.1:9006/form/rest/customer curl http://127.0.0.1:9006/form/rest/customer/search/findByName?name=张三 curl http://127.0.0.1:9006/form/rest/customer/ curl -X PUT -H "Content-Type:application/json" -d '{ "name" : "张三", "sex" : "女" }' http://127.0.0.1:9006/form/rest/customer/573488b75b667641251bd32d curl -X PATCH -H "Content-Type:application/json" -d '{ "name": "李武" }' http://127.0.0.1:9006/form/rest/customer/573492bd5b66066a3abd38c1
2016-04-13
解决方案
@JsonFormat进行时区处理;处理完成送到数据库,处理完成送到 response; 前端根据显示需要显示所需的格式。
mysql -u app -p
mysql> set @@global.show_compatibility_56=ON;
实体类的get方法就需要多一个@JsonFormat的注解配置
@DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone = "GMT+8")
public Date getCreateTime() {
return this.createTime;
}
@DateTimeFormat(pattern="yyyy-MM-dd")
@JsonFormat(pattern="yyyy-MM-dd",timezone = "GMT+8")
public Date getBirthday() {
return this.birthday;
}
2016-03-30 获取Domain 元数据 http://127.0.0.1:9006/form/rest/webmetas?domainName=com.supermy.security.domain.User http://127.0.0.1:9006/form/rest/public/user.html
2016-03-23 RBAC进行角色权限管理 http://127.0.0.1:9006/form/rest/login http://127.0.0.1:9006/form/rest/admin http://127.0.0.1:9006/form/rest/hello
调整之后访问路径
http://127.0.0.1:9006/form/rest/public/channel.html
美化SQL 语句
hibernate.show_sql=true
hibernate.use_sql_comments=true
hibernate.format_sql=true
2016-03-17 方法授权访问: @PreAuthorize("hasRole('ROLE_ADMIN')") List findByFirstNameLike(@Param("firstName") String firstName);
2016-03-11 利用log4jdbc 采集日志已经落伍;现在使用flume 或者es进行日志采集. 配置中去掉log4jdbc相关
2016-03-02 升级到1.2.8版本,测试失败;原来更改的与ExtJs 无缝整合的方法需要重新调测.
2016-02-27 单点集成 cas-client-core 版本为3.3.1 ok 之前版本,导致打成的包不能运行; 集成方法详见Application filter and listener
application.properties 配置
server.context-path=/rest/api
nginx 配置
location /rest {
proxy_pass http://133.224.220.66:9000/rest;
}
2016-02-26 http://127.0.0.1:8080/webgits/role/dept/style2?uId=jamesmo 完成页面组件后台构造
2015-12-16 -------------------------------------------------------- -- DDL for Table USERS -------------------------------------------------------- CREATE TABLE "USERS" ( "USERNAME" VARCHAR2(45 CHAR), "ENABLED" NUMBER(1,0), "PASSWORD" VARCHAR2(60 CHAR) )
2015-07-04 docker 封装 spring-boot
mvn package spring-boot:repackage
生成的war 不能正常加载到 tomcat
cd /Users/moyong/project/env-myopensource/1-spring/12-spring/spring-mysql-data-rest/complete/target/gs-accessing-data-rest-0.1.0/WEB-INF/lib
zip -d spring-data-commons-1.9.2.RELEASE.jar org/springframework/data/domain/Pageable.class zip -d spring-data-commons-1.9.2.RELEASE.jar org/springframework/data/domain/PageRequest.class zip -d spring-data-jpa-1.7.2.RELEASE.jar org/springframework/data/jpa/repository/support/SimpleJpaRepository.class zip -d spring-data-rest-webmvc-2.2.2.RELEASE.jar org/springframework/data/rest/webmvc/AbstractRepositoryRestController.class
http://www.thetekblog.com/2014/03/upgrading-to-hibernate-4-3-4-final-nosuchmethod/
http://docs.spring.io/spring-boot/docs/current/reference/html/build-tool-plugins-maven-plugin.html
http://docs.spring.io/spring-boot/docs/current/reference/html/howto-database-initialization.html
spring-boot 按class生成时间进行加载没有解决
归纳来讲:是基于JVM sandbox(沙盒)安装模型上提供应用层的可定制的安全机制. Java虚拟机(JVM)寻找Class的顺序:
- Bootstrap classes 属于Java 平台核心的class,比如java.lang.String等.及rt.jar等重要的核心级别的class.这是由JVM Bootstrap class loader来载入的.一般是放置在{java_home}\jre\lib目录下;
- Extension classes 基于Java扩展机制,用来扩展Java核心功能模块.比如Java串口通讯模块comm.jar.一般放置在{Java_home}\jre\lib \ext目录下;
- User classes 开发人员或其他第三方开发的Java程序包.通过命令行的-classpath或-cp,或者通过设置CLASSPATH环境变量来引用.JVM通过放置 在{java_home}\lib\tools.jar来寻找和调用用户级的class.常用的javac也是通过调用tools.jar来寻找用户指定 的路径来编译Java源程序.这样就引出了User class路径搜索的顺序或优先级别的问题. 3.1 缺省值:调用Java或javawa的当前路径(.),是开发的class所存在的当前目录 3.2 CLASSPATH环境变量设置的路径.如果设置了CLASSPATH,则CLASSPATH的值会覆盖缺省值 3.3 执行Java的命令行-classpath或-cp的值,如果制定了这两个命令行参数之一,它的值会覆盖环境变量CLASSPATH的值 3.4 -jar 选项:如果通过java -jar 来运行一个可执行的jar包,这当前jar包会覆盖上面所有的值.换句话说,-jar 后面所跟的jar包的优先级别最高,如果指定了-jar选项,所有环境变量和命令行制定的搜索路径都将被忽略.JVM APPClassloader将只会以jar包为搜索范围. 有关可执行jar有许多相关的安全方面的描述,可以参考http://java.sun.com/docs/books/tutorial/jar/ 来全面了解. 这也是为什么应用程序打包成可执行的jar包后,不管你怎么设置classpath都不能引用到第三方jar包的东西了.
2015-06-30 common 中抽取的方案完成解耦;
2015-06-29
Extjs grid 的下拉选项与显示预处理完成
两个老问题圆满解决。
extjs grid filter 条件编辑面板在chrome 浏览器下失效的问题解决;
行编辑器保存按钮,在数据正确之后不能自动变回的问题解决。
修正日期 boolean 类型的过滤
2015-06-27 完成filter 编写,完成filterController编写,完成对 findAll 过滤查询调试; http://127.0.0.1:8080/filter/channel/?_dc=1435308762365&sort=name%2CASC&sort=code%2CDESC&page=0&filter=%5B%7B%22type%22%3A%22numeric%22%2C%22comparison%22%3A%22lt%22%2C%22value%22%3A6%2C%22field%22%3A%22id%22%7D%2C%7B%22type%22%3A%22numeric%22%2C%22comparison%22%3A%22gt%22%2C%22value%22%3A2%2C%22field%22%3A%22id%22%7D%2C%7B%22type%22%3A%22string%22%2C%22value%22%3A%2212%22%2C%22field%22%3A%22code%22%7D%2C%7B%22type%22%3A%22boolean%22%2C%22value%22%3Atrue%2C%22field%22%3A%22status%22%7D%2C%7B%22type%22%3A%22date%22%2C%22comparison%22%3A%22lt%22%2C%22value%22%3A11122222%2C%22field%22%3A%22createDate%22%7D%5D&start=0&size=10 todo:filger 与 extjs rest 整合
内部整合 todo?
http://127.0.0.1:8080/channel_auth/filter/?_dc=1435308762365&sort=name%2CASC&sort=code%2CDESC&page=0&filter=%5B%7B%22type%22%3A%22numeric%22%2C%22comparison%22%3A%22lt%22%2C%22value%22%3A6%2C%22field%22%3A%22id%22%7D%2C%7B%22type%22%3A%22numeric%22%2C%22comparison%22%3A%22gt%22%2C%22value%22%3A2%2C%22field%22%3A%22id%22%7D%2C%7B%22type%22%3A%22string%22%2C%22value%22%3A%2212%22%2C%22field%22%3A%22code%22%7D%2C%7B%22type%22%3A%22boolean%22%2C%22value%22%3Atrue%2C%22field%22%3A%22status%22%7D%2C%7B%22type%22%3A%22date%22%2C%22comparison%22%3A%22lt%22%2C%22value%22%3A11212212%2C%22field%22%3A%22createDate%22%7D%5D&start=0&size=10
Pageable and PageRequest 增加参数 MyFilter;
SimpleJpaRepository 增加filter 参数处理判断;
增加MyRepositoryEntityController,增加/{repository}/filter入口
todo:
lua template 简化消费者的前端使用。
2015-06-25 spring-data-rest 排序查询 http://127.0.0.1:8080/channel_auth?page=1&size=10&sort=name,desc&sort=code,asc
//废除
AbstractPageRequest1
public int getOffset() {//fixme jamesmo 2016-06-23 解决page=1传递进来,其实计算错误的问题。
return (page-1) * size;
}
filter test url
http://127.0.0.1:8080/channel_auth/filter/?_dc=1435308762365&sort=name%2CASC&sort=code%2CDESC&page=0&filter=%5B%7B%22type%22%3A%22numeric%22%2C%22comparison%22%3A%22lt%22%2C%22value%22%3A6%2C%22field%22%3A%22pkId%22%7D%2C%7B%22type%22%3A%22numeric%22%2C%22comparison%22%3A%22gt%22%2C%22value%22%3A2%2C%22field%22%3A%22pkId%22%7D%2C%7B%22type%22%3A%22string%22%2C%22value%22%3A%2212%22%2C%22field%22%3A%22code%22%7D%2C%7B%22type%22%3A%22boolean%22%2C%22value%22%3Atrue%2C%22field%22%3A%22status%22%7D%2C%7B%22type%22%3A%22date%22%2C%22comparison%22%3A%22lt%22%2C%22value%22%3A%2206%2F26%2F2015%22%2C%22field%22%3A%22createDate%22%7D%5D&start=0&size=10
2015-06-24 完成后端返回值的规范处理,processReponse 完成用户操作之后的提示信息,afterRequest 完成Controler级别变量定义,总记录数,total 完成form 方式编辑与新增 todo remote filter
2015-06-23 后端类型定义死了,不好更改返回值; 从前端更改。
2015-06-22
curl -i -X PUT -H "Content-Type:application/json"
-d '{"pkId": 1, "name": "test1", "code": "test", "pwd": "test", "tokenExpire": "1", "iplist": "192.168.59.103"}'
http://127.0.0.1:8080/channel_auth/1
2015-06-19 能否成功与extends ResourceSupport和权限系统都关系,都去掉即可。
curl -i -X POST -H "Content-Type:application/json" -d '{ "firstName" : "Frodo", "lastName" : "Baggins" }' http://localhost:8080/people curl -X PUT -H "Content-Type:application/json" -d '{ "firstName": "Bilbo", "lastName": "Baggins" }' http://localhost:8080/people/1 curl http://localhost:8080/people/1 curl -X DELETE http://localhost:8080/people/1
2015-06-17 hibernate 生成数据库 spring data.sql 完成数据的导入 rest 生产者与消费者的概念; 生产者:spring-data-rest 消费者:thymeleaf+[lua-resty-template extjs bootstrap]
Thymeleaf是一个XML/XHTML/HTML5模板引擎,可用于Web与非Web环境中的应用开发
Thymeleaf提供了一个用于整合Spring MVC的可选模块,在应用开发中,你可以使用Thymeleaf来完全代替JSP,或其他模板引擎,如Velocity、
FreeMarker等。Thymeleaf的主要目标在于提供一种可被浏览器正确显示的、格式良好的模板创建方式,因此也可以用作静态建模。你可以使用它
创建经过验证的XML与HTML模板。相对于编写逻辑或代码,开发者只需将标签属性添加到模板中即可。接下来,这些标签属性就会在DOM(文档对象
模型)上执行预先制定好的逻辑。
# 代表 获取对象 从 messages bundle 也就是消息的资源本地化文件
$ 表示从model里面获取
# $这2个可以一起用 比如#{'system.'+${model.id}} -----这相当于 #{system.01}的资源本地化文件中的system.01内容
表达式基本对象:
#ctx:context object
#root或者#vars
#locale
#httpServletRequest
#httpSession
表达式功能对象:
#dates:java.util.Date的功能方法类。
#calendars:类似#dates,面向java.util.Calendar
#numbers:格式化数字的功能方法类。
#strings:字符串对象的功能类,contains,startWiths,prepending/appending等等。
#objects:对objects的功能类操作。
#bools:对布尔值求值的功能方法。
#arrays:对数组的功能类方法。
#lists:对lists功能类方法
#sets
#maps
#aggregates:对数组或者集合创建聚合的功能方法,
th:text="${#aggregates.sum(o.orderLines.{purchasePrice * amount})}"
#messages:在变量表达式中获取外部信息的功能类方法。
#ids:处理可能重复的id属性的功能类方法。
<table>
<thead>
<tr>
<th th:text="#{msgs.headers.name}">Name</th>
<th th:text="#{msgs.headers.price}">Price</th>
</tr>
</thead>
<tbody>
<tr th:each="prod : ${allProducts}">
<td th:text="${prod.name}">Oranges</td>
<td th:text="${#numbers.formatDecimal(prod.price,1,2)}">0.99</td>
</tr>
</tbody>
</table>
2015-06-05 最新的rest框架技术,注解无xml 配置
http://127.0.0.1:8080/people/
http://127.0.0.1:8080/people/1
http://127.0.0.1:8080/people/?page=1&size=2&sort=firstName
http://127.0.0.1:8080/people/?page=1&size=2&sort=firstName,asc
http://127.0.0.1:8080/people/search
http://127.0.0.1:8080/people/search/findByLastName?name=客气
http://127.0.0.1:8080/people/search/findByFirstNameLike?firstName=实施跟踪12% --通配符号需要转码
http://127.0.0.1:8080/people/search/findByEmailAddress?lname=施跟踪2
http://127.0.0.1:8080/people/search/findByName?name1=跟踪12&name2=气
java -jar target/gs-accessing-data-rest-0.1.0.jar
2015-05-06 http://127.0.0.1:8080/login http://127.0.0.1:8080/hello http://127.0.0.1:8080/admin
2015-01-09 安全框架:类的注解生效失效 JdbcSecurityConfig 便于固有系统的集成,整合原有的用户权限表; UserSecurityConfig 便于新系统的建立,自动建立数据表。
before ...... Test Spring MVC REST application based on mysql
测试 ok mvn spring-boot:run
todo:
rest excetion 信息控制