JavaWeb_day2_servlet2

一、 Servlet的生命周期:
 1. 创建:第一次请求时,web容器(Servlet引擎)会调用默认的构造方法创建出Servlet的一个实例
 2. 初始化:在Servlet实例创建后,web容器会立即调用init()方法来初始化资源。
 3. 服务:web容器会针对一个请求启动一个线程,在线程中执行service()方法。
               在service()方法中会根据请求方式调用相应的处理方法(doGet(), doPost())
               doGet()或doPost()方法中的代码一定要注意线程安全问题。
 4. 销毁:在web应用程序卸载时,web容器会回调destroy()方法来清理资源。


二、Servlet API:Sun公司在JavaEE规范中定义好的。5.0, 1.4
1. Servlet->GenericServlet->HttpServlet-->自定义的Servlet,重写doGet()和doPost()


2. HttpServletRequest: 代表客户端的请求,由web容器创建并传递给Servlet的服务方法。
      web容器会把客户端提交给服务器的HTTP请求数据封装到这个对象中。
  1) void setCharacterEncoding("字符集");    //对请求消息体中的数据用指定的字符集进行编码转换,这个方法一定要在获取参数值之前设置
  2) String getParameter("参数名");               //从请求对象中获取指定参数名对应的字符串值
  3) String[] getParameterValues("参数名"); //获取指定参数名对应的一组字符串值
  4) String getContextPath();                         //获取本Web应用程序的上下文根路径
  5) RequestDispatcher getRequestDispatcher("目标资源路径");  //获取一个跳转到指定路径的请求分派器
      如果路径以/开头,表示以当前web应用的根路径开始。
      利用请求分派器分派请求: requestDispatcher.forward(request, response);


3. HttpServletResponse: 代表要返回给客户端的响应对象。由web容器创建并传递给Servlet的服务方法。
  1) void setContentType("text/html;charset=字符集"); //设置响应的内容类型及编码方式
  2) PrintWriter getWriter();  //获取向客户端输出字符的输出流
  3) ServletOutputStream getOutputSteam(); //获取向客户端输出字节的输出流
  4) void sendRedirect("目标资源路径");  //重定向到指定的路径。
      如果路径以/开头,表示以服务器的根路径开始。


