1 . 将tomcat 集群到eclipse中 :
Tomcat的配置步骤
进入eclipse -->window -->preferences —>server -->
Runtime Enviror —>Add ---->点击Add:
选择Tomcat的版本:
点击Browse选择导入Tomcat的路径(到 bin的上级目录)
tomcat的导入完成
2 . 在 Quick Access搜索 server , 完成Server的配置
弹出如下语句:点击它
弹出如下:选择服务器Tomcat server,点击完成
一个Tomcat可以创建多台服务器,点击完成后 拿到服务器
点击右键选择open
弹出以下界面,选择鼠标位置
将 wtpwebapps 改名为 webapps(可改可不改) ,然后保存
Servlet : 运行在服务端的小程序
1.Servlet 就是一个接口,定义了Java类被浏览器访问到(也就是能被tomcat 识别)的规则 。
2.我们自定义一个类,去实现Servlet接口 ,重写servlet 方法 ,该类被称为serve类。浏览器请求服务器的动态资源,其实请求是java类,但是java类呢,它必须依赖服务器,且通过Tomact去执行,可是Tomact不认识java类,为了让Tomcat认识所有的java类,这些java类必须遵循一定的规则,这样Tomcat才能识别它。这个规则就是Servlet接口。我们可以说这个规则是一个接口,java类去实现这个接口以后,Tomcat就可以识别该java类,并去执行它。
创建一个java类去实现 implements 如下
Servlet生命周期 对其中方法的解释
1. //被创建:执行init方法,只执行一次
* Servlet什么时候被创建?
* 默认情况下,第一次被访问时,Servlet被创建,也可以配置它的创建时机,在配置文件中进行配置
* 在<servlet>标签下配置
1. 第一次被访问时,创建 : <load-on-startup>的值为负数
2. 在服务器启动时,创建 :<load-on-startup>的值为0或正整数
* Servlet的init方法,只执行一次,说明一个Servlet在内存中只存在一个对象,Servlet是单例的
* 多个用户同时访问时,可能存在线程安全问题。
* 解决:尽量不要在Servlet中定义成员变量。即使定义了成员变量,也不要对修改值
@Override
public void init(ServletConfig servletConfig) throws ServletException {
}
2.//获取ServletConfig对象的,也就是servlet的配置对象
@Override
public ServletConfig getServletConfig() {
return null;
}
3. //提供服务:执行service方法,执行多次
* 每次访问Servlet时,Service方法都会被调用一次。
@Override
public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
System.out.println("demo1....");
}
4.//获取servlet的版本、作者等信息
@Override
public String getServletInfo() {
return null;
}
5. 被销毁:执行destroy方法,只执行一次
* Servlet被销毁时执行。服务器关闭时,Servlet被销毁
* 只有服务器正常关闭时,才会执行destroy方法。
* destroy方法在Servlet被销毁之前执行,一般用于释放资源
@Override
public void destroy() {
}
Servlet3.0注解配置每建一个servlet类就需要配置一个web.XMl ,为了解决这种不断重写,且复杂的配置,在Servlet3.0出现后,出现了注解配置。
实现步骤:
1.创建JavaEE项目必须是Servlet3.0版本以上的,也就是选择javaEE6及以上的项目
2.定义一个类,实现servlet接口,并进行方法的复写
3.servlet类上面使用@webServlet进行注解,进行配置
@WebServlet("资源路径")
urlpartten:Servlet访问路径(上述的资源路径有多中方式)
1. 一个Servlet可定义多个访问路径 : @WebServlet({"/d4","/dd4","/ddd4"}),输入哪一个路径都可进行访问
2. 路径定义规则:
1. /xxx:路径匹配
2. /xxx/xxx:多层路径,目录结构
3. *.任意名称:扩展名匹配
package com.hx;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/Test2")
public class Test2 extends HttpServlet {
//方法的调用不用我们管 由服务器自行调用
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//对get请求的处理request
//服务器内部跳转getRequestDispatcher()
//可以让request 携带数据的方法
// req.setAttribute("name", "tom");
// req.getAttribute("name");
// req.getRequestDispatcher("Test3").forward(req,resp);
//响应
// PrintWriter writer = resp.getWriter();
// writer.write("I love you");
//两句可以做一句写resp.getWriter().write("I love you");
//设置response 对内容进行编码
resp.setCharacterEncoding("utf-8");
//设置浏览器的解析编码,告诉浏览器用什么编码解码
resp.setContentType("text/html;charset=utf-8");
resp.getWriter().write("我爱你啊");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// TODO Auto-generated method stub
//对post请求的处理
}
}
package com.hx;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/Test3")
public class Test3 extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("跳转过来了");
System.out.println(request.getAttribute("name"));
// response 响应对象
PrintWriter writer = response.getWriter();
writer.write("132531");
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
}
}