介绍
方法动态调用核心类
org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver
正在学习SpringMVC,感觉这个很重要。
前台访问后台会根据spring的配置文件转到Controller
Controller类有两种方法
1,implements Controller(实现Controller接口)
2,extends MultiActionController(继承 MultiActionController)
但是实现接口有缺陷,只能写一种方法(handleRequest),不太好利于外面使用,
所以一般都会采用第二种方法
操作导包
核心类都是spring的,所以需要导包
配置文件编写
核心代码
在配置文件中,当需要实现访问controller里面的多个函数时,就需要将这个核心类注入
<!-- 为多个方法调用时,进行解析 -->
<bean id="methodNameResolver" class="org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">
<property name="defaultMethodName" value="execute"></property><!-- 不带method参数时,默认执行execute方法 -->
<property name="paramName" value="method"></property>
</bean>
<bean name="/two" class="cn.hncu.controller2.MyController2"><!-- 在前台直接请求路径为拦截路径+/two 在我的这个里面拦截的是/sp/*,所以请求路径是 项目名/sp/two -->
<!-- 必须注入这个属性,在多个方法调用时需要解析 -->
<property name="methodNameResolver" ref="methodNameResolver"></property>
</bean>
当然完整的配置文件需要多个核心了的,如:加载配置文件核心类,处理url影射核心类,ResourceBundleViewResolver等
具体的配置文件如下:
<!-- 单个方法,实现Controller -->
<bean name="/hello" class="cn.hncu.controller.MyController"></bean>
<!-- 当controller没有配置到相应的servlet中时,我们需要采用映射url地址 -->
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"></bean>
<!-- 转发的时候我们写配置文件properties,一般必须要求 -->
<bean class="org.springframework.web.servlet.view.ResourceBundleViewResolver">
<property name="basenames">
<list><!-- 默认查询属性文件为hncu的配置文件classpath目录下 -->
<value>hncu</value><!-- 这是资源的名字 ,让controller中返回的值在这个文件里面找相应的路径和类型->
</list>
</property>
<!-- 写这个默认之后,我们properties文件中就不用写同样的类型 jstlview 了 -->
<property name="defaultParentView" value="abc"></property>
</bean>
<!-- 为多个方法调用时,进行解析 -->
<bean id="methodNameResolver" class="org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">
<property name="defaultMethodName" value="execute"></property><!-- 不带method参数时,默认执行execute方法 -->
<property name="paramName" value="method"></property>
</bean>
<bean name="/two" class="cn.hncu.controller2.MyController2"><!-- 在前台直接请求路径为拦截路径+/two 在我的这个里面拦截的是/sp/*,所以请求路径是 项目名/sp/two -->
<!-- 必须注入这个属性,在多个方法调用时需要解析 -->
<property name="methodNameResolver" ref="methodNameResolver"></property>
</bean>
Controller类里面编写
上面的配置只是前台传过来,可以访问多个方法了,但是函数的编写也是有规则的
/*处理规则:
* 空参方法是不行的,SpringMVC要求必须至少带以req,resp开始的两个参数
* 返回值任意,但是会影响相应显示结果
*/
package cn.hncu.controller2;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;
public class MyController2 extends MultiActionController{
//这样就可以指定调用我们方法,而不是唯一的
/*处理规则:
* 空参方法是不行的,SpringMVC要求必须至少带以req,resp开始的两个参数
* 返回值任意,但是会影响相应显示结果
*/
//空参数访问不到的
public void one(){
System.out.println("aa");
}
public void two(HttpServletRequest req,HttpServletResponse reps){
System.out.println("bb");
}
//必须要带以req和resp开头的参数,否则404错误
public String three(HttpServletRequest req,HttpServletResponse reps){
System.out.println("进来了"+req.getParameter("name"));
return "abc";
}
//在前台不带method的方法名时候,就会默认的调用这个。这个是在配置文件里面配置的
public void execute(HttpServletRequest req,HttpServletResponse reps){
System.out.println("进入默认了");
}
//封装信息,返回到前台。
//一般这种返回都是ModelAndView====》前面是数据,后面是显示的页面
public ModelAndView four(HttpServletRequest req,HttpServletResponse reps,User user){
ModelAndView mv =new ModelAndView();
mv.setViewName("xyz");//当返回之后会进入配置文件(控制器),由ResourceBundleViewResolver进行解析
System.out.println(user);//在这里,当前台的封装数据的属性名一致,spring就可以自动封装数据
mv.addObject("user", user);//这样返回,就可以去前台读取,本质是存放在request容器里面的
return mv;
/*
* 在这里,我们采用的这种他封装之后的方法是可以的,但是我们也可以采用最原始的servlet来写
* 因为有了req和resp(必须要求带这两个参数),就可以对底层的servlet进行操作了
* //req.setAttribute("name", user.getName());
//req.setAttribute("user", user);
*/
}
}
请求路径:在前台直接请求路径为拦截路径+/two 在我的这个里面拦截的是/sp/*,所以请求路径是 项目名/sp/two?method=three? name=""&age=""......
总结:
要想可以访问多个函数,就必须要配置ParameterMethodNameResolver到配置文件中去,注意相应的参数,当然要想能够访问controller中的函数,函数必须要求必须至少带以req,resp开始的两个参数,返回值可以随意。
springMVC的访问路径图