day11
Tomcat服务器
Tomcat服务器介绍
- Tomcat就是一个web的服务器,用来发布web项目。
- Tomcat有很多版本不同版本的规范技术可能不同。我们学习的tomcat8.5,Servlet规范3.1,JDK至少使用1.7
tomcat下载
其它服务器
- weblogic (Oracle 部属大型分布式项目使用)
- nginx是一个高性能的HTTP和反向代理web服务器
Tomcat 重要目录
-
bin:脚本目录
-
启动脚本:startup.bat
- windows
-
启动脚本:startup.sh
- liunx
-
shutdown.bat
- windows停止服务
-
shutdown.sh
- liunx停止服务
-
-
conf:配置文件目录 (config /configuration)
- 核心配置文件:server.xml
- 用户权限配置文件:tomcat-users.xml
- 所有web项目默认配置文件:web.xml
- logging.properties 代码格式设置
-
lib:依赖库
- ,tomcat和web项目中需要使用的jar包
-
logs:日志文件
-
temp:
- 临时文件目录,文件夹内内容可以任意删除。
-
webapps
- 默认情况下,发布的WEB项目所存放的目录。
-
work
- tomcat处理JSP页面的工作目录。
Tomcat的项目发布方式
-
- 将项目复制到tomcat/webapps中
-
- 启动Tomcat服务器,双击 startup.bat
-
- 访问项目
- http://localhost:8080/aaa/index.html
eclipse集成tomcat
web项目目录结构(重要)
- 项目名称(存放于:Tomcat软件安装目录中,webapps目录下的子文件夹)
- |-----静态资源 HTML,CSS,JS
- |-----WEB-INF (不能直接通过浏览器进行访问)
- |----web.xml 当前WEB项目的核心配置,Servlet2.5必须有,3.0以后可省略
- |----lib 当前WEB项目所需要的第三方的jar的存放位置。
- |----classes Java源码编译后生成class文件存放的位置。
Servlet入门
servlet的概述
- 1、Servlet(Server Applet)是Java Servlet的简称,称为服务器端小程序,用Java编写进行编写,具有独立于平台和协议的特性,主要功能在于交互式地浏览和生成数据,生成动态Web内容。
- 2、狭义的Servlet是指Java语言实现的一个接口
- 5、广义的Servlet是指任何实现了这个Servlet接口的类,一般情况下,人们将Servlet理解为后者。Servlet运行于支持Java的应用服务器中。从原理上讲,Servlet可以响应任何类型的请求,但绝大多数情况下Servlet只用来扩展,基于HTTP协议的Web服务器。
- 4、我说他是一个运行在服务器上的java小程序,可以用于处理页面请求,和响应数据给页面
servlet的初体验
servlet程序执行原理
Tomcat&Servlet&页面的关系
- Servlet就是tomcat的一个组件,Servlet运行必须依靠tomcat 举个例子:如果说tomcat是汽车发动机,那么Servlet就是汽车的变速器
Servlet生命周期
-
概述
- Servlet生命周期定义了一个Servlet如何被加载、初始化,以及它怎样接收请求、响应请求,提供服务。
-
Servlet对象什么时候被创建
- Servlet默认第一次访问的时候,对象被创建
-
如何让tomcat在启动的时候就创建Servlet
- Tomcat服务器启动的时候创建对象,需要修改web.xml (一般不配置)
- …
-
Servlet对象什么时候被销毁
- 停止Tomcat服务器
serlvet的访问路径配置
-
url-pattern配置方式共有三种:完全匹配、目录匹配、扩展名匹配
-
- 完全匹配
- /path : 浏览器地址栏必须写 /path
-
- 目录匹配
- /aaa/bbb/* : 浏览器地址栏可以写 /aaa/bbb/任意
-
- 扩展名匹配
- *.do : 浏览器地址栏可以写 任意.do
-
注意:目录匹配和后缀名匹配不能同时使用
- 错误的写法: /aaa/bbb/*.do
-
案例:用户登录
案例分析
实现步骤
- 创建数据库表
- 创建WEB项目
- 添加必要的jar,配置文件,工具类,JavaBean(User类)
- 编写页面
- 编写服务器Servlet
/**
*
*/
package com.ujiuye;
import java.io.IOException;
import java.sql.SQLException;
import javax.servlet.Servlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import com.mchange.v2.c3p0.ComboPooledDataSource;
/**
* @author: t c y
* @date:2019年11月11日
* @Copyright:
*/
public class FromDemo implements Servlet {
//本类为测试Tomcat Tomcat组件servlet 数据库连接池 的表单验证
/*
* 1、导包。 c3p0 DButils MySQL驱动包
* c3p0-0.9.2.1.jar
* commons-dbutils-1.4.jar
* mchange-commons-java-0.2.3.4.jar
* mysql-connector-java-5.1.40-bin.jar
* 以及导入properties文件
* 2、新建数据库 新建表
* 3、新建与之数据表同类型同名称的java类对象
* 并设置set get 有参无参构造!
* 4、新建HTML表单网页。获取登录数据。注意表单登录方式,
* post的方式在tomcat 8.5下获取中文字符会乱码,务必改为get方式
*
* 5、新建java文件,form表单类 实现servlet接口。
* 新建数据连接池,这里采用c3p0连接池,DBUtils
* 6、配置xml文件, 注册servlet到web容器中 确定java名字,确定表单的包名+类名的路径
* <!-- 注册servlet到web容器中 --> web.xml文件位于WEB-INF文件夹下
* <servlet>
* <servlet-name>LoginServlet</servlet-name>
* <servlet-class>com.offcn.servlet.LoginServlet</servlet-class>
* </servlet>
*
* <!--配置访问路径 -->
* <servlet-mapping>
* <servlet-name>LoginServlet</servlet-name>
* <url-pattern>/login</url-pattern>
* </servlet-mapping>
* 7、调用DBUtils工具获得对象在数据库是否验证正确!
* tomcat 7.0方式获取的中文字符会乱码,需要设置 编码格式为utf-8
* username= new String(username.getBytes("iso-8859-1"),"utf-8");
*/
public ComboPooledDataSource datasoure=new ComboPooledDataSource("mysql");
public QueryRunner querRunner=new QueryRunner(datasoure);
@Override
public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
// TODO Auto-generated method stub
HttpServletRequest hreq=(HttpServletRequest) req;
HttpServletResponse hres=(HttpServletResponse) res;
String username = hreq.getParameter("username");
String password = hreq.getParameter("password");
hres.setContentType("text/html;charset=UTF-8");
String sql = "select * from user where username=? and password=?";
try {
User user = querRunner.query(sql,new BeanHandler<User>(User.class),username,password);
System.out.println(user);
if (user!=null) {
hres.getWriter().print("登录成功!");
}else {
hres.getWriter().print("登录失败!");
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
@Override
public void init(ServletConfig config) throws ServletException {
// TODO Auto-generated method stub
}
@Override
public ServletConfig getServletConfig() {
// TODO Auto-generated method stub
return null;
}
@Override
public String getServletInfo() {
// TODO Auto-generated method stub
return null;
}
@Override
public void destroy() {
// TODO Auto-generated method stub
}
}