spring 怎么spring boot 获取beann

Spring中Bean初始化实例【重要】 - 每天进步一点点! - ITeye技术网站
博客分类:
可参考文章:
容器启动时:
BeanFactoryPostProcessor
-&postProcessBeanFactory()
getBean时:
实例化之后调用:
InstantiationAwareBeanPostProcessor
-&postProcessPropertyValues()
初始化时:
属性注入(setter)
BeanNameAware
-&setBeanName()
BeanFactoryAware
-&setBeanFactory()
ApplicationContextAware
-&setApplicationContext()
BeanPostProcessor
-&postProcessBeforeInitialization()
InitializingBean
-&afterPropertiesSet()
init-method属性
BeanPostProcessor
-&postProcessAfterInitialization()
DiposibleBean
-&destory()
destroy-method属性
BeanFactoryPostProcessor
//Spring IoC容器允许BeanFactoryPostProcessor在容器实际实例化任何其它的bean之前读取配置元数据,并有可能修改它。
//同时BeanFactoryPostProcessor的回调比BeanPostProcessor要早
void postProcessBeanFactory(ConfigurableListableBeanFactory arg)
InstantiationAwareBeanPostProcessorAdapter
其适配器类:InstantiationAwareBeanPostProcessor
//实例化Bean之前调用 (Bean构造函数前)
Object postProcessBeforeInstantiation(Class&?& beanClass, String beanName)
//实例化Bean之后调用
boolean postProcessAfterInstantiation(Object bean, String beanName)
PropertyValues postProcessPropertyValues(PropertyValues pvs,
PropertyDescriptor[] pds, Object bean, String beanName)
BeanPostProcessor
//实例化、依赖注入完毕,在初始化之前调用,完成一些定制的初始化任务
Object postProcessBeforeInitialization(Object bean, String beanName)
//实例化、依赖注入、初始化完毕时执行
Object postProcessAfterInitialization(Object bean, String beanName)
BeanFactoryPostProcessor和BeanPostProcessor都是Spring初始化bean的扩展点。两个接口非常相似。
BeanFactoryPostProcessor可以在postProcessBeanFactory()中对bean的定义(配置元数据)进行处理,而BeanPostProcessor不可以。
同时BeanFactoryPostProcessor的回调比BeanPostProcessor要早。
百度文库:
实例2(重要):
Bean的完整生命周期经历了各种方法调用,这些方法可以划分为以下几类:
1、Bean自身的方法:
  这个包括了Bean本身调用的方法和通过配置文件中&bean&的init-method和destroy-method指定的方法
2、Bean级生命周期接口方法:
  这个包括了BeanNameAware、BeanFactoryAware、InitializingBean和DiposableBean这些接口的方法
3、容器级生命周期接口方法:
  这个包括了InstantiationAwareBeanPostProcessor 和 BeanPostProcessor 这两个接口实现,一般称它们的实现类为“后处理器”。
4、工厂后处理器接口方法:
  这个包括了AspectJWeavingEnabler, ConfigurationClassPostProcessor, CustomAutowireConfigurer等等非常有用的工厂后处理器  接口的方法。工厂后处理器也是容器级的。在应用上下文装配配置文件之后立即调用。
