spring

对于spring的看法觉得spring就相当于一个容器似的,可以装很多bean,然后对那些bean进行管理,首先是配置bean,我们可以这样写<bean id="xxx" class="xxx.xxx.xxx"/>其中id是唯一的。我们还可以给bean指定别名:<alias name="xxxx" alis="xx"/>,配置好了bean,我们就要先初始化他们,然后去调用它们,初始化呢,我们有三种方法,第一:构造器,第二:静态工厂,第三:实例工厂。然后我们调用bean,Resoruce resource = new FileSystemResource("bean.xml") BeanFactory beanFactory=new XmlBeanFactory(resource);
这样我们就可以获取到在xml文件中配置的bean了。或者用applicationContent来获取:
ApplicationContent content = new ClassPathXmlApplicationContent("applicationContent.xml");
BeanFactory beanFactory = content;
得到了beanFactory以后就可以获取到你想到得到的bean。
在实例化bean的时候,如果要用到static工厂方法那么在<bean factory-method="createInstance"/>bean标签中中一定要使用factory-method属性。
在bean中要有一个static方法例如:
class ExampleBean(){
private ExampleBean(Abean abean,Bbean bbean){
this.abean = abean;
this.bbean = bbean;

};
public static ExampleBean createInstance(Abean abean,Bbean bbean){
ExampleBean bean = new ExampleBean(abean,bbean);
return bean;

}


}

以上就是static工厂实例化bean方法。在配置文件中配置bean的时候我们可以在bean中加一个属性<idref = "beanId"/>这个属性可以验证在调用这个bean的时候这个bean是否存在。

关于注入有几种:set,get注入(同时配置文件要有bean注入配置),构造器注入(同上)。
<ref>标签是用来引用其他bean,内部bean则用<bean><property><bean/></property></bean>标签。注入list,map,set。后来出现自动注入@Autowired.

bean的作用域包括(singleton,prototype,request,session,global session)
如果你打算用一个作用域为request的baen注入到其他bean中,那么需要注入一个aop代理来替代被注入的作用域bean,也就是说,你需要注入一个代理对象,该对象具有与被代理对象一样的公共接口,而容器则可以足够智能的从相关作用域中(比如一个HTTP request)获取到真实的目标对象,并把方法调用委派给实际的对象。(这个理解不是很透彻)。

我们经常用ApplicationContext,但是ApplicationContext到底是什么?
beans包是对bean的管理,ApplicationContext则是以一种更加面向框架的方式增强了BeanFactory的功能。context包核心是ApplicatonContext接口由于ApplicationContext是由BeanFactory派生而来的所以ApplictionContext具有BeanFactory所有的功能。

spring国际化消息,可以自定义MessageSource或者是spring中的org.springframework.context.support.ResourceBundleMessageSource那么必须有属性文件在可以为list集合多个属性文件。获取国际化消息有三种方式:
String getMessage(String code, Object[] args, String default, Locale loc):用来从MessageSource获取消息的基本方法。如果在指定的locale中没有找到消息,则使用默认的消息。args中的参数将使用标准类库中的MessageFormat来作消息中替换值。

String getMessage(String code, Object[] args, Locale loc):本质上和上一个方法相同,其区别在:没有指定默认值,如果没找到消息,会抛出一个NoSuchMessageException异常。

String getMessage(MessageSourceResolvable resolvable, Locale locale):上面方法中所使用的属性都封装到一个MessageSourceResolvable实现中,而本方法可以指定MessageSourceResolvable实现。

注解:
@Autowired可以注解属性,方法,set,map(key为String类型,values为已知类型),构造器字段.
对于spring对classpath的扫描,我们可以用@component注解,@Repository,@service,@controller是对@component的细化,@Scope可以注解bean的作用域,如果要自定义检测bean名称策略,那么就要实现beanNameGenerator,自定义作用域那么要实现scopeMetadataResolver,注解元数据那么要用到@qualifiter("")等。

spring Validator :
实现validator接口,然后用rejectValue();来返回错误,然后用<spring:bind>来显示错误。
自定义转化,要继承PropertyEditorSupport或者实现PropertyEditorRegistrar ,然后在配置文件中注册这个转化<bean class="org.springframework.beans.factory.config.CustomEditorConfigurer">
<property name="customEditors">
<map>
<entry key="example.ExoticType">
<bean class="example.ExoticTypeEditor">
<property name="format" value="upperCase"/>
</bean>
</entry>
</map>
</property>
</bean>


面向切面:
spring aop 两种代理机制,一个是jdk代理,一个是cglib代理
启动@AspectJ支持,<aop:aspectj-autoproxy/>然后就可以自定义aopbean
并且切入点表达式使用@Pointcut注解来表示(作为切入点签名的方法必须返回void 类型)。
关于切面注解匹配:@execution,@within,@target(目标bean),@annotation,@args,this
(代理bean)声明通知:@before,@afterReturnning(可以有返回值参数),@afterReturnningThrowing(可以有抛出什么异常的参数),@after,@around,@agrs("")(传递参数),
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值