Java 如何在JSP中显示对象的数据
我通过注册表将一些用户详细信息存储到db(hibernate和spring)中。我想在一个单独的JSP页面中显示所有用户的详细信息。有人能告诉我怎么做吗 下面是我的控制器代码Java 如何在JSP中显示对象的数据,java,spring,hibernate,jsp,Java,Spring,Hibernate,Jsp,我通过注册表将一些用户详细信息存储到db(hibernate和spring)中。我想在一个单独的JSP页面中显示所有用户的详细信息。有人能告诉我怎么做吗 下面是我的控制器代码 @Controller public class RegisterController { @Autowired private UserDao userDao; @RequestMapping(value = "/registerForm.htm", method = RequestMetho
@Controller
public class RegisterController {
@Autowired
private UserDao userDao;
@RequestMapping(value = "/registerForm.htm", method = RequestMethod.GET)
public ModelAndView registerPage(ModelMap map) {
User user = new User();
map.addAttribute(user);
return new ModelAndView("registerForm", "command", user);
}
@RequestMapping(value = "/registerProcess.htm", method = RequestMethod.POST)
public ModelAndView registerUser(@ModelAttribute("user") User user, Model model) {
model.addAttribute("userName", user.getUserName());
model.addAttribute("password", user.getPassword());
model.addAttribute("emailId", user.getEmailId());
System.out.println("user is " + user);
System.out.println("userdao is" + userDao);
userDao.saveUser(user);
return new ModelAndView("registerProcess", "user", user);
}
}
userdao中的代码
public void saveUser(User user) {
Session session=getSessionFactory().openSession();
Transaction tx;
tx=session.beginTransaction();
session.persist(user);
tx.commit();
}
编写另一个方法来获取所有用户,然后将检索到的用户列表存储在模型对象中,然后在JSP中使用JSTL forEach标记来显示用户,您可以使用此链接查看如何使用JSTL forEach循环在JSP上显示数据:您应该获得要在get请求中向用户显示的元素。这包括以下步骤:
- 具有适当的URL映射和视图以处理GET
- 获取将预处理URL的方法中的数据
- 将要显示给用户的数据存储为请求属性
- 转发到视图(JSP)
- 在视图中,显示来自请求属性的数据
@Controller
public class RegisterController {
@Autowired
private UserDao userDao;
@RequestMapping(value="/registerForm.htm",method=RequestMethod.GET)
public ModelAndView registerPage(ModelMap map){
User user=new User();
map.addAttribute(user);
return new ModelAndView("registerForm","command",user);
}
@RequestMapping(value="/registerProcess.htm",method=RequestMethod.POST)
public ModelAndView registerUser(@ModelAttribute("user") User user,Model model){
model.addAttribute("userName", user.getUserName());
model.addAttribute("password", user.getPassword());
model.addAttribute("emailId",user.getEmailId());
System.out.println("user is "+user);
System.out.println("userdao is"+userDao);
userDao.saveUser(user);
return new ModelAndView("registerProcess","user",user);
}
//this is the new method with proper mapping
@RequestMapping(value="/userList.htm", method=RequestMethod.GET)
public ModelAndView registerPage(ModelMap map) {
//this method should retrieve the data for all users
List<User> userList = userDao.getAllUsers();
map.addAttribute("userList", userList);
return new ModelAndView("userList", map);
}
}
@控制器
公共类注册控制器{
@自动连线
私有UserDao UserDao;
@RequestMapping(value=“/registerForm.htm”,method=RequestMethod.GET)
公共模型和视图注册表页(模型地图){
用户=新用户();
map.addAttribute(用户);
返回新的ModelAndView(“registerForm”、“command”、user);
}
@RequestMapping(value=“/registerProcess.htm”,method=RequestMethod.POST)
公共模型和视图注册器(@modeldattribute(“用户”)用户,模型模型){
model.addAttribute(“userName”,user.getUserName());
model.addAttribute(“password”,user.getPassword());
model.addAttribute(“emailId”,user.getEmailId());
System.out.println(“用户为”+用户);
System.out.println(“userdao是”+userdao);
userDao.saveUser(用户);
返回新的ModelAndView(“registerProcess”、“user”、user);
}
//这是具有适当映射的新方法
@RequestMapping(value=“/userList.htm”,method=RequestMethod.GET)
公共模型和视图注册表页(模型地图){
//此方法应检索所有用户的数据
List userList=userDao.getAllUsers();
addAttribute(“userList”,userList);
返回新的ModelAndView(“用户列表”,映射);
}
}
然后,在userList.jsp中:
用户列表
用户名单:
${user.userName}
请注意,这是一个关于如何执行此操作的非常基本的示例。代码可以大大改进
更多信息:
列表
。您可以设置所需的任意多个变量。但如果数据已经存储在对象中,则存储该对象,而不是单独存储数据。其余的请阅读