协议是指计算机通信网络中两台计算机之间进行通信所必须共同遵守的规定或规则,超文本传输协议(HTTP)是一种通信协议,它允许将超文本标记语言(HTML)文档从Web服务器传送到客户端的浏览器
 
 
servletRequest是接口,httpServletRequest是实现,但是有些方法是httpServletRequest独有的,比如getSession().。
HttpServletRequest接口是继承自ServletRequest接口的。增加了和HTTP相关的一些方法。而所谓request(在JSP中使用的)其实只是规范中的一个名称而已。它当然是一个对象,但并不是SUN提供的,这是由各个不同的Servlet提供商编写的,SUN只是规定这个类要实现HttpServletRequest接口
 
如果说DOM是javascript与HTML的桥梁,那么servlet就是前端与后端的桥梁,HttpServletRequest和HttpServletResponse就是之间的信使
 
1.Servlet 
    [1] Servlet简介
        > Server + let
        > 意为:运行在服务器端的小程序。
        > Servlet实际上就是一个接口。
            - 狭义上的Servlet,指的就是Servlet接口
            - 广义上的我们认为凡是实现Servlet接口的类,我们都称他是一个Servlet *****
        > Servlet的作用:
            1.接收用户发送的请求
            2.调用其他的java程序来处理请求
            3.根据处理结果,返回给用户一个页面
 
        > Servlet的HelloWorld
            1.创建一个类并实现Servlet接口
            2.在web.xml文件中对Servlet进行配置
                <servlet>
                    <servlet-name>别名</servlet-name>
                    <servlet-class>全类名</servlet-class>
                </servlet>
                <servlet-mapping>
                    <servlet-name>别名</servlet-name>
                    <url-pattern>需要servlet处理的请求地址</url-pattern>
                </servlet-mapping>
 
        > Servlet的三个名字:
            <servlet-name>
                - Servlet的别名,程序员通过别名对Servlet进行配置
            <servlet-class>
                - Servlet的全类名,服务器通过全类名来创建Servlet的实例
            <url-pattern>
                - Servlet映射的请求地址,用户通过该地址访问Servlet
 
    [2] Servlet的生命周期
        > Servlet的生命周期,指Servlet的对象从被创建到被销毁的过程。
        > Servlet的生命周期方法:
            1.构造器:
                - Servlet第一次处理请求时,会调用构造器,来创建Servlet实例。
                - 只会调用一次,Servlet是单例模式,他是以多线程的方式调用service()方法.
                - Servlet不是线程安全,所以尽量不要再service()方法中操作全局变量。
 
            2.init()方法:
                - 构造器调用之后马上被调用,用来初始化Servlet,只会调用一次。
 
            3.service()方法:
                - Servlet每次处理请求时都会调用service()方法,用来处理请求,会调用多次。
 
            4.destroy()方法:
                - Servlet对象销毁前(WEB项目卸载时)调用,用来做一些收尾工作,释放资源。
 
    [3] 相关接口
        ①ServletConfig
            代表:当前Servlet的配置信息,每一个Servlet都有其唯一对应的ServletConfig。
                <servlet>
                    <servlet-name>AServlet</servlet-name>
                    <servlet-class>com.atguigu.servlet.AServlet</servlet-class>
                    <init-param>
                        <param-name>user</param-name>
                        <param-value>root</param-value>
                    </init-param>
                    <init-param>
                        <param-name>password</param-name>
                        <param-value>123123</param-value>
                    </init-param>
                </servlet>
 
            获取:由Tomcat服务器创建,最终作为参数传递到init()方法中,我们可以在init()方法直接使用。
                    当我们通过继承HttpServlet创建Servlet时,由于父类已经实现ServletConfig接口,
                        所以我们可以在Servlet中直接调用ServletConfig的方法。
 
            功能:
                【1】 获取Servlet的别名
                【2】 获取当前Servlet的初始化参数。
                        <init-param>
                            <param-name>user</param-name>
                            <param-value>root</param-value>
                        </init-param>
                        <init-param>
                            <param-name>password</param-name>
                            <param-value>123123</param-value>
                        </init-param>
                【3】 获取当前WEB应用的ServletContext对象。
 
        ②ServletContext
            代表:当前的WEB应用,一个WEB应用对应一个唯一的ServletContext对象,
                  ServletContext对象在项目启动时创建,在项目卸载时销毁。
 
            获取:通过ServletConfig的getServletContext()方法获取。
 
            功能:
                【1】 可以获取整个WEB应用的初始化参数
                    <context-param>
                        <param-name>phone</param-name>
                        <param-value>1388888888</param-value>
                    </context-param>
                【2】 可以获取资源的真实路径(物理路径),主要在文件的上传和下载时使用。
                【3】 可以作为一个域对象在不同的web资源之间共享数据。(下回分解)
 
    [4] GenericServlet
        - 通用Servlet的父类
        - 相比Servlet接口GenericServlet更加简单一些,但是我们最终实际上使用的HttpServlet
 
    [5] HttpServlet
        - HttpServlet继承了GenericServlet,而GenericServlet实现Servlet接口
        - 所以我们可以同构继承HttpServlet来创建一个Servlet。
        - HttpServlet重写service()方法:
            1.在该方法中先将ServletRequest和ServletResponse
                强转为了HttpServletRequest和HttpServletResponse。
            2.然调用重载的service()方法,并将刚刚强转得到对象传递到重载的方法中。
        - 重载service(HttpServletRequest request , HttpServletResponse response)
            1.在方法中获取请求的方式(get或post)
            2.在根据不同的请求方式去调用不同的方法:
                如果是GET请求,则调用doGet(HttpServletRequest request , HttpServletResponse response)
                如果是post请求,则调用doPost(HttpServletRequest request , HttpServletResponse response)
        - 结论:
            当通过继承HttpServlet来创建一个Servlet时,我们只需要根据要处理的请求的类型,来重写不同的方法。
                处理get请求,则重写doGet()
                处理post请求,则重写doPost()
 
 
 
    [6] HttpServletRequest 
        代表:浏览器发送给服务器的请求报文。
        获取:该对象由Tomcat服务器创建,最终作为参数传递到doGet或doPost方法中,我们可以在这两个方法中直接使用。
        功能:
            【1】获取用户发送的请求参数
                request.getParameter("username");
            【2】获取项目的名字(用来设置绝对路径)
                request.getContextPath();
            【3】作为一个域对象,在不同的WEB资源之间共享数据。
            【4】请求的转发
                request.getRequestDispatcher("target.html").forward(request, response);
 
 
    [7] HttpServletResponse
        代表:服务器发送给浏览器的响应报文。
        获取:该对象由Tomcat服务器创建,最终作为参数传递到doGet或doPost方法中,我们可以在这两个方法中直接使用。
        功能:
            【1】响应给浏览器一个网页或者是网页片段(设置的是响应报文的响应体)
                response.getWriter("");
            【2】请求的重定向
                response.sendRedirect("target.html");
 
    转发和重定向:(掌握)
 
                            转发                重定向
        请求的次数:          1                      2
        发生的位置            服务器内部            浏览器
        浏览器地址栏        不改变                改变
        浏览器的感知        不知道                知道   
 
 
    [8] 字符编码
        > 当用户通过表单向Servlet发送中文请求参数时,Servlet获取到内容会产生乱码,
            当Servlet向浏览器响应中文内容时,也会产生乱码。
        > 浏览器和服务器之间通信时,中文内容时不能直接发送的,需要对中文进行编码。
        > 编码:
            - 将字符转换为二进制码的过程叫编码。
        > 解码:
            - 将二进制码转换为普通字符的过程叫解码。
        > 编码和解码所采用的规则我们称为字符集。
 
        > 产生乱码问题的根本原因:
            编码和解码所采用的字符集不同。
 
        > 解决方法:
            统一编码和解码的字符集为UTF-8。
 
        > 常见字符集:
            1.ASCII
            2.ISO8859-1
            3.GBK
            4.GB2312
            5.UTF-8
 
        > 请求编码
            - 请求是浏览器发送给服务器的。
            - 浏览器 --> 服务器
            - 浏览器 编码
                > 浏览器的会自动使用网页的字符集对参数进行编码
                  UTF-8的张三:%E5%BC%A0%E4%B8%89
                  GBK的张三:%D5%C5%C8%FD
 
                > 所以我们只需要统一网页的字符集为UTF-8即可。
 
            - 服务器 解码
                post请求
                    > request解码时默认字符集时iso8859-1,但是iso压根就不支持中文
                    > post请求在servlet中解码,所以我们只需要指定request的字符集即可。
                    > 我们可以通过如下方法,来设置request的字符集:
                        request.setCharacterEncoding("utf-8");
                    > 注意:
                        该方法要在request.getParameter()第一次调用之前调用
 
                get请求
                    > get请求是通过url地址传递请求参数,url中的请求参数将会被Tomcat服务器自动解码。
                    > Tomcat的默认编码是iso8859-1,但是iso压根就不支持中文,所以必然乱码。
                    > 只需要修改Tomcat的解码的默认字符集,修改配置文件server.xml
                    > 在server.xml的Connector标签中(改端口号的那个标签)添加如下属性:
                        URIEncoding="utf-8"
                    > 修改完配置文件以后,get请求的编码就不用再处理的,但是post请求还是老样子。
 
        > 响应编码
            - 响应是服务器发送给浏览器
            - 服务器 --> 浏览器
            - 服务器 编码
                > 指定服务器的编码字符集为UTF-8。
                > 指定response的字符集
                    response.setCharacterEncoding("utf-8");
                > 虽然我们已经指定了response的字符集为utf-8,但是浏览器并不是用utf-8解码。
                    浏览器默认使用gb2312解码的,所以依然乱码,只不过没有那么乱。
 
            - 浏览器 解码
                > 浏览器的解码字符集可以通过浏览器来设置(不靠谱)
                > 我们可以通过服务器来告诉浏览器,我们的内容的编码格式为utf-8
                > 我们可以通过一个响应头来告诉浏览器,内容的编码格式:
                    Content-Type:text/html;charset=utf-8
                > 通过response的方法,来设置响应头:
                    response.setHeader("Content-Type", "text/html;charset=utf-8");
 
            解决方案:
                1.设置响应头
                    response.setHeader("Content-Type", "text/html;charset=utf-8");
                2.设置response的编码格式
                    response.setCharacterEncoding("utf-8");
 
                > 当我们设置Content-Type这个响应头时,服务器会自动使用响应头中的字符集为内容编码。
 
                > 最终方案:
                    response.setContentType("text/html;charset=utf-8");
 
        总结:
            post请求:
                - 在request.getParameter()方法第一次调用之前,调用如下代码:
                    request.setCharacterEncoding("utf-8");
            get请求:
                - 修改server.xml配置文件
                - <Connector URIEncoding="utf-8" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
 
            响应:
                - 设置一个Content-Type响应头
                    response.setContentType("text/html;charset=utf-8");
 
 
 
 
    [9] 路径问题
        > URI和URL
            - URL是URI的一种实现,也是URI最常见的实现方式。
            - URI有两种实现方式URL和URN,URN用的很少
            - 我们说URL和URI实际上可以理解为一个意思
 
        > URL地址的格式
            http://主机名:端口号/项目名/资源路径/资源名
 
        ①相对路径和绝对路径
            > 相对路径
            - 之前我们使用的路径全都是相对路径:
                - 所谓的相对路径指相对于当前资源所在路径:
                    http://主机名:端口号/项目名/资源路径/
            - 由于转发的出现,相对路径会经常发生变化,容易出现错误的链接
                所以在开发中我们一般不使用相对路径,而是使用绝对路径。
 
            > 绝对路径
            - 绝对路径使用/开头   
            - 由浏览器解析的绝对路径中的/代表的是服务器的根目录:
                http://主机名:端口号/
                注意:需要加上项目名
 
            - 由服务器解析的绝对路径中的/代表的项目的根目录:
                http://主机名:端口号/项目名/
                注意:不要加项目名
 
            - 转发的路径由服务器解析,设置绝对路径时不需要加项目名
            - 重定向的路径由浏览器解析,设置绝对路径时需要加上项目名
 
 
        ②常见的路径:
            url-pattern:
            转发的路径:
                - url-pattern和转发中的路径都是由服务器解析的,
                    根目录是项目的根目录:
                        http://主机名:端口号/项目名/
                - 所以这两个路径不需要加项目名
 
            重定向的路径:
            页面中的路径:
                - 重定向和页面中的路径(HTML标签中的路径),由浏览器解析的,
                    根目录是服务器的根目录:
                        http://主机名:端口号/
                - 所以这个两个路径必须加上项目名
 
 

