C:/Program Files/java/jdk1.6.0/bin,classpath设置的是java classLoader加载class类的时候要用到(比如你的程序中要写了一行代码:String str=new String();类加载器就必须再classpath路径中找到dt.jar中的java.lang.String类),一般设为:C:/Program Files/java/jdk1.6.0/lib/tools.jar;C:/Program Files/java/jdk1.6.0/lib/dt.jar.
2.Spring 1.x版本用的是DTD解析XML文件,2.x用的是Schema(xsd文件),里面包含了namespace(避免命名冲突)和数据类型。现在一般用Schema,他也是XML文件的格式,很多优点。两者不能混在一起使用。
<!--使用dtd方式-->
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
……
</beans>
<!--使用Schema方式-->
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">
</beans>
不能这样:
<!--不能混用-->
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">
.........
</beans>
其中spring-beans-2.0.xsd,spring-beans-2.0.xsd文件在Spring.jar中,可以自己解压看下。。。
3.Eclipse中改变jar包执行顺序
有时两个同样的类在不同的jar包中均有,而可能ClassLoader先加载的过期或不能用,我们可以改变下jar包的执行顺序。
方法:右击项目-属性-java bulider path--order。。。up ,down...........
4.几个项目之间可以相互访问各自的类,方法:右击项目-属性-java bulider path--。。。。。
5.java动态代理 代理的是接口,不能代理类,要代理普通java类需要CGLIB代理,要加入cglib.jar及其他依赖包(如asm*.jar)。
spring对AOP的支持2:
1)、如果目标对象实现了接口,默认情况下会采用JDK的动态代理实现AOP
2)、如果目标对象实现了接口,可以强制使用CGLIB实现AOP
3)、如果目标对象没有实现了接口,必须采用CGLIB库,spring会自动在JDK动态代理和CGLIB之间转换
在实现接口的情况下,如何强制使用CGLIB实现AOP?
* 添加CGLIB库,SPRING_HOME/cglib/*.jar
* 在spring配置文件中加入<aop:aspectj-autoproxy proxy-target-class="true"/>
JDK动态代理和CGLIB字节码生成的区别?
* JDK动态代理只能对实现了接口的类生成代理,而不能针对类
* CGLIB是针对类实现代理,主要是对指定的类生成一个子类,覆盖其中的方法
因为是继承,所以该类或方法最好不要声明成final
6.Spring中AspectJ @Aspect 方面 获得拦截方法:joinPoint.getSignature().getName();
待添加。。。。。。。。。。。
呵呵