1 – @RequestMapping
表单数据的提取 :
此处是 jsp中的表单代码 ,需要在后端代码中获取输入的 name参数
<form action="/map">
name<input type="text" name ="name"><br/>
<input type="submit">
</form>
此处为后端的代码 ,通过 注解 (requestparam(“str”)获取 前端数据 —str 为 前端表单中的 name 属性 )
@RequestMapping(value = "map")
public String loginmap(@RequestParam("name") String name ,ModelMap m){
System.out.println(name);
m.put("name",name);
return "success";
}
2-- ModelAndView
如果在后端需要同时处理 数据 与 视图(model view)时 就可以是用 modelandview
控制器的 类型要是 ModelAndView 。
处理视图信息–ModelAndView mv =new ModelAndView("success");
此处的 success 就是 要跳转的 页面信息。
当然 这个 页面信息 也会在视图解析中 增加定义的前后缀
<!-- 视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!--增加前缀-->
<property name="prefix" value="/view/"/>
<!--增加后缀-->
<property name="suffix" value=".jsp"/>
</bean>
处理数据 (model)
使用 addObject 方法即可
mv.addObject("sss" ,student);
类似modelandview 的方法 还有 使用 map modelmap 等
但是 返回的是 String 代表 页面的信息 ,使用 map.put 将数据放入request 域中
3–@ModelAttribute
此属性不会单独使用 一般是用于 一个修改功能中
修改 的过程 分为两步 1. 获取 对象 2. 对该对象修改
本注释 就是用于 第一步 获取对象的
具体使用
@ModelAttribute
public void querystu(Map<String,student> map, @RequestParam("name") String name){
// 模拟查询
student student =new student(name);
System.out.print(student.getName()+" ------ "+ student.getId()+" ----------" + student.getAddress());
map.put("stu",student);
}
此处的代码 接受 了 前端的 name 属性的值 ,对其进行模拟查询 – student 然后将其 放入 map即可
第二步 修改
@RequestMapping(value = "welcomeModelAndViewquerrystud")
public ModelAndView loginnn(@ModelAttribute("stu") student student){
System.out.print(student.getName()+" ------ "+ student.getId()+" ----------" + student.getAddress());
ModelAndView mv =new ModelAndView("success");
mv.addObject("sss" ,student);
return mv;
}
此处 通过 @ModelAttribute("stu") student student
获取 了第一步找中的stu的对象 赋值给 student
然后进行操作
在一个类中 ,只要有方法被 @ModelAttribute 修饰了, springmvc就会自动的先执行它 ,然后 再 根据 @RequestMapping 进行操作 。所以 该示例 中 一定会先得到 一个 student对象
4–@SessionAttributes
将 对象 加入到 session 域中 — 对于登录验证 一般 与 拦截器一起 作用
@SessionAttributes("username")
@RequestMapping(value = "userlogin.action")
public ModelAndView userlogin(@RequestParam("name") String username ){
// session.setAttribute("username",username);
// System.out.println("username is "+ session.getAttribute("username"));
ModelAndView mv =new ModelAndView( "success");
System.out.println("username is "+username);
mv.addObject("username",username);
// return "success";
return mv;
}
此处 就将 username 对象加入到了 session域中
5-- 拦截器
首先在xml中对其进行配置
使用 mvc:interceptors 标签
<!--配置拦截器 -->
<mvc:interceptors>
<mvc:interceptor>
<!--所有路径都拦截-->
<mvc:mapping path="/**"/>
<bean class="Interceptor.myInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
拦截器的部分代码
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object o) throws Exception {
//判断 是不是登录界面 login
if(!request.getRequestURI().contains("/userlogin")){
System.out.println( request.getRequestURI() );
String name = (String )request.getSession().getAttribute("username");
if(name== null){
System.out.println(" 名字为空 ");
//转发?到登录界面
response.sendRedirect("/view/login.jsp");
return false;//不放行
}
}
return true;
}
当 获取到 当前的 uri 中不包含 /login 且 session中不包含 username 时 就会 拦截本次的请求 ,将其转发 到 登录界面
<form action="/userlogin.action">
name<input type="text" name ="name"><br/>
<input type="submit">
</form>
登录界面 --后端处理 获取name ,将其 添加到 session中
@RequestMapping(value = "userlogin.action")
public ModelAndView userlogin(@RequestParam("name") String username ){
ModelAndView mv =new ModelAndView( "success");
System.out.println("username is "+username);
mv.addObject("username",username);
return mv;
}
此时 session域中的username 不为空 拦截会对其放行 ,进入 success界面