天天看点

关于itcast-tools工具包的详解。3.(servlet)一.BaseServlet初级方法:

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

继续阅读