servlet基础

作者: Dylan666666 | 来源:发表于2019-07-24 12:09 被阅读0次

    简介:

    servlet 是运行在Web服务器中的小型 java 程序。servlet 通常通过 HTTP(超文本传输协议)接收和响应来自Web客户端的请求。也就是说,Servlet 是由我们自己来完成的! 但Servlet一定要实现 java.servlet.Servlet 接口,并且还要在 web.xml 文件中部署!不然 Tomcat 是找不到我们写的Servlet 的。

    五大方法:

    /**

        * 当Servlet实例被创建的时候被调用,做初始化工作

        *ServletConfig:Servlet的配置对象,初始化的时候进行配置

        */

        @Override

        public void init(ServletConfig servletConfig) throws ServletException {

        }

        /**

        *获得ServletConfig的配置对象

        */

        @Override

        public ServletConfig getServletConfig() {

            return null;

        }

        /**

        * 当一个请求来请求当前的Servlet的时候被调用

        * 处理当前的Servlet的业务逻辑并且把相应的返回给浏览器

        */

        @Override

        public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {

        }

        /**

        *获取当前的Servlet的一些属性信息(了解)

        */

        @Override

        public String getServletInfo() {

            return null;

        }

        /**

        * 是Servlet的实例对象被销毁的时候调用

        * 做一些收尾或清理的工作

        */

        @Override

        public void destroy() {

        }

    注意:

    servlet 容器仅在实例化 servlet 之后调用 init 方法一次 ; 在 servlet 可以接收任何请求之前,init 方法必须成功完成。

    service(req,res) 方法仅在 servlet 的 init() 方法成功之后调用。

    destroy() 方法仅在 service 方法已退出或者在过了超时期之后调用一次,调用此方法以后,servlet 容器不会再对此 servlet 调用 service方法

    destroy() 方法为 servlet 提供了一个清除持有的所有资源(比如内存,文件句柄和线程)的机会,并确保任何持久状态都与内存中该servlet 的当前状态保存同步。

    servlet生命周期

    从第一次调用到服务器关闭

    如果 servlet在web.xml中配置了 load-on-startup (配置的数字代表调用顺序),生命周期从服务器启动到服务器关闭

    注意:init 方法是对 servlet 进行初始化的一个方法,会在 servlet 第一次加载进行存储时执行

    destory 方法是在servlet被销毁时执行,也就是服务器关闭时

    service方法和doGet方法和doPost方法的区别

    service 方法:可以处理 get/post 方法的请求,如果 servlet 中有 service方法,会优先调用 service方法对请求进行处理。

    doGet 方法: 处理get方式的请求

    doPost 方法:处理post方式的请求

    注意:如果覆写的 service 方法中调用了父类的 service 方法(super.service(arg0,arg2)),则service 方法处理完后会再次根据请求方式响应 doGet 和 doPost 方法执行。所以,一般不调用此父类方法,避免出现405错误。

    servlet常见错误:

    404错误:资源为找到

      原因一:在请求地址中的 servlet 的别名书写错误

      原因二:虚拟项目名称拼写出错误

    500错误:

    ① java,lang.ClassNotFoundException

      解决: 在web.xml中校验路径是否拼写错误

    ② 逻辑错误 (例如除以0类型)

      解决: 根据具体错误去更改

    405错误: 请求方式不支持

      原因:请求方式和 servlet 中的方法不匹配造成

      解决:尽量使用 service 方法进行请求处理,并且不要在service 方法中调用父类的 service

    request对象学习:

    作用:request 对象中封存了当前请求的所有请求信息

    作用: 获取请求头数据 – 获取请求行数据 – 获取用户数据

    注意: request对象由 tomcat 服务器创建,并作为实参传递给处理请求的 servlet 的 service方法

    response对象学习

    作用:用来响应数据到浏览器的一个对象

    使用:

    ①设置响应头

      resp.setHeader("mouse","two elephents");      // 在响应头中添加响应信息,但同键会覆盖

      resp.addHeader("key","do"); //在响应头中添加响应信息,但是不会覆盖

    ②设置响应状态

      resp.sendError(405,"this is a joke");    //自定义响应状态码

    ③设置响应实体

      resp.getWrite().write(" this is resp study");      //响应具体数据给服务器

    ④设置响应编码格式

      resp.setContentType("text/html;charset = utf-8");

      resp.getWriter().write("<h1> this is resp study </h1>");

    service请求处理代码流程:

    设置响应编码格式

    获取请求数据

    处理请求数据

    数据库操作(MVC)

    响应处理结果

    请求乱码问题解决

    使用String进行重新编码:

      uname = new String(uname.getBytes("iso8859-1"),"utf-8");

    Get 方式请求:

      在 service 方法中使用:req.setCharacterEnCoding("utf-8");

      在tomcat服务器目录下的conf文件找到server.xml文件,在端口号=“8080”,protocol="HTTP/.1.1"那一栏,最后加上 useBodyEncodingForURI="true"

    Post方式请求:

      在service方法中使用:req.setCharacterEncoding("utf-8");

    servlet流程总结:

    浏览器发送请求到服务器(请求)

    服务器接收浏览器的请求,创建request对象存储请求数据

    服务器调用对应的servlet进行请求处理,并将request对象作为实参传递给Servlet的方法进行请求处理

    设置请求编码格式–>>设置响应编码格式–>>获取请求信息–>>处理请求信息–>>创建业务层对象–>>调用业务层对象的方法–>>响应处理结果

    请求转发学习:

    作用:实现多个servlet联动操作处理请求,这样避免代码冗余,让servlet的职责更加明确

    使用:req.getRequestDispatcher(“地址”).forward(req,resp); 地址:相对路径

    特点:一次请求,浏览器地址栏信息不改变

    注意:请求转发后直接 return 结束即可。

    使用request对象的作用域:

    使用 : request.setAttribute(object name,Object value); request.getAttribute(Object obj)

    作用: 解决了一次请求内的不同Servlet的数据共享问题。

    作用域:基于请求转发,一次请求中的所有 servlet 共享。

    注意:使用 Request 对象进行数据流转,数据只有一次请求内有效。

    特点: 服务器创建------每次请求都会创建------生命周期只有一次请求

    重定向:

    解决了表单重复提交的问题,以及当前的servlet无法处理的请求的问题

    使用: resp.sendRedirect(String uri);

    示例:resp.sendRedirect("/ServletLogin005_war_exploded/main");

    特点:两次请求,两个request对象 — 浏览器地址栏信息改变 —

    时机:如果请求中有表单数据,而数据又比较重要,不能重复提交,建议使用重定向。

    如果请求被servlet接收后,无法进行处理,建议使用重定向到可处理的资源。

    Cookie学习

    作用:解决了发送的不同请求的数据共享问题

    使用: Cookie的创建和存储

      // 创建 Cookie 对象

      Cookie c = new Cookie(String name,String value);

      //设置 cookie (可选)

      //设置有效期

      c.setMaxAge(int seconds);

      //设置有效路径

      c.setpath(String uri);

      // 响应 Cookie 信息给客户端

      resp.addCookie(c);

    Cookie的获取

      // 获取Cookie信息数组

      Cookie[] cks = req.getCookies();

      // 遍历数组获取Cookie信息

      使用for循环遍历即可:

    if(cks != null)

    {

    for (Cookie c : cks) {

    String name = c.getName();

    String value = c.getValue();

    System.out.println(name + “:” + value);

    }

    }

    注意: 一个Cookie对象存储一条数据。多条数据,可以多创建几个Cookie对象进行存储

    特点:

    ---- 浏览器端的数据存储技术

    ---- 存储的数据声明在服务器

    ---- 临时存储:存在浏览器内存中,浏览器关闭即失效

    ---- 定时存储:设置了 Cookie 的有效期,存储在客户端的硬盘里面

    ---- 默认cookie信息存储好之后,每次请求都会附带,除非设置有效路径

    相关文章

      网友评论

        本文标题:servlet基础

        本文链接:https://www.haomeiwen.com/subject/lffxrctx.html