记录一次反射的使用,第一次真正运用到实际工作中,发现反射是真的强大!
写了一个通用类,主要是便于和 db 的交互操作,使用到了泛型 T 对象,但是有一步需要获取该对象的属性 id 值(前提是所有赋值给 T 对象的对象自己都有一个相同类型的 id),再做一点逻辑处理,如果是具体对象来调用这个泛型,则可以正常 getId() 得到该对象的属性值,但是对于如果是泛型方法里面要通过 T 这个泛型对象来 getId() 出 id 的值,正常是无法获取到的,解决方法有两种:
(1)给 T 对象继承一个统一的父类,在父类里面定义一个 id 属性,这样 T 对象就可以点出 id 的属性值了
(2)通过反射的方式来获取 id 的属性值
这里主要介绍第二种:
public Integer getId(T t){
try{
Class<? extends Object> tClass = t.getClass();
//得到所有属性
Field[] field = tClass.getDeclaredFields();
/**
* 这里只需要 id 这个属性,所以直接取 field[0] 这
* 一个,如果id不是排在第一位,自己取相应的位置,
* 如果有需要,可以写成for循环,遍历全部属性
*/
//设置可以访问私有变量
field[0].setAccessible(true);
//获取属性的名字
String name = field[0].getName();
//将属性名字的首字母大写
name = name.replaceFirst(name.substring(0, 1), name.substring(0, 1).toUpperCase());
//整合出 getId() 属性这个方法
Method m = tClass.getMethod("get"+name);
//调用这个整合出来的get方法,强转成自己需要的类型
Integer id = (Integer)m.invoke(t);
//成功通过 T 泛型对象取到具体对象的 id !
return id;
}catch(Exception e){
log.info("没有这个属性");
return null;
}
}
如果需要获取所有的属性,并且想写的更灵活,可以再获取一个属性的类型,然后写一个 for 循环,在 for 循环里面对每个属性再写一些 if 判断,对应是什么类型,自己强转成对应的类型:
for(int i=0;i<field.length;i++){
// 获取属性类型
String type = field[i].getGenericType().toString();
if(type.equals("class java.lang.String")){
String value = (String)m.invoke(t);
}
if(type.equals("class java.lang.Integer")){
Integer value = (Integer)m.invoke(t);
}
if(type.equals("class java.util.Date")){
Date value = (Date)m.invoke(t);
}
}
一开始觉得想从泛型 T 对象中取具体的对象的属性值,感觉有些滑稽,但自己的逻辑处理中如果这一步能够实现,真的可以简化很多东西,然后就是带着这种看似滑稽的想法,尝试着去做做看,没想到真的可以实现!
有些东西真的去做了,才会发现多么神奇!
java 把json转字符串格式转换 java json字符串转java对象
将json字符串转换为json对象:
JSONObject jsonObject = JSONObject.fromObject(jsonStr);将java对象转换为json对象:
JSONObject json = JSONObject.fromObject(obj);将json对象转换为java对象:
Person jb = (Person) JSONObject.toBean(obj,Pe
java项目中的权限设置 java权限管理shiro
一、Shiro 简介1、关于 ShiroApache Shiro是一个强大且易用的Java安全框架,执行身份验证、授权、密码和会话管理。使用Shiro的易于理解的API,您可以快速、轻松地获得任何应用程序,从最小的移动应用程序到最大的网络和企业应用程序。官网:https://shiro.apache.org/
2、Shiro 主要功能Authentication:身份认证/登录,验证用户是不是拥有
mysql8 json查询 mysql json类型 查询
1、json对象1.1、方法使用对象操作的方法进行查询:字段->'$.json属性'
使用函数进行查询:json_extract(字段, '$.json属性')
获取JSON数组/对象长度:JSON_LENGTH()
1.2、数据CREATE TABLE `test` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '