Nutz 是一个基于 Java 语言的开源框架,主要用于快速开发企业级应用程序。它提供了一系列简洁易用的工具和组件,能够帮助开发者高效地完成项目开发工作。以下是 Nutz 框架的一些简洁特点:
轻量级框架: Nutz 是一个轻量级的框架,核心代码简洁明了,不依赖于复杂的第三方库,易于理解和学习。
依赖注入和AOP支持: Nutz 框架提供了依赖注入(DI)和面向切面编程(AOP)的支持,能够帮助开发者实现松耦合的组件之间的依赖关系,并实现横切关注点的统一处理。
ORM框架: Nutz 提供了强大的 ORM(对象关系映射)框架,能够帮助开发者轻松地操作数据库,支持多种数据库,包括 MySQL、Oracle、PostgreSQL 等。
模块化设计: Nutz 框架采用了模块化的设计理念,将各种功能和组件进行了模块化划分,开发者可以根据项目需求选择合适的模块进行使用,提高了框架的灵活性和可扩展性。
丰富的工具集: Nutz 框架提供了丰富的工具集,包括各种常用的工具类、模板引擎、缓存框架等,能够帮助开发者快速构建各种应用程序。
良好的文档和社区支持: Nutz 框架有着完善的官方文档和活跃的社区支持,开发者可以通过阅读文档和参与社区讨论,快速解决问题并获取技术支持。
总的来说,Nutz 框架以其简洁、轻量、灵活的特点,成为了许多 Java 开发者的首选框架之一,能够帮助他们快速、高效地开发各种类型的企业级应用程序。
<!--Nutz-->
<dependency>
<groupId>org.nutz</groupId>
<artifactId>nutz-plugins-spring-boot-starter</artifactId>
<version>1.r.68.v20201205</version>
</dependency>
<!--beetl-->
<dependency>
<groupId>com.ibeetl</groupId>
<artifactId>beetl</artifactId>
<version>3.10.0.RELEASE</version>
</dependency>
以上配置也要加入到启动类工程。
nutz:
json:
# 是否启用,默认true
enabled: false
# json模式,默认compact
mode: compact
# 是否启用压缩模式
compact: true
# 是否自动将值应用unicode编码
auto-unicode: false
# 日期格式化
date-format: yyyy-MM-dd HH:mm:ss
dao:
runtime:
# 自动创建表
create: false
# 根据bean自动更新表结构
migration: false
# 是否添加列 默认true
add-column: false
# 是否删除列 默认true
delete-column: false
# 是否删表重建,注意此功能会删除全部表及数据,一般应用于demo或测试 默认false
foce-create: false
# 是否检查索引 默认true
check-index: false
# 扫描bean
basepackage:
- com.ruoyi.domain
sql-manager:
#自定义sql管理模式 file和xml
mode: file
# sql文件存放位置
paths:
- sqls
sql-template:
#是否启用 默认false
enable: true
#模板引擎类型,默认beetl
type: beetl
指定编译版本
JDK一定要1.8,不指定的话启动会报如下错误
15:40:19.283 [restartedMain] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dao' defined in class path resource [org/nutz/plugin/spring/boot/NutzDaoAutoConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.nutz.dao.Dao]: Factory method 'dao' threw exception; nested exception is java.lang.ExceptionInInitializerError
at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:658)
at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:638)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1352)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1195)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542)
at org.springframework.beans.factory.support.AbstractBeanFactory.lambdadoGetBean0(AbstractBeanFactory.java:335)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:955)
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:920)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583)
at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145)
at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780)
at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453)
at org.springframework.boot.SpringApplication.run(SpringApplication.java:343)
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370)
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359)
at com.RuoYiApplication.main(RuoYiApplication.java:17)
at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104)
at java.base/java.lang.reflect.Method.invoke(Method.java:578)
at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49)
Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.nutz.dao.Dao]: Factory method 'dao' threw exception; nested exception is java.lang.ExceptionInInitializerError
at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185)
at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:653)
... 22 common frames omitted
Caused by: java.lang.ExceptionInInitializerError: null
at org.nutz.json.entity.JsonEntityField.setGenericType(JsonEntityField.java:211)
at org.nutz.json.entity.JsonEntityField.eval(JsonEntityField.java:113)
at org.nutz.json.impl.JsonEntityFieldMakerImpl.make(JsonEntityFieldMakerImpl.java:25)
at org.nutz.json.AbstractJsonEntityFieldMaker.make(AbstractJsonEntityFieldMaker.java:18)
at org.nutz.json.entity.JsonEntity.<init>(JsonEntity.java:59)
at org.nutz.json.Json.getEntity(Json.java:319)
at org.nutz.mapl.impl.convert.ObjConvertImpl.injectObj(ObjConvertImpl.java:210)
at org.nutz.mapl.impl.convert.ObjConvertImpl.inject(ObjConvertImpl.java:91)
at org.nutz.mapl.impl.convert.ObjConvertImpl.convert(ObjConvertImpl.java:72)
at org.nutz.mapl.Mapl.maplistToObj(Mapl.java:34)
at org.nutz.json.Json.parse(Json.java:94)
at org.nutz.json.Json.fromJson(Json.java:73)
at org.nutz.dao.jdbc.Jdbcs.<clinit>(Jdbcs.java:73)
at org.nutz.dao.impl.DaoSupport.setDataSource(DaoSupport.java:189)
at org.nutz.dao.impl.DaoSupport.setDataSource(DaoSupport.java:180)
at org.nutz.dao.impl.NutDao.<init>(NutDao.java:108)
at org.nutz.dao.impl.NutDao.<init>(NutDao.java:112)
at org.nutz.plugin.spring.boot.NutzDaoAutoConfiguration.dao(NutzDaoAutoConfiguration.java:37)
at org.nutz.plugin.spring.boot.NutzDaoAutoConfigurationEnhancerBySpringCGLIBa60af6bb.CGLIBdao2(<generated>)
at org.nutz.plugin.spring.boot.NutzDaoAutoConfigurationEnhancerBySpringCGLIBa60af6bbFastClassBySpringCGLIBc5d4798e.invoke(<generated>)
at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244)
at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331)
at org.nutz.plugin.spring.boot.NutzDaoAutoConfigurationEnhancerBySpringCGLIBa60af6bb.dao(<generated>)
at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104)
at java.base/java.lang.reflect.Method.invoke(Method.java:578)
at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154)
... 23 common frames omitted
Caused by: java.lang.reflect.InaccessibleObjectException: Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @528df37f
at java.base/java.lang.reflect.AccessibleObject.throwInaccessibleObjectException(AccessibleObject.java:387)
at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:363)
at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:311)
at java.base/java.lang.reflect.Method.checkCanSetAccessible(Method.java:201)
at java.base/java.lang.reflect.Method.setAccessible(Method.java:195)
at org.nutz.lang.reflect.ReflectTool$1.run(ReflectTool.java:37)
at java.base/java.security.AccessController.doPrivileged(AccessController.java:319)
at org.nutz.lang.reflect.ReflectTool.<clinit>(ReflectTool.java:24)
... 49 common frames omitted
启动测试
能正常启动说明工程依赖已正常依赖。
package com.ruoyi.controller;
import com.ruoyi.common.core.domain.R;
import com.ruoyi.domain.Person;
import org.nutz.dao.Cnd;
import org.nutz.dao.Dao;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
@RequestMapping("/api/v1/person")
public class PersonController {
@Autowired
private Dao dao;
/**
* 添加person
*
* @return
*/
@GetMapping("/add")
public R<Person> add() {
Person p = new Person();
p.setName("ABC");
p.setAge(20);
Person insert = dao.insert(p);
return R.ok(insert);
}
/**
* 获取person列表
*
* @return
*/
@GetMapping("/list")
public R<List<Person>> list() {
List<Person> query = dao.query(Person.class, Cnd.NEW());
return R.ok(query);
}
/**
* 修改person
*
* @return
*/
@GetMapping("/update")
public R<Object> update(Person person) {
int update = dao.update(person);
return R.ok(update);
}
/**
* 删除person
*
* @return
*/
@GetMapping("/delete")
public R<Object> delete(Person person) {
int update = dao.delete(person);
return R.ok(update);
}
}
powered by kaifamiao