Quiero usar un bean prototipo anotado en mi controlador. Pero la primavera está creando un frijol singleton en su lugar. Aquí está el código para que:@Scope ("prototype") bean scope no crea nuevo bean
@Component
@Scope("prototype")
public class LoginAction {
private int counter;
public LoginAction(){
System.out.println(" counter is:" + counter);
}
public String getStr() {
return " counter is:"+(++counter);
}
}
código de controlador:
@Controller
public class HomeController {
@Autowired
private LoginAction loginAction;
@RequestMapping(value="/view", method=RequestMethod.GET)
public ModelAndView display(HttpServletRequest req){
ModelAndView mav = new ModelAndView("home");
mav.addObject("loginAction", loginAction);
return mav;
}
public void setLoginAction(LoginAction loginAction) {
this.loginAction = loginAction;
}
public LoginAction getLoginAction() {
return loginAction;
}
}
plantilla Velocity:
LoginAction counter: ${loginAction.str}
primavera config.xml
tiene la exploración componente habilitado:
<context:annotation-config />
<context:component-scan base-package="com.springheat" />
<mvc:annotation-driven />
Recibo un recuento incrementado cada vez. ¡No puedo entender dónde me estoy equivocando!
actualización
Como suggested by @gkamal, hice HomeController
webApplicationContext
sea conscientes y se resolvió el problema.
código actualizado:
@Controller
public class HomeController {
@Autowired
private WebApplicationContext context;
@RequestMapping(value="/view", method=RequestMethod.GET)
public ModelAndView display(HttpServletRequest req){
ModelAndView mav = new ModelAndView("home");
mav.addObject("loginAction", getLoginAction());
return mav;
}
public LoginAction getLoginAction() {
return (LoginAction) context.getBean("loginAction");
}
}
Me gustaría poder duplicar upvote que para la implementación de la respuesta correcta en su código para que otros vean la diferencia real –