Typora软件介绍

  • Markdown文本编辑器(可以编辑文件)
public class test{
	public static void main (String[] args){
        
    }
}

servlet

关于系统架构

1、系统架构包括什么形式

  • C/S架构
  • B/S架构

2、C/S架构

  • Client / Server(客户端,服务器)
  • C/S架构的软件或者说系统有哪些呢?
  • QQ(先去腾讯官网下载一个qq软件,几十MB,然后输入qq号以及密码,登录之后,就可以和你的朋友聊天了,就可以使用这个软件了。
  • C/S架构的特点:需要安装特定的客户端软件。
  • C/S架构的系统优点和缺点分别是什么?
  • 优点:
  • 速度快(软件中的数据大部分都是集成到软件客户端软件当中的,很少量的数据是从服务器端传过来的,所以C/S结构的系统速度快)
  • 体验好(速度又快,界面又炫酷,当然体验好了)
  • 界面炫酷
  • 服务器压力小
  • 安全(因为大量的数据都是集成在客户端软件当中的,并且客户端有很多个,服务器虽然只有一个,就算服务器那边地震了,火灾了,服务器受损了,问题也不大,因为大量的数据在多个客户端上有缓存,有存储,所以从这个方面来说,C/S结构的系统比较安全。)
  • 缺点:
  • 升级维护比较差劲。(升级维护比较麻烦。成本比较高,每一个客户端软件都需要升级。有一些软件不是那么容易安装的)

3、B/S架构?

  • B/S(Browser/Server,浏览器/服务器)
  • http://www.baidu.com
  • http://www.jd.com
  • http://126.com
  • B/S结构的系统是不是一个特殊的C/S系统?
  • 实际上B/S结构的系统还是个C/S,只不过这个C比较特殊,这个Client是一个固定不变的浏览器软件。
  • B/S结构系统的优点和缺点是:
  • 优点:
  • 升级维护方便,成本比较低。(只需要升级服务器端即可)
  • 不需要安装特定的客户端软件,用户操作及其方便,只需要打开浏览器,输入网址即可。
  • 缺点:
  • 速度慢(不是因为带宽低的问题,是因为所有的数据都是在服务器上,用户发送的每一个请求都是需要服务器全身心的响应数据,所以B/S结构的系统在网络中传送的数据量比较大。)
  • 体验差(界面不是那么炫酷,因为浏览器只支持三个语言HTML CSS JavaScript。在加上速度慢。)
  • 不安全(所有的数据都在服务器上,只要服务器发生火灾,地震等不可抗力,最终数据全部丢失。)

4、C/S和B/S结构的系统,哪个好,哪个不好?

  • 这个问题问的没有水平。并不是哪个好,哪个不好,不同结构的系统在不同的业务场景下有不同的适用场景。
  • 娱乐性软件建议适用?
  • C/S结构
  • 公司内部使用的一些业务软件建议使用?
  • 公司内部使用的系统,需要维护成本低。
  • 公司内部使用的系统,不需要很炫酷
  • 公司内部使用的企业级系统主要是能够进行数据的维护即可。
  • B/S结构。

5、注意了:开发B/S结构的系统,其实就是开发网站,其实就是开发一个WEB。

  • 开发一个WEB系统你需要会哪些技术?
  • WEB前端
  • HTML
  • CSS
  • JavaScript
  • WEB后端(WEB服务器端的程序。)
  • java可以(java做WEB开发我们称为javaWEB开发。 javaWEB开发最核心的规范:Server【Servlet Applet服务器端的小程序。】)
  • c语言也可以
  • c++也可以
  • python也行
  • PHP也可以

6、javaEE是什么?

  • Java包括三大块:
  • javaSE
  • java标准版(一套类库,别人写好的一套类库,只不过这个类库是标准类库,走EE,或者走ME,这个是SE一定是基础,先学。)
  • javaEE(WEB方向,WEB系统)
  • java企业版(也是一套类库:也是别人写好的一套类库,只不过这套类库可以帮助我们完成企业级项目开发,专门为企业内部提供解决方案的一套(多套)类库)
  • 别人写好的,你用就行了,用它可以开发企业级项目。
  • 可以开发web系统
  • java比较火爆的就是这个javaEE方向。
  • javaME
  • java微型版(还是一套类库,只不过这套类库帮助我们进行电子微型设备内核程序的开发)
  • 机顶盒内核程序,吸尘器内核程序,电冰箱内核程序,电饭煲内核程序。。。。
  • javaEE实际上包括很多种规范,13种规范,其中Servlet就是javaEE规范之一。学Servlet还是java语言。

B/S结构的系统通信原理(没有涉及到java小程序)

  • WEB系统的访问过程
  • 第一步:打开浏览器
  • 第二步:找到地址栏
  • 第三步:输入一个合法的网址
  • 第四步:回车
  • 第五步:在浏览器上会展示响应的结果。
  • 关于域名:
  • https://www.baidu.com(网址)
  • www.baidu.com 是一个域名
  • 在浏览器地址栏上输入域名,回车之后,域名解析器会将域名解析出来一个具体的IP地址和端口号等。
  • IP地址是啥?
  • 计算机在网络当中的身份证号,在同一个网络当中,IP地址是唯一的。
  • A计算机要想和B计算机通信,首先你需要知道B计算机的IP地址,有了IP地址才能建立连接。
  • 端口号是啥?
  • 一个端口代表一个软件(一个端口代表一个应用,一个端口仅代表一个服务)。
  • 一个计算机当中有很多软件,每一个软件启动之后,都有一个端口号。
  • 在同一个计算机上 ,端口号具有唯一性。
  • 一个WEB系统的通信原理?通信步骤:
  • 第一步:用户输入网址(URL)
  • 第二步:域名解析器进行域名解析:http://39.156.66.14:80/index.html
  • 第三步:浏览器软件在网络中搜索39.156.66.14这台主机,直到找到这台主机。
  • 第四步:定位39.156.66.14主机上的服务器软件,因为是80端口,可以很轻松的定位到80端口对应的服务器软件。
  • 第五步:80端都对应的服务器软件得知浏览器想要的资源名是index.html
  • 第六步:服务器软件找到index.html文件,并且将index.html文件中的内容直接输出响应到浏览器上。
  • 第七步:浏览器接受来自服务器的代码(HTML CSS JS)
  • 第八步:浏览器渲染,执行HTML CSS JS 代码,展示效果
  • 什么是URL?
  • 统一资源定位符(https://www.baidu.com)
  • 什么是请求,什么是响应?
  • 请求和响应实际上说的是数据的流向不同
  • 从浏览器Browser端发送数据到Server端,我们称为请求。英语单词:request
  • 从Server端向浏览器Browser端发送数据,我们称为响应。英文单词:response
  • B–> S(请求request)
  • S–> B(响应response)

关于WEB服务器软件

  • WEB服务器软件都有哪些呢?(这些软件都是提前开发好的)
  • Tomcat(WEB服务器)
  • jetty(WEB服务器)
  • JBOSS(应用服务器)
  • WebLogic(应用服务器)
  • WebSphere(应用服务器)
  • 应用服务器和WEB服务器的关系?
  • 应用服务器实现了JavaEE的所有规范,(javaEE有13个不同的规范。)
  • WEB服务器只实现了JavaEE中的Servlet + JSP两个核心的规范。
  • 通过这个讲解说明了:应用服务器是包含WEB服务器的。
  • 用过JBOSS服务器的同学应该很清楚,JBOSS中内嵌了一个Tomcat服务器。
  • Tomcat下载
  • apache官网地址:(https://apache.org/)
  • tomcat官网地址:(https://tomcat.apache.org/)
  • tomcat开源免费的轻量级WEB服务器
  • tomcat是java语言写的。
  • tomcat服务器要想运行,必须先有jre(java的运行环境)
  • Tomcat服务器要想运行,需要先有jre,所以要先安装JDK,配置java运行环境。
  • JAVA_HOME = JDK的根
  • PATH = %JAVA_HOME %\bin
  • Tomcat服务器的安装:
  • 绿色版本的安装很简单,直接zip包解压即可。解压就是安装。
  • 有一个好的习惯,在c盘的根目录下新建一个dev目录,java开发所有相关的工具都安装到dev目录下,这样比较方便管理。
  • 启动Tomcat
  • bin目录下有一个文件:startup.bat,通过它可以启动Tomcat服务器。
  • xx.bat文件是什么文件?bat文件是windows操作系统专用的,bat文件是批处理文件,这种文件中可以编写大量的windows的dos命令,然后执行bat文件就相当于批量的执行dos命令。
  • startup.sh,这个文件在wiondows当中无法执行,在Liunx环境下能够执行的shell命令,大量的shell命令编写在shell文档当中,然后执行这个shell文件可以批量的执行shell命令。
  • tomcat服务器提供了bat和sh文件,说明了tomcat服务器的通用性。
  • 分析startup.bat文件得出,执行这个命令实际上最后执行:catalina.bat文件。
  • catalina.bat文件中有这样一行配置:MAINCLASS = org.apache.catelina.startup.Bootstrap(这个类就是main方法所在的类。)
  • tomcat服务器就是java语言写的,既然是java语言写的,n那么启动Tomcat服务器就是执行main方法。
  • 启动Tomcat服务器只配置path对应的bin目录是不行。有两个环境变量需要配置:
  • JAVA_HOME = JDK的根
  • CATALINA_HOME是Tomcat服务器的根

  • 关于Tomcat服务器的目录
  • bin:这个目录是Tomcat服务器的命令文件存放的目录,比如:启动Tomcat,关闭Tomcat等。
  • conf:这个目录是Tomcat服务器的配置文件存放目录。(server.xml文件中可以配置端口号,默认Tomcat端口是8080)
  • lib:这个目录是Tomcat服务器的日志目录,Tomcat服务器启动等信息都会在这个目录下生成日志文件。
  • logs:Tomcat服务器的日志目录,Tomcat服务器启动等信息都会在这个目录下生成日志文件。
  • temp:Tomcat服务器临时目录,存储临时文件。
  • webapps:这个目录当中就是用来存放大量的webapp(web application: web应用)
  • work:这个目录是用来存放JSP文件翻译之后的java文件以及编译只有的class文件。
  • 配置Tomcat服务器需要哪些环境变量?
  • JAVA_HOME = JDK的根
  • CATALINA_HOME =Tomcat服务器的根
  • PATH = %JAVA_HOME%\bin, %CATALINA_HOME%\bin
  • 启动Tomcat : startup
  • 关闭Tomcat:stop(shutdown.bat文件重命名为stop.bat,为什么?原因是shutdown命令和windows中的关机命令冲突,所以修改以下。)
  • 怎么测试Tomcat服务器有没有启动成功呢?
  • 打开浏览器,在浏览器的地址栏上输入URL即可:

实现一个最基本的web应用(这个应用中没有java程序)

  • 第一步:找到CATALINA_HOME\webapps目录
  • 因为所有webapp要放到webapps目录下。(没有为什么,这是Tomcat服务器的要求。如果不放到这里,Tomcat服务器找不到你的应用。)
  • 第二步:在CATALINA_HOME\webapps目录下新建一个子目录,起名:oa
  • 这个目录名oa就是你这个webapp的名字。
  • 第三步:在oa目录下新建资源文件,例如:index.html
  • 编写index.html文件的内容。
  • 第四步:启动Tomcat服务器
  • 第五步:打开浏览器,在浏览器地址栏上输入这样的URL:
  • 思考一个问题:
  • 我们在浏览器上直接输入一个URL,然后回车。这个动作和超链接一样吗?既然是一样的我们完全可以使用超链接。
<!--注意以下的路径,以/开始,带项目名,是一个绝对路径。不需要添加:http://127.0.0.1:8080-->
<a href="/oa/login.html">index_login</a>
<!--多个层级也没有关系,正常访问即可-->
<!--注意:目前前端上的路径都以"/”开始的,都是加项目名的-->
  • 访问这个地址,可以展示一个用户列表页面。但是这个用户列表页面是写死在HTML文件当中的。这种资源我们称为静态资源。怎么能变成动态资源。显然需要连接数据库。
  • 连接数据库需要JDBC程序,也就是说需要编写java程序连接数据库,数据库中有多少条记录,页面上就显示多少条记录,这种技术被称为动态网页技术。(动态网页技术并不是说页面中有flash动画。动态网页技术是说页面中的数据是动态的,根据数据库中数据的变化而变化。)

对于一个动态的web应用来说,一个请求和响应有多少个角色参与,角色和角色之间有多少个协议

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pWhRVL8t-1644296175899)(C:\Users\L\AppData\Roaming\Typora\typora-user-images\image-20220206231401242.png)]

  • 有哪些角色(在整个BS结构的系统当中,有哪些人参与进去了)
  • 浏览器软件的开发商(浏览器软件太多了:谷歌,火狐,IE浏览器等。。。)
  • WEB Server的开发团队(WEB Server这个软件太多了:Tomcat、jetty、WebLoglc、JBOSS、)
  • DB Server的开发团队(DB Server这个软件也太多了:Oracle、MySQL…)
  • webapp的开发团队。(WEB应用是我们作为JavaWEB程序员开发的)
  • 角色和角色之间需要遵守哪些规范,哪些协议
  • webapp的开发团队 和WEB Server的开发团队 之间有一套规范:JavaEE规范之一Servlet规范。
  • Servlet规范的作用是什么?
  • WEB Server 和 webapp解耦合。
  • Browser 和 webServer之间有一套传输协议:HTTP协议。(超文本传输协议。)
  • webapp开发团队 和 DB Server的开发团队之间有一套 JDBC 规范

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7BtyuTq9-1644296175900)(C:\Users\L\AppData\Roaming\Typora\typora-user-images\image-20220206233112905.png)]

  • Servlet规范是一个什么规范?
  • 遵循Servlet规范的webapp,这个webapp就可以放在不同的WEB服务器中运行,(因为这个webapp是遵循Servlet规范的。)
  • Servlet规范包括什么?
  • 规范了哪些接口
  • 规范了哪些类
  • 规范了一个web应用中应该有哪些配置文件
  • 规范了一个web应用中配置文件的名字
  • 规范了一个web应用中配置文件存放的路径
  • 规范了一个web应用中配置文件的内容
  • 规范了一个合法有效的web应用它的目录结构应该是怎么样的。

开发一个带有Servlet的webapp(重点)

  • 开发步骤是怎样的?
  • 第一步:在webapps目录下新建一个目录,起名crm(这个crm就是webapp的名字)。当然,也可以是其它项目,比如银行项目,可以创建一个bank,办公系统可以创建一个oa。
  • 注意crm就是webapp的根
  • 第二步:在webapp的根下新建一个目录:WEB-INF
  • 注意:这个目录的名字是Servlet规范中规定的,必须全部大写,必须一模一样,必须的必须
  • 第三步:在WEB-INF目录下新建一个目录:classes
  • 注意:这个目录的名字必须是全部小写的classes。这也是Servlet规范中规定的。另外这个目录下一定存放的是java程序编译之后的class文件(这里存放的是字节码文件)。
  • 第四步:在WEB-INF目录下新建一个目录:lib
  • 注意:这个目录不是必须的。但是如果一个webapp需要第三方的jar包的话,这个jar包要放到这个lib目录下,这个目录的名字也不能随便写,必须是全部小写的lib。例如java语言连接数据库的驱动jar包。那么这个jar包就一定要放到lib目录下。这Servlet规范中规定的。
  • 第五步:在WEB-INF目录下新建一个文件:web.xml
  • 注意:这个文件是必须的,这个文件名必须叫做web.xml。这个文件必须放在这里。一个合法的webapp,web.xml文件是必须的,这个web.xml文件就是一个配置文件,在这个配置文件中描述了请求路径和Servlet类之间的对照关系。
  • 这个文件最好从其他的webapp文件中拷贝,最好别手写。没必要。复制粘贴
<?xml version="1.0" encoding="UTF-8"?>

<web-app xmlns="https://jakarta.ee/xml/ns/jakartaee"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="https://jakarta.ee/xml/ns/jakartaee
                      https://jakarta.ee/xml/ns/jakartaee/web-app_5_0.xsd"
  version="5.0"
  metadata-complete="true">


</web-app>
  • 第六步:编写一个java程序,这个小java程序也不能随意开发,这个小java程序必须实现Servlet接口.
  • 这个Servlet接口不在JDK当中.(因为Servlet不是javaSE了。Servlet属于JavaEE,是另外一套类库。)
  • Servlet接口(Servlet.class文件) 是 Oracle提供的。(最原始的sun公司提供的。)
  • Servlet接口是JavaEE的规范中一员。
  • Tomcat服务器是信了Servlet规范,所以Tomcat服务器也需要使用Servlet接口。Tomcat服务器中应该有这个接口,Tomcat服务器CATALINA_HOME\lib目录下有一个servlet-api.jar,解压这个servlet-api.jar之后,你会看到里面有一个Servlet.class文件。
  • 重点:从jakartaEE9开始,Servlet接口的全名变了:jakarta.servlet.Servlet
  • 注意:编写这个java小程序的时候,java源代码你愿意在哪里就在哪里,位置无所谓,你只需要将java源代码编译之后的class文件方到classes目录下即可
  • 第七步:编译我们编写HelloServlet
  • 重点:你怎么能让你的HelloServlet编译通过呢?配置环境变量CLASSPATH
  • 思考问题:以上CLASSPATH和Tomcat服务器运行有没有关系?
  • 没有任何关系,以上配置这个环境变量只是为了让你的HelloServlet能够正常编译生成class文件。
  • 第八步:将以上编译之后的HelloServlet.class文件拷贝到WEB-INF\classes目录下。
  • 第九步:在web.xml文件中编写配置信息,让“请求路径”和"Servlet类名"关联在一起。
  • 这一步用专业术语描述:在web.xml文件中注册Servlet。