我们用一个简单的Spring Bean来演示一下Spring Bean的生命周期。
1、首先是一个简单的Spring Bean,调用Bean自身的方法和Bean级生命周期接口方法,
为了方便演示,它实现了BeanNameAware、BeanFactoryAware、InitializingBean和DiposableBean这4个接口,
【对于BeanFactoryAware和BeanNameAware接口,第一个接口让bean感知容器(即BeanFactory实例,从而以此获取该容器配置的其他bean对象),而后者让bean获得配置文件中对应的配置名称。在一般情况下用户不需要关心这两个接口。如果bean希望获得容器中的其他bean,可以通过属性注入的方式引用这些bean。如果bean希望在运行期获知在配置文件中的Bean名称,可以简单的将名称作为属性注入
综上所述,我们认为除非编写一个基于spring之上的扩展框架插件或者子项目之类的东西,否则用户完全可以抛开以上4个bean生命周期的接口类
但BeanPostProcessor接口却不一样,它不要求bean去继承它,它可以完全像插件一样注册到spring容器中,为容器提供额外的功能。spring充分利用了BeanPostProcessor对bean进行加工处理(SpringAOP以此为基础)】
同时有2个方法,对应配置文件中&bean&的init-method和destroy-method。如下:
package springBeanT
import org.springframework.beans.BeansE
import org.springframework.beans.factory.BeanF
import org.springframework.beans.factory.BeanFactoryA
import org.springframework.beans.factory.BeanNameA
import org.springframework.beans.factory.DisposableB
import org.springframework.beans.factory.InitializingB
public class Person implements BeanFactoryAware, BeanNameAware,
InitializingBean, DisposableBean {
private BeanFactory beanF
private String beanN
public Person() {
System.out.println("【构造器】调用Person的构造器实例化");
public String getName() {
public void setName(String name) {
System.out.println("【注入属性】注入属性name");
this.name =
public String getAddress() {
public void setAddress(String address) {
System.out.println("【注入属性】注入属性address");
this.address =
public int getPhone() {
public void setPhone(int phone) {
System.out.println("【注入属性】注入属性phone");
this.phone =
public String toString() {
return "Person [address=" + address + ", name=" + name + ", phone="
+ phone + "]";
// 这是BeanFactoryAware接口方法
public void setBeanFactory(BeanFactory arg) throws BeansException {
System.out
.println("【BeanFactoryAware接口】调用BeanFactoryAware.setBeanFactory()");
this.beanFactory =
// 这是BeanNameAware接口方法
public void setBeanName(String arg) {
System.out.println("【BeanNameAware接口】调用BeanNameAware.setBeanName()");
this.beanName =
// 这是InitializingBean接口方法
public void afterPropertiesSet() throws Exception {
System.out
.println("【InitializingBean接口】调用InitializingBean.afterPropertiesSet()");
// 这是DiposibleBean接口方法
public void destroy() throws Exception {
System.out.println("【DiposibleBean接口】调用DiposibleBean.destory()");
// 通过&bean&的init-method属性指定的初始化方法
public void myInit() {
System.out.println("【init-method】调用&bean&的init-method属性指定的初始化方法");
// 通过&bean&的destroy-method属性指定的初始化方法
public void myDestory() {
System.out.println("【destroy-method】调用&bean&的destroy-method属性指定的初始化方法");
2、接下来是演示BeanPostProcessor接口的方法,如下:
package springBeanT
import org.springframework.beans.BeansE
import org.springframework.beans.factory.config.BeanPostP
public class MyBeanPostProcessor implements BeanPostProcessor {
public MyBeanPostProcessor() {
System.out.println("这是BeanPostProcessor实现类构造器!!");
public Object postProcessAfterInitialization(Object arg, String arg)
throws BeansException {
System.out.println("BeanPostProcessor接口方法postProcessAfterInitialization对属性进行更改!");
public Object postProcessBeforeInitialization(Object arg, String arg)
throws BeansException {
System.out.println("BeanPostProcessor接口方法postProcessBeforeInitialization对属性进行更改!");
如上,BeanPostProcessor接口包括2个方法postProcessAfterInitialization和postProcessBeforeInitialization,这两个方法的第一个参数都是要处理的Bean对象,第二个参数都是Bean的name。返回值也都是要处理的Bean对象。这里要注意。
3、InstantiationAwareBeanPostProcessor 接口本质是BeanPostProcessor的子接口,一般我们继承Spring为其提供的适配器类InstantiationAwareBeanPostProcessorAdapter来使用它,如下:
package springBeanT
import java.beans.PropertyD
import org.springframework.beans.BeansE
import org.springframework.beans.PropertyV
import org.springframework.beans.factory.config.InstantiationAwareBeanPostProcessorA
public class MyInstantiationAwareBeanPostProcessor extends
InstantiationAwareBeanPostProcessorAdapter {
public MyInstantiationAwareBeanPostProcessor() {
System.out.println("这是InstantiationAwareBeanPostProcessorAdapter实现类构造器!!");
// 接口方法、实例化Bean之前调用
public Object postProcessBeforeInstantiation(Class beanClass,
String beanName) throws BeansException {
System.out.println("InstantiationAwareBeanPostProcessor调用postProcessBeforeInstantiation方法");
// 接口方法、实例化Bean之后调用
public Object postProcessAfterInitialization(Object bean, String beanName)
throws BeansException {
System.out.println("InstantiationAwareBeanPostProcessor调用postProcessAfterInitialization方法");
// 接口方法、设置某个属性时调用
public PropertyValues postProcessPropertyValues(PropertyValues pvs,
PropertyDescriptor[] pds, Object bean, String beanName)
throws BeansException {
System.out.println("InstantiationAwareBeanPostProcessor调用postProcessPropertyValues方法");
这个有3个方法,其中第二个方法postProcessAfterInitialization就是重写了BeanPostProcessor的方法。第三个方法postProcessPropertyValues用来操作属性,返回值也应该是PropertyValues对象。
4、演示工厂后处理器接口方法,如下:
package springBeanT
import org.springframework.beans.BeansE
import org.springframework.beans.factory.config.BeanD
import org.springframework.beans.factory.config.BeanFactoryPostP
import org.springframework.beans.factory.config.ConfigurableListableBeanF
public class MyBeanFactoryPostProcessor implements BeanFactoryPostProcessor {
public MyBeanFactoryPostProcessor() {
System.out.println("这是BeanFactoryPostProcessor实现类构造器!!");
public void postProcessBeanFactory(ConfigurableListableBeanFactory arg)
throws BeansException {
System.out
.println("BeanFactoryPostProcessor调用postProcessBeanFactory方法");
BeanDefinition bd = arg.getBeanDefinition("person");
bd.getPropertyValues().addPropertyValue("phone", "");
5、配置文件如下beans.xml,很简单,使用ApplicationContext,处理器不用手动注册:
&?xml version="1.0" encoding="UTF-8"?&
&beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd"&
&bean id="beanPostProcessor" class="springBeanTest.MyBeanPostProcessor"&&/bean&
&bean id="instantiationAwareBeanPostProcessor" class="springBeanTest.MyInstantiationAwareBeanPostProcessor"&&/bean&
&bean id="beanFactoryPostProcessor" class="springBeanTest.MyBeanFactoryPostProcessor"&
&bean id="person" class="springBeanTest.Person" init-method="myInit"
destroy-method="myDestory" scope="singleton" p:name="张三" p:address="广州"
p:phone="" /&
package springBeanT
import org.springframework.context.ApplicationC
import org.springframework.context.support.ClassPathXmlApplicationC
public class BeanLifeCycle {
public static void main(String[] args) {
System.out.println("现在开始初始化容器");
ApplicationContext ctx = new ClassPathXmlApplicationContext("springBeanTest/beans.xml");
System.out.println("容器初始化成功");
//得到Preson,并使用
Person person = ctx.getBean("person",Person.class);
System.out.println(person);
System.out.println("现在开始关闭容器!");
((ClassPathXmlApplicationContext)ctx).registerShutdownHook();
结果如下:
现在开始初始化容器
15:46:20 org.springframework.context.support.AbstractApplicationContext prepareRefresh
信息: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@19a0c7c: startup date [Sun May 18 15:46:20 CST 2014]; root of context hierarchy
15:46:20 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from class path resource [springBeanTest/beans.xml]
这是BeanFactoryPostProcessor实现类构造器!
BeanFactoryPostProcessor调用postProcessBeanFactory方法
这是BeanPostProcessor实现类构造器!!
这是InstantiationAwareBeanPostProcessorAdapter实现类构造器!!
15:46:20 org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons
信息: Pre-instantiating singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@9934d4: defining beans [beanPostProcessor,instantiationAwareBeanPostProcessor,beanFactoryPostProcessor,person]; root of factory hierarchy
InstantiationAwareBeanPostProcessor调用postProcessBeforeInstantiation方法
【构造器】调用Person的构造器实例化
InstantiationAwareBeanPostProcessor调用postProcessPropertyValues方法
【注入属性】注入属性address
【注入属性】注入属性name
【注入属性】注入属性phone
【BeanNameAware接口】调用BeanNameAware.setBeanName()
【BeanFactoryAware接口】调用BeanFactoryAware.setBeanFactory()
BeanPostProcessor接口方法postProcessBeforeInitialization对属性进行更改!
【InitializingBean接口】调用InitializingBean.afterPropertiesSet()
【init-method】调用&bean&的init-method属性指定的初始化方法
BeanPostProcessor接口方法postProcessAfterInitialization对属性进行更改!
InstantiationAwareBeanPostProcessor调用postProcessAfterInitialization方法(这个位置感觉有问题,待解决)
容器初始化成功
Person [address=广州, name=张三, phone=110]
现在开始关闭容器!
【DiposibleBean接口】调用DiposibleBean.destory()
【destroy-method】调用&bean&的destroy-method属性指定的初始化方法
图示如下:
浏览 24869
浏览: 2854010 次
来自: 一片神奇的土地
大神又其他网站的账号不?比如微博,知乎,或者CSDN的。
楼主文字写得太好了。
TryRelax 写道call 方法可以用来代替另一个对象调用 ...
https://developer.mozilla.org/z ...Spring工厂方式创建Bean实例 -
- ITeye技术网站
博客分类:
&&& 很多情况下使用&bean id=”bean1” class=”…” /&定义一个bean,这种定义方式Spring将会调用默认的无参数构造方法创建Bean实例。除此之外还可以使用工厂方式创建Bean实例,实现Bean创建与使用的分离,将Bean创建工作交由工厂来完成。
配置工厂Bean的三种方式。
抽象接口:
public interface IMusicBox {
public void play();
1、静态工厂方法取得Bean实例
工厂类:
public class MusicBoxFactory {
public static IMusicBox createMusicBox(){
return new IMusicBox(){
public void play(){
System.out.println("Play piano...");
配置文件:
&bean id="musicBox" class="test.spring.MusicBoxFactory" factory-method="createMusicBox" /&
public static void main(String[] args) {
ApplicationContext
new ClassPathXmlApplicationContext("bean-config.xml");
IMusicBox musicbox = (IMusicBox)ctx.getBean("musicBox");
musicbox.play();
2、工厂实例的方法取得Bean实例
工厂类:
public class MusicBoxFactory {
public IMusicBox createMusicBox(){//没有static修饰
return new IMusicBox(){
public void play(){
System.out.println("Play piano...");
配置文件:
&bean id="factoryBean"
class="test.spring.MusicBoxFactory" /&
&bean id="musicBox" factory-bean="factoryBean" factory-method="createMusicBox" /&
“factory-bean”属性指定工厂Bean,”factory-method”属性指定工厂方法来取得Bean实例。
public static void main(String[] args) {
ApplicationContext
new ClassPathXmlApplicationContext("bean-config.xml");
IMusicBox musicbox = (IMusicBox)ctx.getBean("musicBox");
musicbox.play();
3、工厂类实现org.springframework.beans.factory.FacotryBean接口
工厂类:
import org.springframework.beans.factory.FactoryB
public class MusicBoxFactory2 implements FactoryBean {
public Object getObject() throws Exception {
return new IMusicBox(){
public void play(){
System.out.println("Play piano...");
public Class getObjectType() {
return IMusicBox.
public boolean isSingleton() {
配置文件:
&bean id="musicBox" class="test.spring.MusicBoxFactory2"/&
public static void main(String[] args) {
ApplicationContext
new ClassPathXmlApplicationContext("bean-config.xml");
//不加 & 返回工厂的“产品”
IMusicBox musicbox = (IMusicBox)ctx.getBean("musicBox");
musicbox.play();
//加 & 返回工厂类实例
Object obj = ctx.getBean("&musicBox");
System.out.println(obj.getClass().getName());
实现FactoryBean接口的类不会被视为普通的Bean,Spring会自动检测,调用getObject方法获取Bean实例
浏览 11824
浏览: 148483 次
来自: 杭州
现每一个代理类只能为一个接口服务,这样一来程序开发中必然会产生 ...
很多错误,我只想让其显示一个 如何来设置
哥们,你们的PDF中文不显示怎么解决的?
教程不如代码来得快。。。。匿名用户不能发表回复!|
每天回帖即可获得10分可用分!小技巧:
你还可以输入10000个字符
(Ctrl+Enter)
请遵守CSDN,不得违反国家法律法规。
转载文章请注明出自“CSDN(www.csdn.net)”。如是商业用途请联系原作者。Spring在代码中获取bean的几种方式 - 博客频道 - CSDN.NET
分类:spring
方法一:在初始化时保存ApplicationContext对象 方法二:通过Spring提供的utils类获取ApplicationContext对象 方法三:继承自抽象类ApplicationObjectSupport 方法四:继承自抽象类WebApplicationObjectSupport 方法五:实现接口ApplicationContextAware 方法六:通过Spring提供的ContextLoader
获取spring中bean的方式总结:
方法一:在初始化时保存ApplicationContext对象
ApplicationContext ac = new FileSystemXmlApplicationContext(&applicationContext.xml&);
ac.getBean(&beanId&);
说明:这种方式适用于采用Spring框架的独立应用程序,需要程序通过配置文件手工初始化Spring的情况。
方法二:通过Spring提供的工具类获取ApplicationContext对象
ApplicationContext ac1 = WebApplicationContextUtils.getRequiredWebApplicationContext(ServletContext sc);
ApplicationContext ac2 = WebApplicationContextUtils.getWebApplicationContext(ServletContext sc);
ac1.getBean(&beanId&);
ac2.getBean(&beanId&);
说明:这种方式适合于采用Spring框架的B/S系统,通过ServletContext对象获取ApplicationContext对象,然后在通过它获取需要的类实例。上面两个工具方式的区别是,前者在获取失败时抛出异常,后者返回null。
方法三:继承自抽象类ApplicationObjectSupport
说明:抽象类ApplicationObjectSupport提供getApplicationContext()方法,可以方便的获取ApplicationContext。
Spring初始化时,会通过该抽象类的setApplicationContext(ApplicationContext context)方法将ApplicationContext 对象注入。
方法四:继承自抽象类WebApplicationObjectSupport
说明:类似上面方法,调用getWebApplicationContext()获取WebApplicationContext
方法五:实现接口ApplicationContextAware
说明:实现该接口的setApplicationContext(ApplicationContext context)方法,并保存ApplicationContext 对象。Spring初始化时,会通过该方法将ApplicationContext对象注入。
以下是实现ApplicationContextAware接口方式的代码,前面两种方法类似:
package com.ifaboo.MiomOmmg.
import org.springframework.context.ApplicationC
import org.springframework.context.ApplicationContextA
public class SpringContextUtil implements ApplicationContextAware {
private static ApplicationContext applicationC
* 实现ApplicationContextAware接口的context注入函数, 将其存入静态变量.
public void setApplicationContext(ApplicationContext applicationContext) {
SpringContextUtil.applicationContext = applicationC // NOSONAR
* 取得存储在静态变量中的ApplicationContext.
public static ApplicationContext getApplicationContext() {
checkApplicationContext();
return applicationC
* 从静态变量ApplicationContext中取得Bean, 自动转型为所赋值对象的类型.
@SuppressWarnings(&unchecked&)
public static &T& T getBean(String name) {
checkApplicationContext();
return (T) applicationContext.getBean(name);
* 从静态变量ApplicationContext中取得Bean, 自动转型为所赋值对象的类型.
@SuppressWarnings(&unchecked&)
public static &T& T getBean(Class&T& clazz) {
checkApplicationContext();
return (T) applicationContext.getBeansOfType(clazz);
* 清除applicationContext静态变量.
public static void cleanApplicationContext() {
applicationContext =
private static void checkApplicationContext() {
if (applicationContext == null) {
throw new IllegalStateException(&applicaitonContext未注入,请在applicationContext.xml中定义SpringContextHolder&);
虽然,spring提供的后三种方法可以实现在普通的类中继承或实现相应的类或接口来获取spring 的ApplicationContext对象,但是在使用是一定要注意实现了这些类或接口的普通java类一定要在Spring 的配置文件applicationContext.xml文件中进行配置。否则获取的ApplicationContext对象将为null。
方法六:通过Spring提供的ContextLoader
WebApplicationContext wac = ContextLoader.getCurrentWebApplicationContext();
wac.getBean(beanID);
最后提供一种不依赖于servlet,不需要注入的方式。但是需要注意一点,在服务器启动时,Spring容器初始化时,不能通过以下方法获取Spring
容器,细节可以查看spring源码org.springframework.web.context.ContextLoader。
排名:第18095名
(10)(0)(16)(13)(2)(0)(5)(4)(3)(2)(9)(17)(3)(15)(0)(1)(4)(0)(0)(2)(1)(0)(1)(5)(1)(1)(4)(4)(1)spring mvc 接收表单 bean - 简单的幸福 - ITeye技术网站
博客分类:
spring MVC如何接收表单bean 呢?
之前项目中MVC框架一直用struts2,所以我也就按照struts2 的思维来思考
页面loginInput.jsp:
&?xml version="1.0" encoding="UTF-8" ?&
&%@ page language="java" contentType="text/ charset=UTF-8"
pageEncoding="UTF-8"%&
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path + "/";
&!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&
&html xmlns="http://www.w3.org/1999/xhtml"&
&meta http-equiv="Content-Type" content="text/ charset=UTF-8" /&
&title&Insert title here&/title&
&font color="red" &${message }&/font&
&form action="&%=path %&/user/loginVerify"&
&td&身份证:&/td&
&td& &input type="text" name="user.identity"
&td&用户编号:&/td&
&td&&input type="text" name="user.studentID"
&td colspan="2"&
&input type="submit"
value="login"/&
控制器LoginController 中登录的方法:
* 校验登录用户
* @param session
* @param user
* @throws UnsupportedEncodingException
* @throws Exception
@RequestMapping(value = "/loginVerify")
public String login(User user, HttpSession session,
Map&String, Object& map,Model model) throws UnsupportedEncodingException,
Exception {
User user2 =
if (user.getIdentity() == null) {
map.put("message", "请输入身份证");
return "loginInput";
map.put("identity", user.getIdentity());
model.addAttribute("identity", user.getIdentity());
System.out.println("identity:"+session.getAttribute("identity"));
user2 = this.userDao.getByIdentityAndStudentID(new User(user.getIdentity(),
user.getStudentID()));
System.out.println("user2:" + user2);
if (user2 != null) {
return "welcome";
map.put("message", "身份证和用户编号有误,请重新登录");
return "loginInput";
我认为页面表单中name为user.identity 和user.studentID的元素会自动注入到上述方法的变量User user 中,结果没有!!!?
实体类User:
package com.springmvc.
import javax.persistence.E
import javax.persistence.GeneratedV
import javax.persistence.Id;
* father class
* @author huangwei
class User {
* 用户编号
private String studentID;
public User() {
public User(String identity, String studentID) {
this.identity =
this.studentID = studentID;
@GeneratedValue
public int getId() {
public void setId(int id) {
public String getIdentity() {
public void setIdentity(String identity) {
this.identity =
public String getStudentID() {
return studentID;
public void setStudentID(String studentID) {
this.studentID = studentID;
public String getUsername() {
public void setUsername(String username) {
this.username =
原来,spring MVC 跟struts2的注入方式不一样!!
后来我把页面中的name属性改为identity 和studentID 就好了:
&td&身份证:&/td&
&td& &input type="text" name="identity"
&td&用户编号:&/td&
&td&&input type="text" name="studentID"
这就是spring MVC与struts2 ioc不同的地方!
浏览 16299
页面进行修改如下:&&&&&&&&&&&&&&& &tr&& &&&&&&&&&&&&&&&&&&& &td&身份证:&/td&& &&&&&&&&&&&&&&&&&&& &td& &input type="text" name="identity"& /& &/td&& &&&&&&&&&&&&&&& &/tr&& &&&&&&&&&&&&&&& &tr&& &&&&&&&&&&&&&&&&&&& &td&用户编号:&/td&& &&&&&&&&&&&&&&&&&&& &td&&input type="text" name="studentID"& /& &/td&& &&&&&&&&&&&&&&& &/tr&& &&&&&&&&&&&&&&& &tr&& &&&&&&&&&&&&&&&&&&& &td colspan="2"&& &&&&&&&&&&&&&&&&&&& &input type="submit"& value="login"/&& &&&&&&&&&&&&&&&&&&& &/td&& &&& @RequestMapping(value = "/loginVerify")& &&& public String login(User user,Model model) 应该就可以了谢谢
浏览: 2197324 次
来自: 北京
zzd0058 写道jar是个空的上传了新的jar包:io00 ...
jar是个空的
收了个去取去自己试一下!
蒙奇君杰 写道谢谢了!挺有用的能帮到你很开心

我要回帖

更多关于 spring 获取bean 实例 的文章

 

随机推荐