有关java反射机制 小结
111111111111
Class<?> cls = Class.forName("包名.类名");
Object o = cls.newInstance();
222222222222
//取得方法
Method method = cls.getMethod("set"+StringUtil.makeFirstLetterUpperCase(key),Boolean.class);//这里的boolean也可以是其他类型比如:Integer看情况赋值
333333333333333
//执行方法
method.invoke(o,val); //val是一个值,就是上面set方法的值
444444444444444444444444
//取得该类的所有方法
Method[] ms = cls.getMethods();
//取得其中一个方法的返回值类型
String type = ms[0].getReturnType().getName();
返回值类型:
java.lang.Long
java.lang.String
java.util.Date
java.lang.Double
java.lang.Float
int
这里可以根据方法的名称找到对应的返回值,然后赋值给第二步的参数 这样就获得 第二步的方法
55555555555555555555555555555555
一个excel导入,使用反射列子(个人代码收藏)
前端代码
<script type="text/javascript">
$(function(){
//导入基础数据
$("#importData").click(function() {
var rq = $("#inpRq").val();
var url = __ctx+'/zjdlbb/zjdlbb/zjdlbb/importDialog.ht';
var conf=$.extend({},{dialogWidth:550 ,dialogHeight:200,help:0,status:0,scroll:0,center:1});
var winArgs="dialogWidth="+conf.dialogWidth+"px;dialogHeight="+conf.dialogHeight
+"px;help=" + conf.help +";status=" + conf.status +";scroll=" + conf.scroll +";center=" +conf.center;
url=url.getNewUrl();
/*KILLDIALOG*/
DialogUtil.open({
height:conf.dialogHeight,
width: conf.dialogWidth,
url: url,
isResize: true,
sucCall : function(rtn) {
$.ligerDialog.success("导入成功", "", function(){
window.location.reload();
window.opener.refreshThis();
});
}
});
});
});
</script>
<div class="group"><a class="link " id="importData" href="javascript:;">导入</a></div>
后台代码
@RequestMapping({ "importExcel" })
@Action(description = "导入Excel弹窗")
public void importExcel(MultipartHttpServletRequest request,
HttpServletResponse response) throws Exception {
String rq = request.getParameter("rq");
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
SimpleDateFormat sdfTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-M-d");
MultipartFile fileLoad = request.getFile("xmlFile");
ResultMessage resultMessage = null;
try {
String fileType = fileLoad.getOriginalFilename().substring(
fileLoad.getOriginalFilename().lastIndexOf(".") + 1,
fileLoad.getOriginalFilename().length());
Workbook wb = null;
if (fileType.equals("xls")) {
wb = new HSSFWorkbook(fileLoad.getInputStream());
} else if (fileType.equals("xlsx")) {
wb = new XSSFWorkbook(fileLoad.getInputStream());
} else {
throw new Exception("读取的不是excel文件");
}
Sheet sheet = wb.getSheetAt(0);
XSSFSheet s = null;
HSSFCell cell0 = null;
HSSFCell cell1 = null;
Map<String, String> map = new HashMap<String, String>();
//获得总列数
int coloumNum=sheet.getRow(0).getPhysicalNumberOfCells();
int rowNum=sheet.getLastRowNum();//获得总行数
Class<?> cls = Class.forName("com.ytd.zjdlbb.model.zjdlbb.Zjdlbb");
Method[] ms = cls.getMethods();
List<Zjdlbb> list = new ArrayList<Zjdlbb>();
Map<String,String> keyMap = this.getKey();
//遍历每行数据,第一行0是标题
for (int i = 1; i <= rowNum; i++) {
Object o = cls.newInstance();
//遍历每一列
for (int j = 0; j < coloumNum; j++) {
//获取列标题
String title = sheet.getRow(0).getCell(j).getStringCellValue();
/* if(title.endsWith(")")){
title = title.substring(0,title.indexOf("("));
}*/
// log.info("title ============================="+title);
//获取列的值
String colVal = sheet.getRow(i).getCell(j).getStringCellValue();
//查找对应实体类属性
String key = keyMap.get(title);
// log.info("key ============================="+key);
if(StringUtil.isNotEmpty(key)){
//遍历类的所有方法名
for (int k = 0; k < ms.length; k++) {
//获取get方法
String tmp = "get"+StringUtil.makeFirstLetterUpperCase(key);
//excel标题与类属性相同的时候
if(tmp.equals(ms[k].getName())&&StringUtil.isNotEmpty(colVal)){
String setType = ms[k].getReturnType().getName();
// log.info("setType ============================="+setType);
Method method = null;
if("boolean".equals(setType)){
method = cls.getMethod("set"+StringUtil.makeFirstLetterUpperCase(key),Boolean.class);
method.invoke(o,colVal);
}else if("java.lang.String".equals(setType)){
method = cls.getMethod("set"+StringUtil.makeFirstLetterUpperCase(key),String.class);
method.invoke(o,colVal);
}else if("java.lang.Long".equals(setType)){
method = cls.getMethod("set"+StringUtil.makeFirstLetterUpperCase(key),Long.class);
method.invoke(o,Long.parseLong(colVal));
}else if("int".equals(setType)){
method = cls.getMethod("set"+StringUtil.makeFirstLetterUpperCase(key),Integer.class);
method.invoke(o,Integer.parseInt(colVal));
}else if("java.util.Date".equals(setType)){
method = cls.getMethod("set"+StringUtil.makeFirstLetterUpperCase(key),Date.class);
method.invoke(o,sdfTime.parse(colVal));
}else if("java.lang.Double".equals(setType)){
// log.info("hhhhhhh ===========oooooooooooooooooooo=================="+setType);
method = cls.getMethod("set"+StringUtil.makeFirstLetterUpperCase(key),Double.class);
method.invoke(o,Double.parseDouble(colVal));
}else if("java.lang.Float".equals(setType)){
method = cls.getMethod("set"+StringUtil.makeFirstLetterUpperCase(key),Float.class);
method.invoke(o,Float.parseFloat(colVal));
}
}
}
}
}
list.add((Zjdlbb)o);
}
for(Zjdlbb entity:list){
Long id=UniqueIdUtil.genId();
entity.setId(id);
zjdlbbService.add(entity);
}
String result = "导入数据成功";
if (result.contains("成功")) {
resultMessage = new ResultMessage(1, "导入成功!");
} else {
resultMessage = new ResultMessage(0, result);
}
writeResultMessage(response.getWriter(), resultMessage);
} catch (Exception ex) {
ex.printStackTrace();
String str = MessageUtil.getMessage();
ex.getLocalizedMessage();
if (StringUtil.isNotEmpty(str)) {
resultMessage = new ResultMessage(0, "导入失败请检查导入的Excel是否正确:"
+ str);
response.getWriter().print(resultMessage);
} else {
String message = ExceptionUtil.getExceptionMessage(ex);
resultMessage = new ResultMessage(0, "导入失败请检查导入的Excel是否正确");
response.getWriter().print(resultMessage);
}
}
}
有关java反射机制 小结的更多相关文章
- Java反射机制小结和实际操作
一.什么是反射 1.编译和运行 在了解什么是Java反射机制前,先聊聊Java的编译和运行. 还记得第一次使用记事本编写第一个Java程序的场景吗?通过命令窗口,使用javac命令编译一个.java文 ...
- Java进阶(六)Java反射机制可恶问题NoSuchFieldException
作为一种重要特性,Java反射机制在很多地方会用到.在此做一小结,供朋友们参考. 首先从一个问题开始着手. 可恶的问题又来了,NoSuchFieldException,如下图所示: 完全不知道这个qu ...
- 夯实Java基础(二十一)——Java反射机制
1.反射机制概述 Java反射机制是指程序在运行状态中,对于任何一个类,我们都能够知道这个类的所有属性和方法(包括private.protected等).对于任何一个对象,我们都能够对它的属性和方法进 ...
- 第28章 java反射机制
java反射机制 1.类加载机制 1.1.jvm和类 运行Java程序:java 带有main方法的类名 之后java会启动jvm,并加载字节码(字节码就是一个类在内存空间的状态) 当调用java命令 ...
- Java反射机制
Java反射机制 一:什么事反射机制 简单地说,就是程序运行时能够通过反射的到类的所有信息,只需要获得类名,方法名,属性名. 二:为什么要用反射: 静态编译:在编译时确定类型,绑定对象,即通过 ...
- java基础知识(十一)java反射机制(上)
java.lang.Class类详解 java Class类详解 一.class类 Class类是java语言定义的特定类的实现,在java中每个类都有一个相应的Class对象,以便java程序运行时 ...
- java基础知识(十一)java反射机制(下)
1.什么是反射机制? java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法,对于任意一个对象都能够调用他的属性和方法,这种动态获取属性和方法的功能称为java的反射机制. ...
- Java反射机制专题
·Java Reflection Reflection(反射)是被视为动态语言的关键,反射机制允许程序在执行期借助于Reflection API取得任何类的内部信息,并能直接操作任意对象的内部属性及方 ...
- java反射机制深入详解
java反射机制深入详解 转自:http://www.cnblogs.com/hxsyl/archive/2013/03/23/2977593.html 一.概念 反射就是把Java的各种成分映射成 ...
随机推荐
- win7 cmd终端连接android手机运行adb shell脚本命令
win7 cmd终端连接android手机运行adb shell脚本命令 (2013-03-22 20:13:57) 转载▼ 标签: android it shell 连接 linux 分类: 嵌入式 ...
- 【租房合同】2017北京市房屋租赁合同(自行成交版).doc
最近在北京租房,找租房合同 这个文档还是比较新的,在百度文库上需要积分下载的文档,现在共享给大家吧. 下载地址: https://pan.baidu.com/s/1cEh7lhBqQgkJhB32Df ...
- 关于删除 hao123 主页设置的一点经验
:first-child { margin-top: 0px; } blockquote>:last-child { margin-bottom: 0px; } --> 说一说关于删除 h ...
- 跨服务器做yum源
服务器无法上网,然后自己根据光盘搭建的YUM源不够用.RPM安装软件,各种依赖,找包烦死. 先做个 能上外网的 http proxy 找一个可以上Internet的服务器,然后起一个squid服务, ...
- DDoS(Distributed Denial of Service,分布式拒绝服务)
DDoS:Distributed Denial of Service,即分布式拒绝服务攻击. 借助于客户/服务器技术,将多个计算机联合起来作为攻击平台,对一个或多个目标发动DDoS攻击,从而成倍地提高 ...
- 5:CSS元素类型
5:CSS元素类型 学习目标 1.元素类型分类依据和元素类型分类 2.元素类型的转换 3.inline-block元素类型的应用 4.置换和非置换元素的概念和应用案例 一.元素类型分类依据和元素类型分 ...
- linux_check
linux_check echo "********CPU****************" echo 总核数 = 物理CPU个数 X 每颗物理CPU的核数 echo " ...
- dubbo-admin2.8.4部署
1.环境准备 (1)操作系统:CentOS6.5 (2)安装JDK并且配置好环境变量,参考:http://blog.csdn.net/u013274055/article/details/739206 ...
- 【每日一题】Squares UVA - 201 暴力+输出坑 + 读文件模板
题意 给你n*n的图,让你数正方形 题解:暴力for每个点,对于每个点从它出发顺时针走一个正方形.走完就ans[i]++; 坑:多输了一行******,然后在那里手摸样例,无限debug orz #d ...
- manifold 微分流形上可以定义可微函数、切向量、切向量场、各种张量场等对象并建立其上的分析学,并可以赋予更复杂的几何结构以研究它们的性质。
小结: 1.流形(英语:Manifolds)一般可以通过把许多平直的片折弯并粘连而成,是局部具有欧几里得空间性质的空间,是欧几里得空间中的曲线.曲面等概念的推广 2.描述一个流形往往需要不止一个“地图 ...