Chcę użyć adnotowanej fasoli prototypowej w moim kontrolerze. Ale wiosna tworzy zamiast tego pojedynczą fasolę. Oto kod, który:@ Beope ("prototyp") zakres komponentu bean nie tworząc nowego komponentu 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);
}
}
kod Kontroler:
@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;
}
}
Velocity szablon:
LoginAction counter: ${loginAction.str}
Wiosna config.xml
ma skanowanie komponentu włączone:
<context:annotation-config />
<context:component-scan base-package="com.springheat" />
<mvc:annotation-driven />
Za każdym razem otrzymuję inkrementowaną liczbę. Nie mogę się domyślić, co się dzieje źle!
Aktualizacja
Jak suggested by @gkamal, zrobiłem HomeController
webApplicationContext
-aware i to rozwiązało problem.
zaktualizowany kod:
@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");
}
}
Chciałbym podwoić upvote ciebie za wdrażanie poprawną odpowiedź w Twój kod dla innych, aby zobaczyć rzeczywistą różnicę –