<?xml version="1.0" encoding="UTF-8"?>

<web-app xmlns="https://jakarta.ee/xml/ns/jakartaee"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="https://jakarta.ee/xml/ns/jakartaee
                      https://jakarta.ee/xml/ns/jakartaee/web-app_5_0.xsd"
  version="5.0"
  metadata-complete="true">
	<!--servlet描述信息-->
	<!--任何一个servlet都对应一个servlet-mapping-->
<servlet>
	<servlet-name>sersername</servlet-name>
	<!--这个位置必须带有包名的全限定类名-->
	<servlet-class>com.bjpowernode.servlet.HelloServlet</servlet-class>

</servlet>
	<!--servlet映射信息-->
<servlet-mapping>
	<!--这个也是随便的,不过这里写的内容要和上面的一样-->
	<servlet-name>sersername</servlet-name>
	<!--这里需要一个路径-->
	<!--这个路径唯一的要求是必须以/开始-->
	<!--当前这个路径可以随便写-->
	<url-pattern>/myfirst/ht/ml</url-pattern>
	
</servlet-mapping>

</web-app>
  • 第十步:启动Tomcat服务器
  • 第十一步:打开浏览器,在浏览器地址栏上输入一个url,这个url必须是:
  • 127.0.0.1:8080/crm/myfirst/ht/ml
  • 非常重要的一件事:浏览器上的请求路径不能随便写,这个请求路径必须和web.xml文件中的url.pattern一致。
  • 注意:浏览器上的请求路径和web.xml文件中的url-pattern的唯一区别就是:浏览器上的请求路径带项目名:crm。
  • 浏览器上编写的路径太复杂,可以使用超链接。(非常重要:Html页面只能放到WEB-INF页面目录之外)
  • 以后不需要我们编写main方法了。tomcat服务器负责调用main方法,Tomcat服务器启动的时候执行的就是main方法。我们javaweb程序员只需要编写Servlet接口的实现类,然后将其注册到web.xml文件中,即可。
  • 总结以下:一个合法的webapp目录结构应该是怎样的?

