EWeb4J 1.9.1 新版本发布 基于Servlet/JDBC的轻量级web开发框架
程序员文章站
2022-06-08 12:48:00
...
EWeb4J 是一个基于 Servlet/Jdbc 构建的轻量级 Java Web 开发框架。它可以代替 SSH 来开发一个完整的 Web 应用程序。它专注于 少侵入、少配置、松耦合架构风格的 Web 应用程序开发。EWeb4J 的目标是让 Java Web 开发更加简单。
本版本更新是一个里程碑版本。
本次更新内容主要有:
bug 修复:
IOC模块,修复POJO依赖了另外POJO导致的注入失败问题。
IOC模块 当使用构造器方法注入依赖时,必须要提供一个无参构造器方法进行初始化,否则会报错。修复为无需提供无参构造器方法
新功能:
新增 Models 帮助类,以支持类似 ActiveRecord style 的数据库操作。
DAO接口增加join、alaias、ennableExpress、getPage等方法。随之带来的新功能是:多表连接查询、新的更加强大的分页功能
为ORM模块增加ddl配置功能,通过ddl可以配置框架启动的时候创建SQL脚本和运行SQL脚本,常用到建表。
MVC增加对Velocity模板的支持
增加 FTPUtil 和 ThumbUtil两个实用工具类,后者支持远程、本地图片的处理,包括等比压缩、中心裁剪、亮度/对比度调节、锐化调节等。
重构ORM的表关系相关的级联接口,使其支持更多的JPA注解,包括@OrderBy、@MappedBy、 还有fetchType
ORM模块实体类不用必须提供@Id属性,以支持查询视图。
增加对JPA @JoinColumn(referenceColumnName)的支持,使得表关系的外键可以映射到非ID字段。
改善:
MVC增加对上传文件的验证配置。只要在上传处理方法添加@Upload注解,可以填写限制的后缀名、文件大小等参数。
增强了各个模块对ClassPath的扫描功能,包括扫描Maven依赖库
改善了对JAR包的扫描,上一版本是暴力扫描所有JAR文件,这一版本改为增加扫描JAR文件的配置,通过不同的配置来扫描不同的JAR文件,以下为例子:
将ORM模块所有对List接口的依赖改成Collection接口
修改生成SQL脚本实体字段的nullable默认设置,由原来的not null改成 null
修改级联接口的 merge方法为fetch
如何获取?
项目主页Clone下来自己跑:https://github.com/laiweiwei/eweb4j-framework
下载下来:https://github.com/laiweiwei/eweb4j-framework/downloads
Maven依赖:
可以参考基于EWeb4J开发的其他项目:
Java网络爬虫Spiderman https://github.com/laiweiwei/spiderman
SolidBase https://github.com/laiweiwei/eweb4j-solidbase
SolidBase Webapp https://github.com/laiweiwei/solidbase-webapp
SolidBase在线演示 http://210.38.137.96/solidbase/users/login
SolidBase最新版本还在开发中,现在谷歌Code的还是上一版本的,想要获取最新开发版本可以到Github里面获取,已经同步到1.9.1了。
本版本更新是一个里程碑版本。
本次更新内容主要有:
bug 修复:
新功能:
//使用 Pet p = new Pet("xiaohei", 5); Models.inst(p).create();//insert Models.inst(p).save();//当没有ID值的时候是insert p.setId(2); Models.inst(p).load();//这个时候会通过id值去查询数据库,并将数据注入到pet实例中。 Models.inst(p).delete();//通过id值删除 List<Pet> pets = Models.inst(Pet.class).findAll(); // 分页 List<Pet> page = Models.inst(Pet.class).find().fetch(10); page = Models.inst(Pet.class).find().fetch(2, 5); // 条件查询 List<Pet> pets = Models.inst(Pet.class).find("byName", "xiaohei").fetch(); pets = Models.inst(Pet.class).find("byNameAndAge", "xiaohei", 5).fietch(); pets = Models.inst(Pet.class).find("name = ?", "xiaohei").fetch(); Pet p = Models.inst(Pet.class).find("name = ?", "xiaohei").first(); p = Models.inst(Pet.class).findById(3L); p = Models.inst(Pet.class).find("byNameAndAge", "xiaohei", 5).first(); // 删除 Models.inst(Pet.class).delete("byName", "xiaohei"); Models.inst(Pet.class).deleteAll(); // 行数 long rows = Models.inst(Pet.class).count();/* select count(*) */ rows = Models.inst(Pet.class).count("byName", "xiaohei");/* count(*) ... where name='xoapjeo' */
Page<User> page = DAOFactory.getDAO(User.class) .alias("u") .join("role", "r") .selectAll() .where() .field("u.name").like(name) .enableExpress(true)//开启表达式 .and("r.id").equal("u.role")// 相当于join xxx on xxx = xxx .getPage(p, n); Collection<User> users = page.getList(); int page = page.getPageIndex(); int pageCount = page.getTotalPageCount(); int allCount = page.getTotalRowCount(); Page<User> nextPage = page.next(); Page<User> prevPage = page.prev();
<ddl generate="true" run="true" ds="myDBInfo"/>
改善:
<scanPojoPackage> <path>JAR:apache*</path><!--扫描命名以apache开头的JAR包--> </scanPojoPackage>
如何获取?
<dependency> <groupId>org.eweb4j</groupId> <artifactId>eweb4j-all</artifactId> <version>1.9.1</version> </dependency>
可以参考基于EWeb4J开发的其他项目:
SolidBase最新版本还在开发中,现在谷歌Code的还是上一版本的,想要获取最新开发版本可以到Github里面获取,已经同步到1.9.1了。