目录
一、 什么是Servlet二、Servlet API三、第一个Servlet四、Servlet工作原理五、Servlet的生命周期六、请求常用方法补充1:客户端如何发送数据给服务器补充2:处理请求乱码的问题补充3:get和post的区别
七、响应八、重定向和转发的对比九、会话十、获取初始化参数十一、注解方式实现servlet
一、 什么是Servlet
#mermaid-svg-BYPakgiCbWb6jzs9 .label{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);fill:#333;color:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .label text{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .node rect,#mermaid-svg-BYPakgiCbWb6jzs9 .node circle,#mermaid-svg-BYPakgiCbWb6jzs9 .node ellipse,#mermaid-svg-BYPakgiCbWb6jzs9 .node polygon,#mermaid-svg-BYPakgiCbWb6jzs9 .node path{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-BYPakgiCbWb6jzs9 .node .label{text-align:center;fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .node.clickable{cursor:pointer}#mermaid-svg-BYPakgiCbWb6jzs9 .arrowheadPath{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .edgePath .path{stroke:#333;stroke-width:1.5px}#mermaid-svg-BYPakgiCbWb6jzs9 .flowchart-link{stroke:#333;fill:none}#mermaid-svg-BYPakgiCbWb6jzs9 .edgeLabel{background-color:#e8e8e8;text-align:center}#mermaid-svg-BYPakgiCbWb6jzs9 .edgeLabel rect{opacity:0.9}#mermaid-svg-BYPakgiCbWb6jzs9 .edgeLabel span{color:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .cluster rect{fill:#ffffde;stroke:#aa3;stroke-width:1px}#mermaid-svg-BYPakgiCbWb6jzs9 .cluster text{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:12px;background:#ffffde;border:1px solid #aa3;border-radius:2px;pointer-events:none;z-index:100}#mermaid-svg-BYPakgiCbWb6jzs9 .actor{stroke:#ccf;fill:#ECECFF}#mermaid-svg-BYPakgiCbWb6jzs9 text.actor>tspan{fill:#000;stroke:none}#mermaid-svg-BYPakgiCbWb6jzs9 .actor-line{stroke:grey}#mermaid-svg-BYPakgiCbWb6jzs9 .messageLine0{stroke-width:1.5;stroke-dasharray:none;stroke:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .messageLine1{stroke-width:1.5;stroke-dasharray:2, 2;stroke:#333}#mermaid-svg-BYPakgiCbWb6jzs9 #arrowhead path{fill:#333;stroke:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .sequenceNumber{fill:#fff}#mermaid-svg-BYPakgiCbWb6jzs9 #sequencenumber{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 #crosshead path{fill:#333;stroke:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .messageText{fill:#333;stroke:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .labelBox{stroke:#ccf;fill:#ECECFF}#mermaid-svg-BYPakgiCbWb6jzs9 .labelText,#mermaid-svg-BYPakgiCbWb6jzs9 .labelText>tspan{fill:#000;stroke:none}#mermaid-svg-BYPakgiCbWb6jzs9 .loopText,#mermaid-svg-BYPakgiCbWb6jzs9 .loopText>tspan{fill:#000;stroke:none}#mermaid-svg-BYPakgiCbWb6jzs9 .loopLine{stroke-width:2px;stroke-dasharray:2, 2;stroke:#ccf;fill:#ccf}#mermaid-svg-BYPakgiCbWb6jzs9 .note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-BYPakgiCbWb6jzs9 .noteText,#mermaid-svg-BYPakgiCbWb6jzs9 .noteText>tspan{fill:#000;stroke:none}#mermaid-svg-BYPakgiCbWb6jzs9 .activation0{fill:#f4f4f4;stroke:#666}#mermaid-svg-BYPakgiCbWb6jzs9 .activation1{fill:#f4f4f4;stroke:#666}#mermaid-svg-BYPakgiCbWb6jzs9 .activation2{fill:#f4f4f4;stroke:#666}#mermaid-svg-BYPakgiCbWb6jzs9 .mermaid-main-font{font-family:"trebuchet ms", verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 .section{stroke:none;opacity:0.2}#mermaid-svg-BYPakgiCbWb6jzs9 .section0{fill:rgba(102,102,255,0.49)}#mermaid-svg-BYPakgiCbWb6jzs9 .section2{fill:#fff400}#mermaid-svg-BYPakgiCbWb6jzs9 .section1,#mermaid-svg-BYPakgiCbWb6jzs9 .section3{fill:#fff;opacity:0.2}#mermaid-svg-BYPakgiCbWb6jzs9 .sectionTitle0{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .sectionTitle1{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .sectionTitle2{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .sectionTitle3{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .sectionTitle{text-anchor:start;font-size:11px;text-height:14px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 .grid .tick{stroke:#d3d3d3;opacity:0.8;shape-rendering:crispEdges}#mermaid-svg-BYPakgiCbWb6jzs9 .grid .tick text{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 .grid path{stroke-width:0}#mermaid-svg-BYPakgiCbWb6jzs9 .today{fill:none;stroke:red;stroke-width:2px}#mermaid-svg-BYPakgiCbWb6jzs9 .task{stroke-width:2}#mermaid-svg-BYPakgiCbWb6jzs9 .taskText{text-anchor:middle;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 .taskText:not([font-size]){font-size:11px}#mermaid-svg-BYPakgiCbWb6jzs9 .taskTextOutsideRight{fill:#000;text-anchor:start;font-size:11px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 .taskTextOutsideLeft{fill:#000;text-anchor:end;font-size:11px}#mermaid-svg-BYPakgiCbWb6jzs9 .task.clickable{cursor:pointer}#mermaid-svg-BYPakgiCbWb6jzs9 .taskText.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-BYPakgiCbWb6jzs9 .taskTextOutsideLeft.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-BYPakgiCbWb6jzs9 .taskTextOutsideRight.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-BYPakgiCbWb6jzs9 .taskText0,#mermaid-svg-BYPakgiCbWb6jzs9 .taskText1,#mermaid-svg-BYPakgiCbWb6jzs9 .taskText2,#mermaid-svg-BYPakgiCbWb6jzs9 .taskText3{fill:#fff}#mermaid-svg-BYPakgiCbWb6jzs9 .task0,#mermaid-svg-BYPakgiCbWb6jzs9 .task1,#mermaid-svg-BYPakgiCbWb6jzs9 .task2,#mermaid-svg-BYPakgiCbWb6jzs9 .task3{fill:#8a90dd;stroke:#534fbc}#mermaid-svg-BYPakgiCbWb6jzs9 .taskTextOutside0,#mermaid-svg-BYPakgiCbWb6jzs9 .taskTextOutside2{fill:#000}#mermaid-svg-BYPakgiCbWb6jzs9 .taskTextOutside1,#mermaid-svg-BYPakgiCbWb6jzs9 .taskTextOutside3{fill:#000}#mermaid-svg-BYPakgiCbWb6jzs9 .active0,#mermaid-svg-BYPakgiCbWb6jzs9 .active1,#mermaid-svg-BYPakgiCbWb6jzs9 .active2,#mermaid-svg-BYPakgiCbWb6jzs9 .active3{fill:#bfc7ff;stroke:#534fbc}#mermaid-svg-BYPakgiCbWb6jzs9 .activeText0,#mermaid-svg-BYPakgiCbWb6jzs9 .activeText1,#mermaid-svg-BYPakgiCbWb6jzs9 .activeText2,#mermaid-svg-BYPakgiCbWb6jzs9 .activeText3{fill:#000 !important}#mermaid-svg-BYPakgiCbWb6jzs9 .done0,#mermaid-svg-BYPakgiCbWb6jzs9 .done1,#mermaid-svg-BYPakgiCbWb6jzs9 .done2,#mermaid-svg-BYPakgiCbWb6jzs9 .done3{stroke:grey;fill:#d3d3d3;stroke-width:2}#mermaid-svg-BYPakgiCbWb6jzs9 .doneText0,#mermaid-svg-BYPakgiCbWb6jzs9 .doneText1,#mermaid-svg-BYPakgiCbWb6jzs9 .doneText2,#mermaid-svg-BYPakgiCbWb6jzs9 .doneText3{fill:#000 !important}#mermaid-svg-BYPakgiCbWb6jzs9 .crit0,#mermaid-svg-BYPakgiCbWb6jzs9 .crit1,#mermaid-svg-BYPakgiCbWb6jzs9 .crit2,#mermaid-svg-BYPakgiCbWb6jzs9 .crit3{stroke:#f88;fill:red;stroke-width:2}#mermaid-svg-BYPakgiCbWb6jzs9 .activeCrit0,#mermaid-svg-BYPakgiCbWb6jzs9 .activeCrit1,#mermaid-svg-BYPakgiCbWb6jzs9 .activeCrit2,#mermaid-svg-BYPakgiCbWb6jzs9 .activeCrit3{stroke:#f88;fill:#bfc7ff;stroke-width:2}#mermaid-svg-BYPakgiCbWb6jzs9 .doneCrit0,#mermaid-svg-BYPakgiCbWb6jzs9 .doneCrit1,#mermaid-svg-BYPakgiCbWb6jzs9 .doneCrit2,#mermaid-svg-BYPakgiCbWb6jzs9 .doneCrit3{stroke:#f88;fill:#d3d3d3;stroke-width:2;cursor:pointer;shape-rendering:crispEdges}#mermaid-svg-BYPakgiCbWb6jzs9 .milestone{transform:rotate(45deg) scale(0.8, 0.8)}#mermaid-svg-BYPakgiCbWb6jzs9 .milestoneText{font-style:italic}#mermaid-svg-BYPakgiCbWb6jzs9 .doneCritText0,#mermaid-svg-BYPakgiCbWb6jzs9 .doneCritText1,#mermaid-svg-BYPakgiCbWb6jzs9 .doneCritText2,#mermaid-svg-BYPakgiCbWb6jzs9 .doneCritText3{fill:#000 !important}#mermaid-svg-BYPakgiCbWb6jzs9 .activeCritText0,#mermaid-svg-BYPakgiCbWb6jzs9 .activeCritText1,#mermaid-svg-BYPakgiCbWb6jzs9 .activeCritText2,#mermaid-svg-BYPakgiCbWb6jzs9 .activeCritText3{fill:#000 !important}#mermaid-svg-BYPakgiCbWb6jzs9 .titleText{text-anchor:middle;font-size:18px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 g.classGroup text{fill:#9370db;stroke:none;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:10px}#mermaid-svg-BYPakgiCbWb6jzs9 g.classGroup text .title{font-weight:bolder}#mermaid-svg-BYPakgiCbWb6jzs9 g.clickable{cursor:pointer}#mermaid-svg-BYPakgiCbWb6jzs9 g.classGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-BYPakgiCbWb6jzs9 g.classGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-BYPakgiCbWb6jzs9 .classLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.5}#mermaid-svg-BYPakgiCbWb6jzs9 .classLabel .label{fill:#9370db;font-size:10px}#mermaid-svg-BYPakgiCbWb6jzs9 .relation{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-BYPakgiCbWb6jzs9 .dashed-line{stroke-dasharray:3}#mermaid-svg-BYPakgiCbWb6jzs9 #compositionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BYPakgiCbWb6jzs9 #compositionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BYPakgiCbWb6jzs9 #aggregationStart{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-BYPakgiCbWb6jzs9 #aggregationEnd{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-BYPakgiCbWb6jzs9 #dependencyStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BYPakgiCbWb6jzs9 #dependencyEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BYPakgiCbWb6jzs9 #extensionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BYPakgiCbWb6jzs9 #extensionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BYPakgiCbWb6jzs9 .commit-id,#mermaid-svg-BYPakgiCbWb6jzs9 .commit-msg,#mermaid-svg-BYPakgiCbWb6jzs9 .branch-label{fill:lightgrey;color:lightgrey;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 .pieTitleText{text-anchor:middle;font-size:25px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 .slice{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 g.stateGroup text{fill:#9370db;stroke:none;font-size:10px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 g.stateGroup text{fill:#9370db;fill:#333;stroke:none;font-size:10px}#mermaid-svg-BYPakgiCbWb6jzs9 g.statediagram-cluster .cluster-label text{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 g.stateGroup .state-title{font-weight:bolder;fill:#000}#mermaid-svg-BYPakgiCbWb6jzs9 g.stateGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-BYPakgiCbWb6jzs9 g.stateGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-BYPakgiCbWb6jzs9 .transition{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-BYPakgiCbWb6jzs9 .stateGroup .composit{fill:white;border-bottom:1px}#mermaid-svg-BYPakgiCbWb6jzs9 .stateGroup .alt-composit{fill:#e0e0e0;border-bottom:1px}#mermaid-svg-BYPakgiCbWb6jzs9 .state-note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-BYPakgiCbWb6jzs9 .state-note text{fill:black;stroke:none;font-size:10px}#mermaid-svg-BYPakgiCbWb6jzs9 .stateLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.7}#mermaid-svg-BYPakgiCbWb6jzs9 .edgeLabel text{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .stateLabel text{fill:#000;font-size:10px;font-weight:bold;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BYPakgiCbWb6jzs9 .node circle.state-start{fill:black;stroke:black}#mermaid-svg-BYPakgiCbWb6jzs9 .node circle.state-end{fill:black;stroke:white;stroke-width:1.5}#mermaid-svg-BYPakgiCbWb6jzs9 #statediagram-barbEnd{fill:#9370db}#mermaid-svg-BYPakgiCbWb6jzs9 .statediagram-cluster rect{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-BYPakgiCbWb6jzs9 .statediagram-cluster rect.outer{rx:5px;ry:5px}#mermaid-svg-BYPakgiCbWb6jzs9 .statediagram-state .divider{stroke:#9370db}#mermaid-svg-BYPakgiCbWb6jzs9 .statediagram-state .title-state{rx:5px;ry:5px}#mermaid-svg-BYPakgiCbWb6jzs9 .statediagram-cluster.statediagram-cluster .inner{fill:white}#mermaid-svg-BYPakgiCbWb6jzs9 .statediagram-cluster.statediagram-cluster-alt .inner{fill:#e0e0e0}#mermaid-svg-BYPakgiCbWb6jzs9 .statediagram-cluster .inner{rx:0;ry:0}#mermaid-svg-BYPakgiCbWb6jzs9 .statediagram-state rect.basic{rx:5px;ry:5px}#mermaid-svg-BYPakgiCbWb6jzs9 .statediagram-state rect.divider{stroke-dasharray:10,10;fill:#efefef}#mermaid-svg-BYPakgiCbWb6jzs9 .note-edge{stroke-dasharray:5}#mermaid-svg-BYPakgiCbWb6jzs9 .statediagram-note rect{fill:#fff5ad;stroke:#aa3;stroke-width:1px;rx:0;ry:0}:root{--mermaid-font-family: '"trebuchet ms", verdana, arial';--mermaid-font-family: "Comic Sans MS", "Comic Sans", cursive}#mermaid-svg-BYPakgiCbWb6jzs9 .error-icon{fill:#522}#mermaid-svg-BYPakgiCbWb6jzs9 .error-text{fill:#522;stroke:#522}#mermaid-svg-BYPakgiCbWb6jzs9 .edge-thickness-normal{stroke-width:2px}#mermaid-svg-BYPakgiCbWb6jzs9 .edge-thickness-thick{stroke-width:3.5px}#mermaid-svg-BYPakgiCbWb6jzs9 .edge-pattern-solid{stroke-dasharray:0}#mermaid-svg-BYPakgiCbWb6jzs9 .edge-pattern-dashed{stroke-dasharray:3}#mermaid-svg-BYPakgiCbWb6jzs9 .edge-pattern-dotted{stroke-dasharray:2}#mermaid-svg-BYPakgiCbWb6jzs9 .marker{fill:#333}#mermaid-svg-BYPakgiCbWb6jzs9 .marker.cross{stroke:#333}
:root { --mermaid-font-family: "trebuchet ms", verdana, arial;}
#mermaid-svg-BYPakgiCbWb6jzs9 {
color: rgba(0, 0, 0, 0.75);
font: ;
}
前端页面
后台代码
请求
后台代码怎么知道用户想来做什么?
并且如何给这个请求分配对应的处理类呢?
前端页面
后台代码
(1) Servlet(Server Applet),全称Java Servlet。是用Java编写的服务器端程序,其主要功能在于交互式地浏览和 修改数据,生成动态Web内容。狭义的Servlet是指Java语言实现的一个接口,广义的Servlet是指任何实现了这个 Servlet接口的类,一般情况下,人们将Servlet理解为后者。
(2) Servlet运行于支持Java的应用服务器中。从实现上讲,Servlet可以响应任何类型的请求,但绝大多数情况下 Servlet只用来扩展基于HTTP协议的Web服务器。
(3) Servlet工作模式:
① 客户端发送请求至服务器
② 服务器启动并调用Servlet,Servlet根据客户端请求生成响应内容并将其传给服务器
③ 服务器将响应返回客户端
二、Servlet API
三、第一个Servlet
public class LoginServlet implements Servlet {
@Override
public void init(ServletConfig servletConfig
) throws ServletException
{
}
@Override
public ServletConfig
getServletConfig() {
return null
;
}
@Override
public void service(ServletRequest servletRequest
, ServletResponse servletResponse
) throws ServletException
, IOException
{
}
@Override
public String
getServletInfo() {
return null
;
}
@Override
public void destroy() {
}
}
//2. 在web.xml文档中配置好映射关系
// web.xml文档相当于是一个中转站,用于配置好请求与当前Servlet的映射关系。
<servlet>
<servlet-name>自定义名称
</servlet-name>
<servlet-class>处理请求的类的完整路径
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>自定义名称
</servlet-name>
<url-pattern>请求名
</url-pattern>
</servlet-mapping>
1.B端请求过来以后
->web
.xml
->servlet
-mapping标签中的url
-pattern标签中的内容和请求名 进行匹配
2.匹配成功后找对应的servlet
-mapping标签中的servlet
-name
3.去servlet标签中找和上一个servlet
-name相同的name值
4.去找servlet标签中的servlet
-class中处理类的完整路径
1.默认调取Service方法实现业务处理
, 发送请求时运行
2.init在service前运行一次
3.destroy在tomcat停止时运行
四、Servlet工作原理
(1) Servlet接口定义了Servlet与servlet容器(Tomcat)之间的契约。这个契约是:Servlet容器将Servlet类载入内存,并产生 Servlet实例和调用它具体的方法。但是要注意的是,在一个应用程序中,每种Servlet类型只能有一个实例(单例设计模式,多请求只产生一个实例)。
(2)用户请求致使Servlet容器调用Servlet的Service()方法,并传入一个ServletRequest对象和一个 ServletResponse对象。ServletRequest对象和ServletResponse对象都是由Servlet容器(例如TomCat)封装好的,并不需要程序员去实现,程序员可以直接使用这两个对象。
(3)ServletRequest中封装了当前的Http请求,因此,开发人员不必解析和操作原始的Http数据。ServletResponse 表示当前用户的Http响应,程序员只需直接操作ServletResponse对象就能把响应轻松的发回给用户。
(4)对于每一个应用程序,Servlet容器还会创建一个ServletContext对象。这个对象中封装了上下文(应用程序) 的环境详情。每个应用程序只有一个ServletContext。每个Servlet对象也都有一个封装Servlet配置的 ServletConfig对象。
五、Servlet的生命周期
当客户端首次发送第一次请求后,由容器(web服务器(tomcat))去解析请求, 根据请求找到对应的servlet,判断该类 的对象是否存在,不存在则创建servlet实例,调取init()方法 进行初始化操作,初始化完成后调取service()方法,由 service()判断客户端的请求方式,如果是get,则执行doGet(),如果是post则执行doPost().处理方法完成后,作出相 应结果给客户端.单次请求处理完毕。
当用户发送第二次以后的请求时,会判断对象是否存在,但是不再执行init(),而直接执行service方法,调取 doGet()/doPost()方法。
当服务器关闭时调取destroy()方法进行销毁。
四个过程:
(1)实例化 --先创建servlet实例
(2)初始化 --init()
(3)处理请求 —service()
(4)服务终止 --destory()
六、请求
前端到后端的过程,称为请求
HttpServletRequest表示Http环境中的Servlet请求。它扩展于javax.servlet.ServletRequest接口)
常用方法
1)String getParameter(String name) 根据表单组件名称获取提交数据,返回值是String
注:服务器在接收数据时使用字符串统一接收
2)String[ ] getParameterValues(String name) 获取表单组件对应多个值时的请求数据 3)void setCharacterEncoding(String charset) 指定每个请求的编码(针对post请求才起作用) 4)RequestDispatcher getRequestDispatcher(String path) --跳转页面
返回一个RequestDispatcher对象,该对象的forward( )方法用于转发请求 示例:
request
.getRequestDispatcher("../success.jsp").forward(request
,response
);
5)存值 request.setAttribute(“key”,value);
6)取值 request.getAttribute(“key”);//取值后需要向下转型
示例: String a1=(String)request.getAttribute(“uname”); 补充1:客户端如何发送数据给服务器
补充1:客户端如何发送数据给服务器
方式1:通过表单 get/post提交
方式2:通过a标签发送数据(get提交)
<a href="请求名?key=value&key=value&key=value...">
示例1:
<a href="/login?a=10&name=abc&pass=123">
这里的key值=表单元素的控件名,value值=表单中控件的value属性值
注:第一个参数使用?拼接,之后的参数使用&拼接,获取数据还是通过 String name=request.getParameter(“name”);
方式3:通过地址栏直接拼接-get请求
http://localhost/login?uname=abc&upass=123
方式4:js提交数据-get请求
location
.href
="目标请求?key=value&key=value"
注:方式2/3都属于get提交方式,表单提交可以使用get、post提交方式
补充2:处理请求乱码的问题
方式1:setCharacterEncoding(“UTF-8”);//post提交时管用
方式2: String s=new String(变量名.getBytes(“ISO-8859-1”),“UTF-8”);//针对于get提交时中文乱码
示例: String s=new String(request.getParameter(“key”).getBytes(“ISO-8859-1”),“GBK”);
方式3:修改tomcat中配置文件://使用于get提交
在Tomcat目录结构\conf\server.xml中设置字符集
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000"
redirectPort="8443" URIEncoding="UTF-8" />
注意:tomcat8.0以后不需要手动设置这个属性了
补充3:get和post的区别
1、GET请求,请求的数据会附加在URL之后,以?分割URL和传输数据,多个参数用&连接。URL的编码格式采用的 是ASCII编码,而不是uniclde,即是说所有的非ASCII字符都要编码之后再传输。
POST请求:POST请求会把请求的数据放置在HTTP请求包的包体中。上面的item=bandsaw就是实际的传输数据。
因此,GET请求的数据会暴露在地址栏中,而POST请求则不会。
2、传输数据的大小
在HTTP规范中,没有对URL的长度和传输的数据大小进行限制。但是在实际开发过程中,对于GET,特定的浏览器 和服务器对URL的长度有限制。因此,在使用GET请求时,传输数据会受到URL长度的限制。
对于POST,由于不是URL传值,理论上是不会受限制的,但是实际上各个服务器会规定对POST提交数据大小进行 限制,Apache、IIS都有各自的配置。
3、安全性
POST的安全性比GET的高。这里的安全是指真正的安全,而不同于上面GET提到的安全方法中的安全,上面提到的 安全仅仅是不修改服务器的数据。比如,在进行登录操作,通过GET请求,用户名和密码都会暴露再URL上,因为 登录页面有可能被浏览器缓存以及其他人查看浏览器的历史记录的原因,此时的用户名和密码就很容易被他人拿到 了。除此之外,GET请求提交的数据还可能会造成Cross-site request frogery攻击
七、响应
在Service API中,定义了一个HttpServletResponse接口,它继承自ServletResponse接口,专门用来封装HTTP响 应消息。 在HttpServletResponse接口中定义了向客户端发送响应状态码,响应消息头,响应消息体的方法。
常用方法:
void addCookie(Cookie var1);//给这个响应添加一个cookie
void sendRedirect(String var1) ;//发送一条响应码,将浏览器跳转到指定的位置
resp
.sendRedirect("/success.html");
PrintWriter getWriter() 获得字符流,通过字符流的write(String s)方法可以将字符串设置到response 缓冲区中, 随后Tomcat会将response缓冲区中的内容组装成Http响应返回给浏览器端。
PrintWriter writer
= resp
.getWriter();
writer
.print("<script>alert('请通过表单进行登录');location.href='/login.html'</script>");
setContentType() 设置响应内容的类型
resp
.setContentType("text/html;charset=utf-8");
八、重定向和转发的对比
页面跳转的模式共有2种:重定向和转发
其差别在于地址栏的差别
表单页面:http://localhost/login.html
转发模式:http://localhost/login
重定向模式:http://localhost/success.html
重定向:response.sendRedirect()
resp
.sendRedirect("/success.html");
转发:request.getRequestDispatcher("…/success.jsp").forward(request,response);
req
.getRequestDispatcher("/error.html").forward(req
,resp
);
相同点:都用来跳转页面
不同点: a.重定向时地址栏会改变,request中存储的数据会丢失.转发时地址栏显示的是请求页面的地址,request数据可以保存.
b.转发属于一次请求一次响应,重定向属于两次请求(地址栏修改了两次)两次响应。
补充:使用out对象往页面中输出js或html,css
out
.print("<script type='text/javascript'>alert('登录失败');location='../login.jsp'</script>");
注:使用js跳转页面,也会丢失request中的数据
resp
.setContentType("text/html;charset=utf-8");
PrintWriter writer
= resp
.getWriter();
writer
.print("<script>alert('请通过表单进行登录');location.href='/login.html'</script>");
九、会话
request存的值只能在单次请求中保存,保存的数据不能跨页面,当重定向时,request存的值会丢失
session的数据可以在多个页面中共享,即使重定向页面,数据不会丢失
session中可以包含n个request。
会话的概念:从打开浏览器到关闭浏览器,期间访问服务器就称为一次会话
常用方法( req.getSession().方法名() )
void setAttribute(String key,Object value) 以key/value的形式保存对象值,将数据存储在服务器端
Object getAttribute(String key) 通过key获取对象值
void invalidate() 设置session对象失效
String getId() 获取sessionid,当第一次登录成功后,session会产生一个唯一的id,浏览器之后访问时如果发现id值 还是之前id,那么说明 当前访问的属于同一个会话
System
.out
.println("LoginServlet->sessionid=" + req
.getSession().getId());
System
.out
.println("DemoServlet->sessionid=" + ((HttpServletRequest
)servletRequest
).getSession().getId());
void setMaxInactiveInterval(int interval) 设定session的非活动时间
示例:
方式1: session.setMaxInactiveInterval(10*60);//设置有效时间为10分钟
方式2:修改web.xml
<session-config>
<session-timeout>10
</session-timeout>
</session-config>
int getMaxInactiveInterval() 获取session的有效非活动时间(以秒为单位),默认的有效时间:30分钟
void removeAttribute(String key)
从session中删除指定名称(key)所对应的对象
小结 :让session失效的方式
(1)invalidate() (2)removeAttribute(“key”) (3)直接关闭浏览器。
示例:使用session验证用户是否登录
补充:
自动刷新到某页面:
注:在head标签中添加该标签,单位:秒
十、获取初始化参数
request.setCharacterEncoding(“utf-8”);代码的耦合度太高,不便于后期维护修改。可以通过初始化参数实现
实现方式:
(1)web.xml中先定义初始化参数
<servlet>
<servlet-name></servlet-name>
<servlet-class></servlet-class>
<init-param>
<param-name>encoding
</param-name>
<param-value>utf-8
</param-value>
</init-param>
</servlet>
(2)servlet中获得初始化参数,重写init()方法
String encoding
= null
;
public void init(ServletConfig config
) throws ServletException
{
encoding
= config
.getInitParameter("encoding");
}
注意:这种方式的初始化参数仅限于当前servlet中使用。
2.全局初始化参数
(1)定义,context-param是和servlet标签同级别
<context-param>
<param-name>code
</param-name>
<param-value>utf-8
</param-value>
</context-param>
(2)获得数据
String code
= null
;
@Override
public void init(ServletConfig config
) throws ServletException
{
code
= config
.getServletContext().getInitParameter("code");
}
十一、注解方式实现servlet
我们每次在搭建Servlet的时候都需要在web.xml文件中去匹配标签和标签,略显麻烦,是否有更简捷的方式?
自servlet3.0版本开始就提供了一种注解方式实现servlet的方法
注解(提供给程序读取的信息) – 注释(提供给程序员看的信息)
注解的格式:@开头的 如:@Override
@WebServlet注解配置Servlet --> 其功能等价于在web.xml文件中对标签进行配置
从Servlet3.0开始,配置Servlet支持注解方式,但还是保留了配置web.xml方式,所以使用Servlet有两种方式:
(1)Servlet类上使用@WebServlet注解进行配置
(2)web.xml文件中配置
@WebServlet常用属性(重点掌握)
测试代码如下:
1.UserServlet
通过注解方式配置,web.xml中不需要配置该Servlet
@WebServlet(name
= "myUserServlet",
urlPatterns
= "/user/test",
loadOnStartup
= 1,
initParams
= {
@WebInitParam(name
="name", value
="小明"),
@WebInitParam(name
="pwd", value
="123456")
}
)
public class UserServlet extends HttpServlet {
private static final long serialVersionUID
= 7109220574468622594L
;
@Override
public void init(ServletConfig config
) throws ServletException
{
super.init(config
);
System
.out
.println("servlet初始化...");
}
@Override
protected void doGet(HttpServletRequest request
, HttpServletResponse response
) throws ServletException
, IOException
{
response
.setContentType("text/html");
response
.setCharacterEncoding("utf-8");
PrintWriter pw
= response
.getWriter();
pw
.append("Hello Servlet!<br>" );
pw
.append("servletName:" + getServletName() + "<br>");
ServletConfig servletConfig
= this.getServletConfig();
Enumeration
<String> paramNames
= servletConfig
.getInitParameterNames();
while (paramNames
.hasMoreElements()) {
String paramName
= paramNames
.nextElement();
pw
.append(paramName
+ ":" + servletConfig
.getInitParameter(paramName
) + "<br>");
}
pw
.close();
}
@Override
protected void doPost(HttpServletRequest request
, HttpServletResponse response
) throws ServletException
, IOException
{
doGet(request
, response
);
}
}
2.测试结果
2.1应用启动时,servlet就会初始化,因为配置了loadOnStartup=1
2.2访问/user/test,页面上显示结果;表名参数正确初始化以及自定义的servlet名称
3.注 (1).loadOnStartup属性:标记容器是否在启动应用时就加载Servlet,默认不配置或数值为负数时表示客户端第一 次请求Servlet时再加载;0或正数表示启动应用就加载,正数情况下,数值越小,加载该Servlet的优先级越高;
实例://斜杠必须
@WebServlet(value
="/test1",loadOnStartup
=1)
(2).name属性:可以指定也可以不指定,通过getServletName()可以获取到,若不指定,则为Servlet的完整类 名,如:cn.edu.njit.servlet.UserServlet
(3).urlPatterns/value属性: String[]类型,可以配置多个映射,如:urlPatterns={"/user/test", “/user/example”}
实例://斜杠必须
@WebServlet(loadOnStartup
=1,urlPatterns
= {"/test1","/test2"})
(4).在使用注解方式时,需要注意:
根元素中不能配置属性metadata-complete=“true”,否则无法加载Servlet。metadata-complete属性表示通知 Web容器是否寻找注解,默认不写或者设置false,容器会扫描注解,为Web应用程序构建有效的元数据; metadata-complete=“true”,会在启动时不扫描注解(annotation)。如果不扫描注解的话,用注解进行的配置 就无法生效,例如:@WebServlet
(5).urlPatterns的常用规则:
/*或者/:拦截所有
*.do:拦截指定后缀
/user/test:拦截路径
/user/.do、/.do、test*.do都是非法的,启动时候会报错