手动注入参数到实体类的实现

Enumeration<String> parameterNames = request.getParameterNames(); //获取name集合
while(parameterNames.hasMoreElements()){
String element = parameterNames.nextElement();  //获得单个name
String methodName = element.replaceFirst(element.substring(0, 1), element.substring(0, 1).toUpperCase());//根据name拿方法名
Field field = user.getClass().getDeclaredField(element);//获取属性
Class type = field.getType();//获取转换类型
String typename = field.getType().getName();//获取转换类型
Method method = user.getClass().getMethod("set"+methodName,type);//根据方法名拿方法,需要注入方法参数列表
if(!"java.lang.String".equals(typename)){ //非字符串就转换
	Constructor constructor = type.getConstructor(String.class);
	Object value = constructor.newInstance(request.getParameter(element));
		method.invoke(user, value);
	}
	else{
		method.invoke(user, request.getParameter(element));
	}
}


以上用到了反射的一些特性,该方法将request中的参数,注入到user实体类中。

不过如果框架一般也有现成的实现方式,也是基于反射的方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用MyBatis Plus来实现根据Java实体类自动生成数据库表和Mapper等代码。以下是一个简单的示例: 1. 首先需要在Maven或Gradle的配置文件中添加MyBatis Plus依赖: Maven: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus</artifactId> <version>3.4.3.1</version> </dependency> ``` Gradle: ```groovy dependencies { implementation 'com.baomidou:mybatis-plus:3.4.3.1' } ``` 2. 创建一个Java实体类,例如: ```java public class User { private Long id; private String name; private Integer age; // getter and setter } ``` 3. 创建一个Mapper接口,例如: ```java public interface UserMapper extends BaseMapper<User> { } ``` 这里使用了MyBatis Plus提供的BaseMapper接口,它已经提供了一些常用的CRUD操作方法,不需要手动编写SQL语句。 4. 在配置文件中配置数据源和MyBatis Plus相关参数,例如: ```properties spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=root # MyBatis Plus mybatis-plus.mapper-locations=classpath:mapper/*.xml mybatis-plus.type-aliases-package=com.example.entity mybatis-plus.global-config.db-config.id-type=auto ``` 这里使用了Spring Boot的配置方式,数据源的相关参数需要根据实际情况进行修改。mapper-locations属性指定Mapper文件所在位置,type-aliases-package属性指定实体类所在包名,global-config.db-config.id-type属性指定主键生成策略。 5. 启动应用程序,MyBatis Plus会自动根据实体类User生成对应的数据库表和Mapper接口实现类。 ```java @SpringBootApplication public class MyApplication { public static void main(String[] args) { SpringApplication.run(MyApplication.class, args); } } ``` 6. 在代码中使用Mapper接口进行数据操作,例如: ```java @RestController public class UserController { @Autowired private UserMapper userMapper; @GetMapping("/users") public List<User> getUsers() { return userMapper.selectList(null); } @PostMapping("/users") public User addUser(@RequestBody User user) { userMapper.insert(user); return user; } } ``` 这里使用了Spring MVC的注解来定义RESTful API,使用了@Autowired注解将UserMapper自动注入到控制器中,使用了selectList和insert方法进行数据操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值