webapproot
	|------WEB-INF
			|------classes(存放字节码)
			|------lib(第三方jar包)
			|------web.xml(注册Servlet)
	|------html
	|------css
	|------javascript
	|------image
	....
  • 浏览器发送请求,到最终服务器调用Servlet中的方法,是怎样的一个过程?(以下这个描述的很粗糙。其中还有很多步骤省略了。)
  • 用户输入URL,或者直接点击超链接:127.0.0.1:8080/crm/myfirst/ht/ml
  • 然后Tomcat服务器接收到请求(request),截取路径:/myfirst/ht/ml
  • Tomcat服务器在web.xml文件中查找/myfirst/ht/ml 对应的Servlet是:com.bjpowernode.servlet.HelloServlet
  • Tomcat服务器通过反射机制,创建com.bjpowernode.servlet.HelloServlet的对象
  • Tomcat服务器调用com.bjpowernode.servlet.HelloServlet对象的Service方法,

关于JavaEE的版本

  • JavaEE目前最高版本是JavaEE
  • JavaEE被Oracle捐献了,Oracle将JavaEE规范捐献给apache了
  • Apache把java改名了,以后不叫JavaEE了,以后叫做jakarta EE。
  • 以后没有JavaEE了。以后都叫做Jakarta EE。
  • JavaEE8版本升级之后的“JavaEE 9”,不再是“JavaEE9”这个名字了,叫做JakartaEE9
  • JavaEE8的时候对应的Servlet类名是:javax.servlet.Servlet
  • JakartaEE9的时候对应用的Servlet类名是:jakarta.servlet.Servlet(包名都换了)
  • 如果你之前的项目还在使用javax.servlet.Servlet,那么你的项目无法直接部署到Tomcat10+版本上。你只能部署到Tomcat9-版本上。在Tomcat9以及Tomcat9之前的版本中还是能够识别javax.servlet这个包。