三、 Servlet的路径匹配方式:(web.xml中<url-pattern>的配置)
☆1) 确切路径匹配:以"/"开始(代表该Web应用的根路径,也叫上下文路径:contextPath),后面跟一个具体的路径名称,也可以包含子路径。
       如:/login、/login.do、/mng/empopt.do
 2) 模糊路径匹配:以"/"开始,以"/*"结束,中间可以包含子路径。如:/mng/*、/emp/*
☆3) 扩展名匹配:以“*.”开始,以任意其它的字符结束。如:*.do、*.action、*.htm
 4) 缺省的Servlet匹配:配置成“/”的Servlet为该应用的缺省Servlet,Web服务器会将所有无法识别的客户端请求交给缺省的Servlet来处理。
 
四、 Web应用启动时创建Servlet实例
 1) 一般来说:Servlet实例的创建是客户端发起第一次请求时由web容器来创建。
 2) 要在Web应用启动时就创建好Servlet实例:在web.xml文件中<servlet>的添加子标签<load-on-startup>数字</load-on-startup>


五、请求分派和重定向
1. 请求分派: request.getRequestDispatcher("/目标路径").forward(request,response);
2. 重定向:response.sendRedirect(request.getContextPath() + "/目标路径");
3. 区别:请求分派由web容器完成,而重定向由客户端完成。
              请求分派时会把请求对象和响应对象传递给下一个资源,请求数据不会丢失。重定向是由客户端自动发起的一次新请求。丢失第一次的请求数据
              重定向的最终路径会显示在浏览器地址栏。而请求分派只显示第一次请求的路径。


六、利用请求属性域传递对象数据
request对象中,内置了一个Map,用来存取对象数据。只在本次请求完成之前可以使用。
 1) void setAttribute("名", Object 值);  //往请求域中存放对象
 2) Object getAttribute("名");  //根据指定的名从请求域中取出对应的对象
 3) void removeAttribute("名"); //根据指定的名从请求域中删除对应的对象 
属于同一个请求的多个处理模块之间(请求分派)可以通过请求域属性来传递对象数据。
常用方式,用Servlet去数据库取数据,存放到请求属性域中, 然后请求分派到JSP页面。JSP页面中从请求域里取出数据,进行显示。


七、Servlet初始化参数和Web应用上下文初始化参数
1. ServletConfig:每个Servlet对象都有自己的ServletConfig对象。
  当web容器在初始化一个Servlet时,它会加载从部署描述文件(web.xml)中“读出”该servlet的初始化参数交给ServletConfig对象。
  在Servlet怎么获取这个参数的值:
  ServletConfig config = this.getServletConfig();
  String str = config.getInitParameter("参数名");


2. ServletContext:每个web应用程序都有自己的ServletContext对象。
  当web容器在部署(启动)完一个Web应用程序时,会为该Web应用创建好一个对应的ServletContext对象。所有在这个Web应用程序中的Servlet都可以获取这个ServletContext对象。
  ServletContext context = this.getServletContext();
  String str = context.getInitParameter("参数名");


3. ServletContext对象中内置一个Map对象,可以用来存取对象数据。这个存放属性的域叫做Web应用上下文,也叫Servlet上下文,也叫application域。本Web应用中的所有Servlet共享它。
 1) void setAttribute("名", Object 值);  //往Web应用上下文中存放对象
 2) Object getAttribute("名");  //根据指定的名从Web应用上下文中取出对应的对象
 3) void removeAttribute("名"); //根据指定的名从Web应用上下文中删除对应的对象
 
  Web应用上下文的生命周期是随着Web应用程序的启动而开始,随着Web应用程序的卸载而终止。因此,不是特殊情况不要使用这个域来存放对象数据。









### 回答1: javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套针对Java开发的微服务框架,该框架提供了一系列功能和组件,用于帮助开发者更轻松地构建和管理微服务架构。 该框架的源码是指该框架的具体实现代码,通过阅读源码,开发者可以深入了解框架的设计思想和实现细节,有助于更好地理解和使用该框架。 javaweb_cloud_elevue_pro微服务框架旗舰版源码的特点主要包括以下几点: 1. 模块化设计:源码采用模块化设计,将整个框架拆分成多个独立的模块,每个模块负责不同的功能,有利于代码的组织和维护。 2. 弹性扩展:框架采用了微服务架构,可以很方便地进行系统扩展,支持动态添加和移除服务实例,以适应不同的业务需求。 3. 高可用性:框架提供了集群和负载均衡的支持,可以提高系统的可用性和性能。 4. 分布式事务管理:源码包含了分布式事务管理的实现,可以保证系统在多节点环境下的数据一致性。 5. 可靠消息传递:框架提供了消息队列和分布式任务调度的功能,可以确保消息的可靠传递和任务的可靠执行。 6. 监控和管理:框架提供了丰富的监控和管理功能,可以对系统进行实时监控和管理,方便开发者进行故障排查和性能调优。 总之,javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套成熟的微服务框架实现代码,通过研究源码,开发者可以更好地理解和使用该框架,提高开发效率和系统稳定性。 ### 回答2: javaweb_cloud_elevue_pro微服务框架是一款功能强大的微服务开发框架,是javaweb_cloud_elevue_pro产品家族中的旗舰版。 该框架的源码提供了一套完整的微服务解决方案,包含了丰富的功能模块和技术组件,可用于构建高性能、稳定可靠的分布式系统。 源码中包含了一系列核心组件,如服务注册与发现、负载均衡、熔断降级、分布式配置中心等,这些组件可以快速搭建起一个具有高可用性和可伸缩性的微服务架构。 此外,框架的源码还提供了一套易用的开发工具和开发规范,使开发者能够快速上手并高效地开发微服务应用。开发者可以根据自己的业务需求,选择合适的组件和模块进行使用,从而实现个性化的定制和扩展。 与其他微服务框架相比,javaweb_cloud_elevue_pro微服务框架的源码具有以下特点: 1. 高性能:框架使用了一系列优化的算法和技术,能够实现高效的请求处理和资源利用,保证系统的稳定和可靠。 2. 可扩展:源码提供了丰富的扩展接口和插件机制,开发者可以根据自己的需求进行个性化的扩展和定制。 3. 易用性:框架的源码结构清晰,文档详细,附带了示例和教程,使开发者能够快速理解和掌握框架的使用方法。 4. 社区支持:javaweb_cloud_elevue_pro框架拥有一个活跃的社区,开发者可以在社区中获取帮助、交流经验,并参与框架的改进和贡献。 总之,javaweb_cloud_elevue_pro微服务框架旗舰版源码提供了一个完整的微服务解决方案和一套易用的开发工具,可帮助开发者快速构建高性能、稳定可靠的分布式系统。它是微服务领域中的佼佼者,值得开发者深入研究和使用。 ### 回答3: javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套用于构建微服务架构的开源代码。该框架旨在提供一种简单、高效的方式来搭建和管理分布式系统。 该框架基于Java语言,采用了云计算、分布式计算和微服务架构的设计理念,提供了一套完整的解决方案来构建和管理分布式应用。 该框架具有以下特点: 1. 架构灵活:框架提供了一套灵活的架构设计,可以根据业务需求进行扩展和定制。 2. 模块化设计:框架采用模块化设计,各个微服务模块之间可以独立部署和调用,实现了高内聚、低耦合的分布式系统。 3. 高可用性:框架支持负载均衡、容错和故障恢复等机制,保证了系统的高可用性和容错性。 4. 弹性扩展:框架支持水平扩展,可以根据需求动态增加或减少服务实例,实现了系统的弹性扩展和负载均衡。 5. 服务治理:框架提供了服务注册与发现、负载均衡、熔断器等功能,实现了对微服务的有效治理和管理。 6. 高性能:框架采用了高性能、高并发的设计和优化策略,提升了系统的性能和扩展能力。 总体而言,javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套功能强大、灵活可扩展的微服务架构代码,可帮助开发人员快速构建和管理分布式系统。无论是在企业级应用程序还是在云计算环境中,该框架都能提供优秀的支持,并具有较高的性能和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值