servlet文件夹下只有一个BaseServlet类;
一.BaseServlet
在实际调用的时候BaseServlet作为其他servlet类的父类使用,在该类中有只有一个service()方法。
使用该类的好处在于,不必为每个方法都写以一个对应的servlet类,可以将多个servlet请求放在一个servlet中进行处理
初级方法:
引用大佬的代码:
public class actionServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//获取请求携带的method方法参数
String methodName = request.getParameter("method");
if("add".equals(methodName)){
add();
}else if("del".equals(methodName)){
del();
}else if("update".equals(methodName)){
update();
}else if("find".equals(methodName)){
find();
}
}
//查询
private void find() {
//执行service层代码
}
//更新
private void update() {
//执行service层代码
}
//删除
private void del() {
//执行service层代码
}
//添加
private void add() {
//执行service层代码
}
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
这样还是很麻烦,所以进化出了进阶级方法如下;
引用大佬的话:
需要让BaserServlet继承于HttpServlet
反射的知识:(从第二步到第四步)
第一步:先获取请求携带的方法参数值
第二步:获取指定类的字节码对象
第三步:根据请求携带的方法参数值,再通过字节码对象获取指定的方法
第四步:最后执行指定的方法
package cn.itcast.servlet;
import java.io.IOException;
import java.lang.reflect.Method;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* BaseServlet用来作为其它Servlet的父类
*
* @author qdmmy6
*
* 一个类多个请求处理方法,每个请求处理方法的原型与service相同! 原型 = 返回值类型 + 方法名称 + 参数列表
*/
@SuppressWarnings("serial")
public class BaseServlet extends HttpServlet {
@Override
public void service(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");//处理响应编码
request.setCharacterEncoding("UTF-8");
/**
* 1. 获取method参数,它是用户想调用的方法 2. 把方法名称变成Method类的实例对象 3. 通过invoke()来调用这个方法
*/
String methodName = request.getParameter("method");
Method method = null;
/**
* 2. 通过方法名称获取Method对象
*/
try {
method = this.getClass().getMethod(methodName,
HttpServletRequest.class, HttpServletResponse.class);
} catch (Exception e) {
throw new RuntimeException("您要调用的方法:" + methodName + "它不存在!", e);
}
/**
* 3. 通过method对象来调用它
*/
try {
String result = (String)method.invoke(this, request, response);
if(result != null && !result.trim().isEmpty()) {//如果请求处理方法返回不为空
int index = result.indexOf(":");//获取第一个冒号的位置
if(index == -1) {//如果没有冒号,使用转发
request.getRequestDispatcher(result).forward(request, response);
} else {//如果存在冒号
String start = result.substring(0, index);//分割出前缀
String path = result.substring(index + 1);//分割出路径
if(start.equals("f")) {//前缀为f表示转发
request.getRequestDispatcher(path).forward(request, response);
} else if(start.equals("r")) {//前缀为r表示重定向
response.sendRedirect(request.getContextPath() + path);
}
}
}
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}
在实际应用中该类作为以一个父类出现,所有的页面请求通过该类处理后,找到其对应的在继承该父类的子类中的方法;
该类的的第三个方法(最后一个try,catch)用来集中处理子类方法中的转发和重定向。
附带大佬的链接:https://blog.csdn.net/u010452388/article/details/80723550