一:
web.xml中的代码如下
<web-app><display-name>Archetype Created Web Application</display-name><servlet><servlet-name>AddServlet</servlet-name><servlet-class>servlets.AddServlet</servlet-class></servlet><servlet-mapping><servlet-name>AddServlet</servlet-name><url-pattern>/add</url-pattern></servlet-mapping><!--用户发请求 action=add当前项目中 web.xml中找到url-pattern=/add找12行的名字 servlet-name =Addsevlet找到和servlet-mapping中servlet-name一致的servlet,即第8行找到第八行servlet-class用户发送的post请求 ,因此会执行AddServlet中的doPost方法-->
</web-app>
通过url-pattern找到对应的servlet-name(目前简单这样子理解,之后学习的过程中会注意)
在根据servlet-name找到我们创建的类所需要初始化的服务。
public class AddServlet extends HttpServlet {//响应页面中的post请求@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//post方式下设置编码防止中文乱码 get方式目前不需要(基于tomcat8)//设置编码这一句必须在参数获取之前设置req.setCharacterEncoding("UTF-8");String fname = req.getParameter("fname");String pricestr = req.getParameter("price");int price = Integer.parseInt(pricestr);String fcountstr = req.getParameter("fcount");int fcount = Integer.parseInt(fcountstr);String remark = req.getParameter("remark");FruitDAO fruitDAO = new FruitDAOImpl();boolean flag = fruitDAO.addFruit(new Fruit(0, fname, price, fcount, remark));System.out.println(flag?"添加成功!":"添加失败");}
}
二:细节
2.servlet的继承关系(1、继承关系:javax.servlet.Servlet接口javax.servlet.GenericServlet抽象类javax.servlet.HttpServlet 抽象子类(2、相关方法:Servlet:void init(config)-初始化方法void service(request,response) -服务方法void destroy()-销毁方法javax.servlet.GenericServlet:void service(request,response) 仍然是抽象的javax.servlet.HttpServlet:void service(request,response)(1.String method = req.getMethod(); 获取请求的方式各种if判断,根据请求方式不同决定去调用不用的do方法在httpservlet抽象类中,do方法都差不多(3.小结:继承关系 HttpServlet->GenericServlet->ServletServlet中的核心方法服务方法:当有请求过来时service方法会自动响应(Tomcat容器调用)
三:servlet的生命周期
1)生命周期:从出生到死亡的过程就是生命周期。对应Servlet中的3个方法init,service,destroy2)默认情况下,第一次接受请求会Servlet会使用反射进行实例化(调用构造方法())、初始化(init())然后服务(service())第二次请求开始每一次都会服务,当容器关闭时所有的servlet实例会被销毁3)通过案例发现:Servlet实例Tomcat只会创建一个,所有请求都依赖这个实例去响应第一次请求时会初始实例化好处:提供系统的启动速度坏处:第一次请求时耗时较长因此,如果要提高响应速度则需要设置Servlet的响应时机4)Servlet初始化时机:默认是第一次请求时 初始化可以通过web.xml中的 <load-on-startup>设置启动时机,数字越小启动越靠前5)Servlet在容器中是单例、线程不安全的因此尽量不要再Servlet中定义成员变量。如果不得不加成员变量:不要修改成员变量的值不要根据成员变量的值做一些判断
四:HTTP协议
HTTP:Hyper Text Transfer Protocol 超文本传输协议 1)HTTP是无状态的 2)HTTP请求响应包含两个部分:请求和响应-请求:请求包含3个部分;1.请求行;2、请求消息头 3、请求主体请求行包含三个信息:1.请求的方式 2.请求的URL 3.请求的协议版本。请求消息头中包含许多客户端需要告诉服务器的信息,比如浏览器的星号、版本、客户端接受的类型、发送内容的类型等等请求体:三种情况get方式,没有请求体,但有queryString(紧跟url之后)post方式:有请求体,form datajson格式:有请求体request payload-响应:响应也包含三个部分:1.响应行 2.响应头 3.响应体响应行包含三个信息:1.协议 2.响应状态码 3.响应状态响应头:包含了服务器的信息、服务器发送给浏览器的信息(内容的媒体类型、编码、长度)响应体:响应的实际内容()
五:会话
1)-HTTP是无状态的:服务器无法判断两次请求是不是一个客户端发过来的-现实问题:第一次请求是添加商品到购物车 第二次请求是结账;如果无法区分是不是一个客户端发过来的就会发生混乱(我结账结的别人的购物车)-通过会话跟踪技术解决无状态的问题 2)会话跟踪技术-客户端第一次发送请求给服务器,服务器获取session,获取不到则创建新的,然后响应给客户端-下次客户端给服务器发送请求时,会把sessionId带给服务器,服务器会判断这次请求和上次请求是同一个客户端,从而能够区分-常用的API:request.getSession() ->获取当前的会话,没有则创建新的会话request.getSession(true) ->效果和不带参数的一样request.getSession(false) ->获取当前会话,没有则返回Null,不会创建新的sessionsession.getId() ->获取sessionIDsession.isNew() ->判断当前session是否是新的session.getMaxInactiveInterval() ->session的非激活间隔时长默认为1800s,(即不操作的情况下session的存在时长)session.setMaxInactiveInterval() ->设置非激活间隔时长session.invalidate() ->强制性让会话立即失效3)Session保存作用域session的保存作用域和某个具体的session是对应的常用的API:void session.setAttribute(k,v)Object session.getAttribute(k)void removeAttribute(k)
六:
1)服务器内部转发:request.getRequestDispatcher("...").forward(request,response)一次请求响应的过程,对于客户端而言内部的变化不知道地址栏没有变化
2)客户端重定向:request.sendRedirect("...")两次请求的响应,客户端知道URL的变化地址栏有变化
七:Thymeleaf -视图模板技术
//servlet3.0开始支持注解的方式注册
@WebServlet("/index")
public class IndexServlet extends com.atguigu.myssm.myspringmvc.ViewBaseServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {FruitDAO fruitDAO = new FruitDAOImpl();List<Fruit> fruitList = fruitDAO.getFruitList();//保存到session中HttpSession session = req.getSession();session.setAttribute("fruitList",fruitList);//处理模板//Thymeleaf会将index这个逻辑视图的名称对应到物理视图名称上去//逻辑视图名称:index//物理视图名称:view-prefix + 逻辑视图名称 +view-suffix//所以真是的视图名称为 / index .htmlsuper.processTemplate("index",req,resp);}
}
1).添加Thymeleaf.jar包 2)新建一个servlet类叫viewbaseServlet(从Thymeleaf中拷入) 3)在web.xml文件中添加配置配置prefix和suffix 4)使servlet类继承与viewbaseServlet 5)根据逻辑视图名称得到物理视图名称//处理模板//Thymeleaf会将index这个逻辑视图的名称对应到物理视图名称上去//逻辑视图名称:index//物理视图名称:view-prefix + 逻辑视图名称 +view-suffix//所以真是的视图名称为 / index .htmlb
八、保存作用域
(1)page(不用了) (2)request一次响应的请求范围通过请求2无法获得lili这个数据(3)session一次会话的范围 (4)application一次应用程序的范围(直到Tomcat停止)
其他:
//200:正常响应 //404:找不到资源 //405:请求方式不支持 //500:服务器内部错误