Skip to content

基于 spring-boot的rest 风格的基础框架,整合 mysql,oracle,redis,mongodb,scala,extjs-filter,rbac 角色权限,sso,

Notifications You must be signed in to change notification settings

supermy/rest-api

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MobileApp

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的顺序:

  1. Bootstrap classes 属于Java 平台核心的class,比如java.lang.String等.及rt.jar等重要的核心级别的class.这是由JVM Bootstrap class loader来载入的.一般是放置在{java_home}\jre\lib目录下;
  2. Extension classes 基于Java扩展机制,用来扩展Java核心功能模块.比如Java串口通讯模块comm.jar.一般放置在{Java_home}\jre\lib \ext目录下;
  3. 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 信息控制

About

基于 spring-boot的rest 风格的基础框架,整合 mysql,oracle,redis,mongodb,scala,extjs-filter,rbac 角色权限,sso,

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published