http协议与servletl理解的更多相关文章

  1. HTTP协议是无状态协议,怎么理解

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp24 HTTP协议是无状态协议,怎么理解?  2010-02-23 09:4 ...

  2. 从C#到Objective-C,循序渐进学习苹果开发(3)--分类(category)和协议Protocal的理解

    本随笔系列主要介绍从一个Windows平台从事C#开发到Mac平台苹果开发的一系列感想和体验历程,本系列文章是在起步阶段逐步积累的,希望带给大家更好,更真实的转换历程体验.本文继续上一篇随笔<从 ...

  3. 四:分布式事务一致性协议paxos通俗理解

    转载地址:http://www.lxway.com/4618606.htm 维基的简介:Paxos算法是莱斯利·兰伯特(Leslie Lamport,就是 LaTeX 中的"La" ...

  4. HTTP协议是无状态协议,怎么理解?

     Http是一个无状态协议,同一个会话的连续两个请求互相不了解,他们由最新实例化的环境进行解析,除了应用本身可能已经存储在全局对象中的全部信息外,该环境不保存与会话有关的不论什么信息. 自己的理解,在 ...

  5. 前端教程(1)http协议的深刻理解

    一 HTTP协议简介 作为学习前端开发的开始,我们必须搞明白以下几件事 1.什么是互联网      互联网=物理连接介质+互联网协议     2.互联网建立的目的? 数据传输打破地域限制,否则的话,我 ...

  6. 对Http协议基本原理的理解

    超文本传输协议 超文本传输协议(HTTP,HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络传输协议,所有的WWW文件都必须遵守这个标准.设计HTTP最初的目的是 ...

  7. TCP/IP网络协议的通俗理解,SOCKET,HTTP,SOAP

    TCP/IP,HTTP,SOAP等协议之区别   术语TCP/IP代表传输控制协议/网际协议,指的是一系列协议.“IP”代表网际协议,TCP和UDP使用该协议从一个网络传送数据包到另一个网络.把IP想 ...

  8. 浅谈对【OSI七层协议】的理解

    我们每天都在上网冲浪,在这背后到底有那些设备.协议去支撑呢?ISO是[Open System Interconnection]的缩写,该模型定义了不同计算机互联的标准,是设计和描述计算机网络通信的基本 ...

  9. 关于TCP\IP协议的简单理解

    一: HTTP是基于TCP协议的,TCP属于传输层.HTTP属于应用层. 另一个属于传输层的是UDP协议. 但HTTP是基于TCP这个协议,不是UDP这个协议. TCP相比于UDP,更安全,稳定.因为 ...

随机推荐

  1. jquery对于ajax的封装

    第一层封装 $.ajax({ 属性名:值,属性名:值}) /* url: 请求服务器地址 data:请求参数 dataType:服务器返回数据类型 error 请求出错执行的功能 success 请求 ...

  2. DNS配置-BIND安装配置全过程

    下载地址:ftp://ftp.isc.org/isc/ 下载bind,我下载的是bind-9.11.13.tar.gz 我下载的文件放在/root目录下进入目录解压缩 [root@localhost ...

  3. java笔试之求最大连续bit数

    功能: 求一个byte数字对应的二进制数字中1的最大连续数,例如3的二进制为00000011,最大连续2个1    输入: 一个byte型的数字    输出: 无     返回: 对应的二进制数字中1 ...

  4. springcloud Eureka Finchley.RELEASE 版本

    创建一个父项目cloud-demo pom.xml <?xml version="1.0" encoding="UTF-8"?> <proje ...

  5. 笔记:使用Python解析JSON

    使用Python解析JSON json是一种轻量级的数据交换格式,易于阅读和编写. json函数具体作用描述 函数 具体描述作用 json.dumps 将python对象编码为JSON字符串 json ...

  6. crontab中反引号和$()无效的解决

    问题描述 1.增加了一条crontab,删除本月中2天以前的日志 10 02  * * * /bin/find /data/logs/php/$(date  +%Y%m)/ -mtime +2 | x ...

  7. 微信小程序前后台调用

    // pages/ruquestexer/index.js Page({ /** * 页面的初始数据 */ data: { }, getUserData:function(){ wx.request( ...

  8. 在js中使用Razor

    @foreach (var tem in Model) { <text> time.push("@tem.CreateTime.ToString("G")&q ...

  9. thinkphp 快捷查询

    快捷查询方式是一种多字段查询的简化写法,可以进一步简化查询条件的写法,在多个字段之间用|分割表示OR查询,用&分割表示AND查询,可以实现下面的查询,例如: 大理石平台价格 一.不同字段相同的 ...

  10. laravel中如何使用Redis(Redis是什么)

    laravel中如何使用Redis(Redis是什么) 一.总结 一句话总结: 基于内存亦可持久化键值数据库 Redis是完全开源免费的,遵守BSD协议,是一个高性能的键值数据库.是当前最热门的的的N ...