解决Tomcat服务器在DOS命令窗口中的乱码问题

将CATALINA_HOME/conf/logging.properties文件中的内容修改如下:

java.util.logging.ConsoleHandler.encoding = GBK

想浏览器响应一段HTML代码

public void service(ServletRequest request,ServletResponse response){
    response.setContentType("text/html");
    printWriter.out = response.getWriter();
    out.print("<h1>hello servlet! </h1>");
}

在Servlet中连接数据库,怎么做?

  • Servlet是java程序,所以在Servlet中完全可以编写JDBC代码连接数据库。
package com.bjpowernode.servlet;
import jakarta.servlet.Servlet;
import jakarta.servlet.ServletException;
import jakarta.servlet.ServletRequest;
import jakarta.servlet.ServletResponse;
import jakarta.servlet.ServletConfig;
import java.io.PrintWriter;
import java.io.IOException;
import java.sql.*;

public class jdbcServlet implements Servlet {
	//5个方法
	public void init(ServletConfig config)throws ServletException{}

	public void service(ServletRequest request,ServletResponse response)
		throws ServletException,IOException{
		//设置响应的内容的类型
		response.setContentType("text/html");
		PrintWriter out = response.getWriter();

		Connection conn = null;
		PreparedStatement ps = null;
		ResultSet rs = null;

		try{
			//JDBC
		//注册驱动
		Class.forName("com.mysql.jdbc.Driver"); 
		//获取连接
		conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/bjpowernode","root","root");
		//创建预编译数据库对象
		String sql = "select ename,sal from emp";
		ps = conn.prepareStatement(sql);
		//执行sql
		rs = ps.executeQuery();
		//处理查询结果集
			while(rs.next()){
					String name = rs.getString("ename");
					String  sal = rs.getString("sal");
					out.print("name: " + name + "sal :"+ sal + "<br>");
				}
		//释放资源o

		}catch(Exception e){
			e.printStackTrace();
		}finally{
			if(rs!= null){
				try{
					rs.close();
				}catch(Exception e){
					e.printStackTrace();
				}
			}
			if(ps!= null){
				try{
					ps.close();
				}catch(Exception e){
					e.printStackTrace();
				}
			}
			if(conn!= null){
				try{
					conn.close();
				}catch(Exception e){
					e.printStackTrace();
				}
			}
		}

		
	}
	public void destroy(){}

	public String getServletInfo(){
		return "";
	}
	
	public ServletConfig getServletConfig(){
		return null;
	}

}
  • 在webapp中去连接数据库需要将jar 包放到WEB-INF/lib目录下。
  • (在mysql5.0的版本中:“com.mysql.jdbc.Driver” 这个类就在驱动jar包当中。‘在老杜的java8.0.27版本中 是这样写的 “com.mysql.cj.jdbc.Driver”)
  • C:\dev\apache-tomcat-10.0.16\webapps\crm\WEB-INF\lib
  • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CK9wtuPw-1644296175901)(C:\Users\L\AppData\Roaming\Typora\typora-user-images\image-20220208121121387.png)]
printStackTrace();
 }
 }
 }}
public void destroy(){}

public String getServletInfo(){
	return "";
}

public ServletConfig getServletConfig(){
	return null;
}}
- 在webapp中去连接数据库需要将jar 包放到WEB-INF/lib目录下。

- (在mysql5.0的版本中:“com.mysql.jdbc.Driver” 这个类就在驱动jar包当中。‘在老杜的java8.0.27版本中 是这样写的 "com.mysql.cj.jdbc.Driver")

- C:\dev\apache-tomcat-10.0.16\webapps\crm\WEB-INF\lib 

- [外链图片转存中...(img-CK9wtuPw-1644296175901)]

## 在集成开发环境当中开发Servlet程序