java - servlet中,关于HttpServlet 的 service 方法的问题
阿神
阿神 2017-04-17 16:11:09
[Java讨论组]

我看的参考书是Budi Kurniawan的《Servlet和JSP学习指南》,其中关于httpservlet的一段没看明白:

与往常一样,Servlet容器调用javax.servlet.Servlet中原始的service方法,HttpServlet中的service方法要如下这么写:

public void service(ServletRequest req, ServletResponse resp)
        throws ServletException, IOException {
    HttpServletRequest request = req;
    HttpServletResponse response = resp;
    try {
        request = (HttpServletRequest) req;
        response = (HttpServletResponse) resp;
    } catch (ClassCastException e) {
        throw new ServletException("non-HTTP request or resonse");
    }
    service(requset, response);
}

原始的service方法将请求和相应对象进行向下转换,分别从Servlet容器转换成HttpServletRequestHttpServletResponse,并调用新的service方法。向下转型总是成功,因为在调用一个Servletservice方法时,Servlet容器总会预计使用HTTP,所以传递一个HttpServletRequestHttpServletResponse

最后一句没有太明白。原文的意思是不是就算我没有使用HttpServlet,Servlet容器传递给service方法的requestresponse对象也是HttpServletRequestHttpServletResponse的实例,即使这个service方法的参数是ServletRequestServletResponse

阿神
阿神

闭关修行中......

全部回复(2)
迷茫

是的,因为HttpServletRequest对象是ServletRequest对象的实现类。
传递进去的就是该实现类的实例

迷茫

首先,Servlet API是一套标准,真正的实现是由Servlet容器(比如Tomcat、Jetty)来实现,Servlet标准是用来约定Servlet容器都得按它的套路来实现。就像国家制定标准电压是220V一样,所有的电器都要根据220V的电压来造。(但是也有例外,比如JFinal,它属于不听话不按标准来的。)

要想理解你的问题,例如为什么有HttpServletRequest、ServletRequest这样两个interface,首先要知道Servlet API标准制定的时候是怎么想的。

实际上Sun在制定Servlet API标准的时候是野心勃勃的,它不甘心只做一套HTTP协议的标准,也就是他想让Servlet兼容更多的网络协议,想要统治全世界。所以就有Servlet、ServletRequest、ServletResponse这样的API,这样的API跟具体协议无关,而HttpServlet、HttpServletRequest、HttpServletResponse就是具体HTTP协议的实现类或子接口。

不过到目前为止,Servlet API就只有HTTP协议这一套实现,并没有统治全世界的所有网络协议。只能说是理想很丰满,现实很骨感。

同样类似的还有jsp第一行的<%@ page language="java" ... %>,为什么要加上language="java",貌似是想统治全世界的所有编程语言,让其他语言也实现jsp标准,language="php"language="python"。然后就没有然后了。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号