在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
开源软件名称:SoJpt Boot开源软件地址:https://gitee.com/sohnny/SoJpt-Boot开源软件介绍:SoJpt Boot介绍官方网站: www.sojpt.com在Spring Boot框架下使用Jfinal特性极速开发 spring boot 为主, jfinal 为辅的混合双打模式, 既可以享受spring 的生态,又可以体验jfinal的极速开发. 可以在Spring Boot中向使用Jfinal一样使用Enjoy, Aop, controller的一系列方法(如: getFile(), renderFile....),以及ActiveRecord, 只有Jfinal的路由被去掉,其他Jfinal特性可以原生使用 SoJpt-Boot-2.5.8-4.8 changelog 1.升级为JFinal4.8 SoJpt-Boot-2.5.8-4.7 changelog 1.升级为JFinal4.7 SoJpt-Boot-2.5.8-4.3 changelog 1.升级为JFinal4.32.修复请求不能异步执行的问题 SoJpt-Boot-2.5.7-4.2 changelog 1.修复上传文件时不能传其它参数的bug2.改善接收参数必须在接收文件后的问题, 不在有先后顺序的要求,避免新手入坑 SoJpt-Boot-2.5.6-4.2 changelog 1.升级为JFinal4.2 https://www.jfinal.com/ SoJpt-Boot-2.5.8-3.8 changelog 1..修复请求不能异步执行的问题 SoJpt-Boot-2.5.6-3.8 changelog 1.修复controller return 返回null问题 SoJpt-Boot-2.5.5-3.8 changelog 1、可以省去spring boot配置文件 (项目不需要的情况)2、进一步优化,减少metaspace开销3、兼容yml文件的配置 SoJpt-Boot-2.5.4-3.8 changelog 1、提升Controller并发处理性能 SoJpt-Boot-2.5.3-3.8 changelog 1、解决spring cloud 环境下报 UT010005: Cannot call getOutputStream(), getWriter()2、加入路径容错, 3、修复上传文件报异常的bug4、JsonRender.exclude方法优化renderJson报异常解决方案 SoJpt-Boot-2.3-3.8 changelog 1.加入事务注解,@Tx(value="configName", level=2), 可在servcie层及其他任何地方使用 value 数据源名称 ,默认为当前数据源 level 数据库事务等级配置, 默认为ActiveRecord配置的事务等级2.优化代码,可使用 sojpt-boot-spring-boot-starter 自动配置 <dependency> <groupId>com.gitee.sohnny</groupId> <artifactId>sojpt-boot-spring-boot-starter</artifactId> <version>2.3.2-3.8</version> </dependency>3、同时发布官方最佳实践 SoJpt-Boot-Staging-mysql-v1.14、解决上个版本在内置tomcat环境系下不能启动的问题 SoJpt-Boot-2.2-3.8 changelog 1.修复 jfinal handler 配置失效问题, 发布2.2-3.8, 建议升级新版 SoJpt-Boot-2.1-3.8 changelog 1.修复 配置 server.servlet.context-path 时配置报空指针的异常。2.修复 使用Validator时 不能返回请求的bug SoJpt-Boot-2.0-3.8 changelog
软件架构基于 JFinal 与 Spring Boot制作, 实现Spring Boot与Jfinal的混合双打,使Spring Boot下的开发者能够体验Jfinal的极速开发特性,有更多的时间去配恋人或家人。 安装教程
<dependency> <groupId>com.gitee.sohnny</groupId> <artifactId>sojpt-boot-spring-boot-starter</artifactId> <version>2.5.8-4.8</version> </dependency>
package com.sojpt.boot;import java.sql.Connection;import javax.servlet.ServletException;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.context.properties.EnableConfigurationProperties;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import com.alibaba.druid.filter.stat.StatFilter;import com.alibaba.druid.wall.WallFilter;import com.jfinal.config.Constants;import com.jfinal.config.Handlers;import com.jfinal.config.Interceptors;import com.jfinal.config.Plugins;import com.jfinal.core.JFinal;import com.jfinal.plugin.activerecord.ActiveRecordPlugin;import com.jfinal.plugin.activerecord.dialect.MysqlDialect;import com.jfinal.plugin.druid.DruidPlugin;import com.jfinal.template.Engine;import com.jfinal.template.ext.spring.JFinalViewResolver;import com.jfinal.template.source.ClassPathSourceFactory;import com.sojpt.model._MappingKit;@Configuration(value = "SoJptBootConfig")@EnableConfigurationProperties(ActiveRecordPluginProperties.class)public class SoJptBootConfig extends SoJptConfig { @Autowired private ActiveRecordPluginProperties arpProperties; /** * 配置JFinal常量 */ @Override public void configConstant(Constants me) { // 设置当前是否为开发模式 me.setDevMode(arpProperties.getIsDevMode()); // me.setError404View("/index.html"); } /** * 配置JFinal插件 数据库连接池 ORM 缓存等插件 自定义插件 */ @Override public void configPlugin(Plugins me) { DruidPlugin dp = new DruidPlugin(arpProperties.getJdbcUrl(), arpProperties.getUsername(), arpProperties.getPassword()); dp.addFilter(new StatFilter()); dp.setDriverClass("com.mysql.cj.jdbc.Driver"); WallFilter wall = new WallFilter(); dp.addFilter(wall); me.add(dp); ActiveRecordPlugin arp = new ActiveRecordPlugin(dp); arp.setTransactionLevel(Connection.TRANSACTION_READ_COMMITTED); arp.setShowSql(arpProperties.getIsDevMode()); arp.setDialect(new MysqlDialect()); // ******** 在此添加dao层sql文件 *********//* //arp.addSqlTemplate("sql/all_sqls.sql"); _MappingKit.mapping(arp); // 初始化任务调度插件,参数为配置文件名 // me.add(new Cron4jPlugin(sysProp)); me.add(arp); } /** * 配置全局拦截器 */ @Override public void configInterceptor(Interceptors me) { // me.addGlobalActionInterceptor(new DuplicateLoginInterceptor()); } /** * 配置全局处理器 */ @Override public void configHandler(Handlers me) { // druid 统计页面功能 //me.add(DruidKit.getDruidStatViewHandler()); //me.add(new JavaMelodyHandler("/monitoring.*", true)); } @Override public void beforeJFinalStop() { } /** * * 配置模板引擎 */ @Override public void configEngine(Engine me) { // 这里只有选择JFinal TPL的时候才用 me.addSharedObject("RESOURCE_HOST", JFinal.me().getContextPath()); me.addSharedObject("WEB_HOST", JFinal.me().getContextPath()); // 配置共享函数模板 // me.addSharedFunction("/view/common/layout.html") } @Override public void afterJFinalStart() { System.err.println("SoJpt Boot 启动成功!"); } /** * * 此内部类可选, (默认不建议开启,注释掉即可) * 其作用就是在SpringBoot中可以直接 return"/view/index.html", * 如果习惯render("/view/index.html")用法,可注释此方法 * * @return * @throws ServletException */ @Bean(name = "jfinalViewResolver") public JFinalViewResolver getJFinalViewResolver() throws ServletException { JFinalViewResolver jfr = new JFinalViewResolver(); // setDevMode 配置放在最前面 jfr.setDevMode(true); // 使用 ClassPathSourceFactory 从 class path 与 jar 包中加载模板文件 jfr.setSourceFactory(new ClassPathSourceFactory()); jfr.setSuffix(".html"); jfr.setContentType("text/html;charset=UTF-8"); jfr.setOrder(0); // jfr.addSharedFunction("/view/common/_layout.html"); // jfr.addSharedFunction("/view/common/_paginate.html"); // init("com.sojpt.boot.MainConfig"); return jfr; }}
arp.jdbc-url = jdbc:mysql://127.0.0.1/sojpt?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=falsearp.username = rootarp.password = 123456arp.is-dev-mode= true
@ComponentScan("com.sojpt") //添加你定义的SoJptBootConfig类所在的包名称@SpringBootApplicationpublic class SoJptSpringbootApplication { public static void main(String[] args) { SpringApplication.run(SoJptSpringbootApplication.class, args); }} 使用说明
@RestControllerpublic class HelloController extends Controller { //不继承Controller,就是原生的Spring Boot,Jfinal的Aop也就不能用 @Before(Tx.class) //事务的用法 @RequestMapping("/list/jfinal") public void index() { System.out.println(getPara("id")); //获取参数示例 SqlPara sqlPara = Db.getSqlPara("admin_log.select"); Page<Record> page = Db.paginate(1, 10, sqlPara); renderJson(page); } }
@RestControllerpublic class HelloPageController extends Controller { @Clear @RequestMapping("/file") public void index() { setAttr("msg", "123123"); renderFile(new File("d://test.txt")); } }
@Controllerpublic class HelloPageController extends Controller { @Before(LoginInterceptor.class) //方法级拦截器 @RequestMapping("/page/jfinal") public void index() { setAttr("msg", "123123"); render("/view/index.html") //放在resources目录下 } } 参与贡献www.sojpt.com |
请发表评论