Servlet学习

Java Servlet 是运行在 Web 服务器或应用服务器上的程序,它是作为来自 Web 浏览器或其他 HTTP 客户端的请求和 HTTP 服务器上的数据库或应用程序之间的中间层。
使用 Servlet,可以收集来自网页表单的用户输入,呈现来自数据库或者其他源的记录,还可以动态创建网页。

1.使用IDEA搭建一个简易的servlet程序(IDEA配置Tomcat)

url

2.开发Servlet方法

2.1 实现 Servlet 接口

public class Hello implements Servlet{

    //用于初始化该servlet()
    //只被调用一次(第一次访问被调用)
    @Override
    public void init(ServletConfig servletConfig) throws ServletException {
        System.out.println("init it!");
    }

    @Override
    public ServletConfig getServletConfig() {
        return null;
    }

    //用于处理业务逻辑(每次访问都被调用)
    //req: 用于获得请求
    //res: 用于返回信息
    @Override
    public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {

        //控制台打印
        System.out.println("service it!");

        //浏览器打印
        PrintWriter pw = res.getWriter();
        pw.println("Hello World!");
    }

    @Override
    public String getServletInfo() {
        return null;
    }

    //释放内存
    @Override
    public void destroy() {

        //控制台打印
        System.out.println("destroy it!");

    }
}

2.2 继承 GenericServlet 类(重写 service()方法)

public class HelloGen extends GenericServlet{

    //重写 service方法即可
    @Override
    public void service(ServletRequest req, ServletResponse res) {
        //返回Hello World! Generic
        try{
            PrintWriter pw = res.getWriter();
            pw.println("Hello World! Generic!");
        }catch (Exception ex){
            ex.printStackTrace();
        }
    }
}

2.3 继承 HttpServlet 类(重写doGet() 和 doPost()方法)

  1. 表单提交数据get请求post请求的区别
  • 安全性
  • 提交内容大小
  • 相应速度
  1. 405错误解决及各种http状态码总结
    链接

3.Servlet配置信息(配置web.xml)

  • 每添加一个servl都需要在这里进行注册

    Hello
    Hello



    Hello
    /Hello

4.同一用户的不同页面共享数据

4.1 cookie

  1. 是服务器在客户端保存用户的信息
  2. 存在有效时间,超过时间则Cookie失效

4.1.1 cookie使用

//创建一个Cookie(在服务器端创建)
Cookie c = new Cookie(String name, String val);

//设置Cookie保存时间(保存30秒),不设置则不会保存
c.setMacAge(30);


//将一个Cookie添加到客户端
response.addCookie(c);

//从客户端读取Cookie到服务器
request.getCookie();

4.2 sendRedirect跳转

sendRedirect("LoginWel?uname=demo&passwd=123456");   //LoginWel为servlet url

req.getParameter("uname");  //对应的跳转页面通过此方法获取变量

4.3 Session技术

  • 每打开一个浏览器,既在服务器产生一个唯一的session
  • 该技术不建议使用存放太多数据,会消耗服务器内存
HttpSession hs = req.getSession(true);      //得到session

hs.setAttribute(String name, Object val);   //向session添加属性

String name = hs.getAttribute(String name); //从session得到某个属性

hs.removeAttribute(String name);            //从session删除某个属性

4.4 隐藏表单提交(form)

4.5 Cookie和Session比较

  1. 存放位置
  2. 安全性
  3. 网络传输量
  4. 生命周期
    cookie生命周期是累计的,而session的生命周期是间隔的
    关机造成session生命周期结束,而对Cookie无影响

你可能感兴趣的:(Servlet学习)