- 浏览: 236468 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (76)
- HQL (1)
- Hibernate (1)
- Oracle (6)
- Struts (1)
- Java (9)
- Android (5)
- oracle字符串截取函数 (1)
- Linux (6)
- DOS (1)
- HTML (1)
- IO (1)
- LOG4J (1)
- MyEclipse (0)
- native2ascii (1)
- JBox (2)
- jUploader (1)
- Eclipse (2)
- Maven (2)
- Jetty (2)
- SpringMVC (1)
- SpringSecurity (2)
- MySql (4)
- JavaScript (1)
- 正则表达式 (1)
- jQuery (4)
- Telnet (1)
- Kindeditor (1)
- JSP (1)
- Tomcat (1)
- WebService (2)
- CXF (1)
- MyBabits (1)
- Nginx (1)
- 反射 (1)
- EXT (1)
- OSX (2)
- MAC (4)
- Intellj IDEA (1)
- PHP (2)
- FTP (1)
- SSH (1)
- PEM (1)
- NTFS (1)
- Tools (1)
最新评论
-
Johnny_L:
lilihongmm 写道这样实现是有问题的。。。。Custo ...
Spring Security 3.0数据库动态实现权限控制 -
lilihongmm:
这样实现是有问题的。。。。CustomInvocationSe ...
Spring Security 3.0数据库动态实现权限控制 -
SundayHa:
SundayHa 写道楼主你好 为什么 我按你的配置完后 没有 ...
Spring Security 3.0数据库动态实现权限控制 -
SundayHa:
楼主你好 为什么 我按你的配置完后 没有进入CustomAcc ...
Spring Security 3.0数据库动态实现权限控制 -
java-lxm:
在哪个地方重新加载?
Spring Security 3.0数据库动态实现权限控制
1、通过反射获取到类中的所有属性列表
2、获取对象类型的值
Class cla = entityName.getClass(); Field field[] = cla.getDeclaredFields();
2、获取对象类型的值
public static Object getProperty(Object entityName) throws Exception { for (int i = 0; i < field.length; i++) { Field f = field[i]; if(f.getName().indexOf("Service") > 0){ f.setAccessible(true);//设置允许访问,不设置的话,属性值为private等就不能获取到值 return f.get(entityName);//这里返回的是一个service对象,接受到后就能调用里面的方法 } } }
package com.mobile.core; import java.lang.reflect.Field; import java.lang.reflect.Method; import java.text.SimpleDateFormat; import java.util.Date; import java.util.Enumeration; import java.util.Map; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.AfterReturning; import org.aspectj.lang.annotation.AfterThrowing; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component; import com.doone.mobile.controller.WebContextUtils; import com.doone.mobile.service.base.BaseService; import com.doone.mobile.tools.UtilString; /** * 根日志轨迹. * 通过AOP能力,将所有方法调用情况输入到根日志器. * 输出到控制台. * @ClassName: RootLogTrack */ @Component @Aspect public class RootLogTrack { @Resource private WebContextUtils webContextUtils; /** * * 配置外部接口层切入点. * 切入点匹配表达式com.doone.mobile.controller..* * 匹配包名为com.doone.mobile.controller及子包 */ @Pointcut("within(com.doone.mobile.controller..*)") public void controllerPointcut() { } /** * * TODO(配置外部接口层切入点. * 切入点匹配表达式com.doone.mobile.controller..* * 匹配包名为com.doone.mobile.controller及子包). * @author Johnny_L_Q */ @Pointcut(value = "execution(* com.doone.mobile.controller..*.save*(..))") public void controllerSavePointcut(){} /** * * TODO(配置外部接口层切入点. * 切入点匹配表达式com.doone.mobile.controller..* * 匹配包名为com.doone.mobile.controller及子包). * @author Johnny_L_Q */ @Pointcut(value = "execution(* com.doone.mobile.controller..*.delete*(..))") public void controllerDeletePointcut(){} /** * * 方法调用前通过日志纪录类名,方法名和参数值. * @param jp JoinPoint */ @Before("controllerPointcut()") public void methodInvokedBefore(JoinPoint jp) { Logger logger = LoggerFactory.getLogger(jp.getTarget().getClass()); logger.info(jp.toString()); StringBuilder builder = new StringBuilder(); Object[] args = jp.getArgs(); if (args.length > 0) { builder.append("arguments:"); } for (Object arg : args) { builder.append(arg).append(","); } if (args.length > 0) { builder.deleteCharAt(builder.length() - 1); } logger.info(builder.toString()); } /** * * controller中save方法调用前通过日志纪录类名,方法名和参数值. * @param jp JoinPoint * @author Johnny_L_Q */ @Before("controllerSavePointcut()") public void saveMethodInvokedBefore(JoinPoint jp) { Logger logger = LoggerFactory.getLogger(jp.getTarget().getClass()); StringBuilder builder = new StringBuilder(); builder.append("用户:" + webContextUtils.getUser().getUserName() + ",在时间:" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()) + ",对类" + jp.toString() + ",进行了保存操作,具体参数如下:"); Object[] args = jp.getArgs(); if (args.length > 0) { if(args[0] instanceof HttpServletRequest){ HttpServletRequest request = (HttpServletRequest) args[0]; Enumeration<String> obj = request.getParameterNames(); Map<String,Object> map = request.getParameterMap(); //循环遍历所有参数值,并记录到日志中 while (obj.hasMoreElements()) { String key = (String) obj.nextElement(); Object object = ((String[])map.get(key))[0]; String value = null; if(object instanceof Long){ System.out.println("Long"); value = ((Long) object).toString(); }else if(object instanceof Integer){ System.out.println("Integer"); value = ((Integer) object).toString(); }else if(object instanceof String){ System.out.println("String"); value = (String) object; } builder.append("'" + key).append("':").append("'" + value).append("',"); } }else{ for (Object arg : args) { builder.append(arg).append(","); } } } if (args.length > 0) { builder.deleteCharAt(builder.length() - 1); } logger.info(builder.toString()); } /** * * TODO(controller执行删除前获取即将删除的id值). * @param request * @author Johnny_L_Q * @return */ public String getRequestId(HttpServletRequest request){ Enumeration<String> obj = request.getParameterNames(); Map<String,Object> map = request.getParameterMap(); while (obj.hasMoreElements()) { String key = (String) obj.nextElement(); //判断字段名中是否含有Id或者是id,如果有则返回该值 if(key.indexOf("id") > 0 || key.indexOf("Id") > 0){ Object object = ((String[])map.get(key))[0]; String value = null; if(object instanceof Long){ value = ((Long) object).toString(); }else if(object instanceof Integer){ value = ((Integer) object).toString(); }else if(object instanceof String){ value = (String) object; } return value; } } return null; } /** * * 方法调用前通过日志纪录类名,方法名和参数值. * @param jp JoinPoint * @author Johnny_L_Q */ @Before("controllerDeletePointcut()") public void deleteMethodInvokedBefore(JoinPoint jp) { Logger logger = LoggerFactory.getLogger(jp.getTarget().getClass()); StringBuilder builder = new StringBuilder(); builder.append("用户:" + webContextUtils.getUser().getUserName() + ",在时间:" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()) + ",对" + jp.toString() + ",进行了删除操作,删除的数据内容如下:"); Object[] args = jp.getArgs(); try { if (args.length > 0) { //获得类中的service属性值 BaseService service = (BaseService) getProperty(jp.getTarget()); String id = null; if(args[0] instanceof HttpServletRequest){ HttpServletRequest request = (HttpServletRequest) args[0]; //获取参数ID id = getRequestId(request); } if(!UtilString.isEmpty(id) && null != service){ //查询出即将删除的实体 Object obj = service.findEntityById(Long.parseLong(id)); builder.append(obj.toString()); }else{ System.out.println("id is null"); } } } catch (Exception e) { e.printStackTrace(); } logger.info(builder.toString()); } /** * 获得一个对象各个属性的字节流 */ @SuppressWarnings("unchecked") public static Object getProperty(Object entityName) throws Exception { Class c = entityName.getClass(); Field field[] = c.getDeclaredFields(); for (int i = 0; i < field.length; i++) { Field f = field[i]; if(f.getName().indexOf("Service") > 0){ f.setAccessible(true); return f.get(entityName); } //System.out.println("---------- " + f.getName() + "\t" + "=========" + "\t" + f.getType()); } return null; } /** * * 方法调用后通过日志纪录返回值. * @param jp JoinPoint * @param retVal 返回值 */ @AfterReturning(pointcut = "controllerPointcut()", returning = "retVal") public void methodInvokedAfter(JoinPoint jp, Object retVal) { Logger logger = LoggerFactory.getLogger(jp.getTarget().getClass()); StringBuilder builder = new StringBuilder(); builder.append("return:"); builder.append(retVal); logger.info(builder.toString()); } /** * * 方法调用产生异常时,通过日志纪录异常. * @param jp JoinPoint * @param ex Exception */ @AfterThrowing(pointcut = "controllerPointcut()", throwing = "ex") public void methodInvokedThrowException(JoinPoint jp, Exception ex) { Logger logger = LoggerFactory.getLogger(jp.getTarget().getClass()); StringBuilder builder = new StringBuilder(); builder.append("exception:"); builder.append(ex.getClass().getSimpleName()); builder.append(ex.getMessage()); logger.error(builder.toString()); } }
发表评论
-
邮箱服务器mailgun的使用记录
2018-11-09 16:21 2757最近项目中需要发送邮箱验证码,使用fastmail和其他的邮箱 ... -
JAVA执行LINUX命令加密内容以及MAC
2016-09-16 17:17 1376最近有遇到一个问题就是接口放提供的接口密文为PHP的sha25 ... -
JAVA开发在Linux环境下需要做的配置和工具安装
2014-03-25 18:27 1006本人使用的是Ubuntu 13.10版本的linux系统 在此 ... -
JAVA 多线程例子
2014-03-03 16:57 1006在java中要想实现多线程 ... -
JAVA开发中的虚拟内存设置
2013-07-18 15:03 18081, 设置Eclipse内存使用情况 修改ec ... -
java获取本地外网ip
2012-08-09 13:28 7227import java.io.BufferedReader; ... -
获取ip地址
2012-08-09 13:19 1199通常,我们都是用以下代码来获取本地ip地址的 Java代码 ... -
JAVA虚拟内存的查看
2012-02-21 11:29 4138java.lang.Runtime类提供了查看当前JVM内存的 ...
相关推荐
本文将深入探讨Java反射的相关知识点。 1. 常用`Class`类方法: - `Class.forName(String className)`: 通过全限定类名获取`Class`对象。 - `obj.getClass()`: 获取对象的`Class`对象,代表该对象的类。 - `...
### Java反射机制详解 #### 一、引言 在Java面试中,经常会出现与反射...以上内容不仅解释了Java反射机制的相关知识点,还通过示例代码进行了实践演示,希望能够帮助你在Java面试中更好地理解和运用这一重要特性。
### Java反射性能测试分析 #### 引言 Java反射机制是Java编程语言中一个强大的特性,它允许程序在运行时动态地访问、检测和修改类、接口、字段和方法等对象。然而,反射操作通常会引入额外的开销,这在性能敏感的...
java反射机制java反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制...
Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射主要用于在运行时分析类和对象,包括访问私有成员、调用私有方法、创建对象、获取类...
Java反射机制是Java编程语言中的一个强大特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。这个特性使得Java具有了高度的灵活性和动态性,尤其是在处理元数据、创建对象、调用私有方法...
### Java反射机制总结 #### 反射的概念与起源 反射的概念最早由Smith于1982年提出,指的是程序能够访问、检测并修改其自身状态或行为的能力。这一概念的提出迅速引起了计算机科学领域的广泛关注,并在之后的研究中...
Java反射相关的API主要位于`java.lang.reflect`包中,这些API提供了操作类、构造函数、方法和字段的功能。以下是一些核心API: 1. **`java.lang.Class`**:表示类的类型,可以通过多种方式获取,如`Class.forName()...
Java反射是Java编程语言中的一个强大特性,它允许运行时的程序访问并操作类、接口、字段和方法等信息,即使这些信息在编译时并未明确知晓。在Java中,反射通常通过`java.lang.Class`类和相关的API来实现。本实例将...
在本文中,我们将深入探讨如何使用Java反射来获取并执行某个特定的方法。 首先,我们需要了解Java反射的基本概念。`java.lang.Class`类是反射的核心,它代表了Java中的每一个类。我们可以通过以下方式获取到一个...
Java反射是Java编程语言中的一个强大特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射机制的核心在于`java.lang.Class`类以及相关的接口和类,如`java.lang.reflect`包下...
### 反射实例—JAVA反射机制 #### 一、反射概念及原理 反射在计算机科学领域,特别是程序设计中,是指程序有能力访问、检测和修改其自身的结构和行为。这一概念最早由Smith于1982年提出,并迅速应用于各种编程语言...
对于学习Java反射,阅读和理解相关的源代码是非常有益的。你可以从Java标准库的`java.lang.reflect`包开始,研究Class、Constructor、Method和Field类的实现。通过阅读源码,可以更深入地理解反射的工作原理,提升...
### Java反射机制详解 #### 一、反射的基本概念与历史背景 反射的概念最早由Smith在1982年提出,其核心思想是程序有能力访问、检测甚至修改自身的状态和行为。这种能力一经提出,迅速成为了计算机科学领域的研究...
1.通过Java反射机制获取JavaBean对象。 2.通过JavaBean全路径字符串获取JavaBean对象。 3.获取JavaBean注解信息
### Java反射机制详解 #### 一、什么是Java反射? Java反射是Java编程语言的一个特性,它允许运行时检查和操作程序结构(类、字段、方法等)。反射的主要用途包括但不限于:动态实例化对象、访问私有成员、调用...
Java反射机制是Java语言提供的一种强大功能,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射机制的核心类是java.lang.Class,它代表了运行时的类信息。通过Class对象,我们...
Java反射是Java编程语言中的一个强大特性,它允许在运行时检查类、接口、字段和方法的信息,并且能够在运行时动态地创建对象和调用方法。这个特性使得Java具有了高度的灵活性,常用于框架开发、插件系统、元编程等...
关于java反射的一些基本的知识梳理,java反射的介绍,基本的操作,以及用法,实例