目录
一,servlet介绍
1,什么是servlet
2,Servlet API
3,第一个servlet程序
二,servlet详解
1,工作原理
2,生命周期
3,补充
四,request常用方法
1,常用方法
1.1 String getParameter(String name)
1.2 String[ ] getParameterValues(String name)
1.3 RequestDispatcher getRequestDispatcher(String path)
1.4 存值 request.setAttribute("key",value); 取值 request.getAttribute("key");//取值后需要向下转型
2,客户端如何发送数据给服务器
3,处理请求乱码的问题
4,get和post的区别
五,response常用方法
六,转发和重定向
1,简介
2,对比
3,运行实例
3.1 转发方式
3.2 重定向方式
3.3 画图总结
七,session会话
1,介绍
2,常用方法
3,代码举例
八,初始化参数获取
1,局部初始化参数
2,全局初始化参数
3,代码举例
九,servlet3.0注解
1, @WebServlet常用属性
2,代码举例
3,注
3.1 loadOnStartup属性
3.2 name属性
3.3 urlPatterns/value属性
3.4 在使用注解方式时,需要注意:
(1) Servlet(Server Applet),全称Java Servlet。是⽤Java编写的服务器端程序,其主要功能在于交互式地浏览和修改数据,生成动态Web内容。
(2) Servlet运⾏于⽀持Java的应⽤服务器中。从实现上讲,Servlet可以响应任何类型的请求,但绝⼤多数情况下Servlet只⽤来扩展基于HTTP协议的Web服务器。
(3) Servlet⼯作模式:
1,在src文件夹中创建web.testServlet类
2,在web文件夹中创建lib文件夹,引入定义Servlet和HttpServlet的jar包javaee-api-7.0.jar
3,将jar包引入程序中
4,在testServlet中重写doGet、doPost方法
5,将前端页面和servlet联系在一起
6,运行
点击链接或按钮后控制台会显示对应的请求类型
注:如果运行项目后,可以跳转到正常页面,但一键入FirstHTML.html(自己编写的页面),就出现404,再访问localhost:8080也出现404时,可以参考这里@虎皮熊【IDEA部署项目到tomcat运行成功但是页面404的两种原因】
原因是Tomcat启动后的访问地址与定义的Application context不一致
折腾了一上午,(╯‵□′)╯︵┻━┻
(1) Servlet接⼝定义了Servlet与servlet容器之间的契约:
(2)⽤户请求致使Servlet容器调⽤Servlet的Service()⽅法
(3)ServletRequest中封装了当前的Http请求
(4)对于每⼀个应⽤程序,Servlet容器还会创建⼀个ServletContext对象。
当客户端⾸次发送第⼀次请求后,由容器(web服务器(tomcat))去解析请求,根据请求找到对应的servlet,判断该类的对象是否存在,不存在则创建servlet实例,调取init()⽅法 进⾏初始化操作,初始化完成后调取service()⽅法,由service()判断客户端的请求⽅式,如果是get,则执⾏doGet(),如果是post则执⾏doPost()。处理⽅法完成后,作出相应结果给客户端,单次请求处理完毕。
当⽤户发送第⼆次以后的请求时,会判断对象是否存在,但是不再执⾏init(),⽽直接执⾏service⽅法,调取doGet()/doPost()⽅法。
当服务器关闭时调取destroy()⽅法进⾏销毁。
感觉这里写的更加清晰易懂一点:@姠惢荇者【Servlet学习笔记-Servlet工作原理和过程】
Servlet
Servlet应用
Servlet容器
Tomcat容器
HttpServletRequest表示Http环境中的Servlet请求。它扩展于javax.servlet.ServletRequest接⼝
无论前台传递什么类型的数据,后台接受时都按照String处理
根据表单组件名称获取提交数据,返回值是String
注:服务器在接收数据时使⽤字符串统⼀接收
1,编写测试GET/POST传参的HTML页面
2,创建UsersServlet类
package com.xrh;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
public class UsersServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String uage = req.getParameter("uage");
String upass = req.getParameter("upass");
System.out.println("[GET] uage: " + uage + ",upass: " + upass);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String username = req.getParameter("username");
System.out.println("[POST] username: " + username);
}
}
3,在web.xml中进行配置
4,运行结果
点击超链接,触发GET请求。输入内容后点击提交,触发POST请求
5,处理POST请求乱码
void setCharacterEncoding(String charset) 指定每个请求的编码(针对post请求才起作⽤)
6,为何GET请求不会出现乱码?
JDK8之后不需要自己手动设置编码格式
获取表单组件对应多个值时的请求数据
1,修改页面,添加复选框(显示的值和传递到后端的值不一定相同,比如选中篮球,传递的是lanqiu)
2,修改UsersServlet
3,运行
跳转⻚⾯。返回⼀个RequestDispatcher对象,该对象的forward( )⽅法⽤于转发请求,示例:
request.getRequestDispatcher("../success.jsp").forward(request,response);
1,修改doPost
2,添加success页面
3,运行
方式一 通过表单 get/post提交
方式二 通过a标签发送数据(get提交)
示例:
这⾥的key值=表单元素的控件名,value值=表单中控件的value属性值
注:第⼀个参数使⽤?拼接,之后的参数使⽤&拼接,获取数据还是通过 String name=request.getParameter("name");
方式三 通过地址栏直接拼接-get请求
方式四 js提交数据-get请求
location.href="⽬标请求?key=value&key=value"
注:⽅式2/3都属于get提交⽅式,表单提交可以使⽤get、post提交⽅式
⽅式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中设置字符集
注意:tomcat8.0以后不需要⼿动设置这个属性了
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接⼝中定义了向客户端发送响应状态码,响应消息头,响应消息体的⽅法。
常⽤⽅法:
比较详细清晰的介绍可以参考这里,<( ̄︶ ̄)↗[GO!]@Zzzer!【重定向与转发的区别与应用】
目前跳转页面的方式有两种,一种是通过request的转发req.getRequestDispatcher,一种是通过response的重定向resp.sendRedirect。
重定向:response.sendRedirect()
转发:request.getRequestDispatcher("../success.jsp").forward(request,response);
相同点:
- 都⽤来跳转⻚⾯
不同点:
- a.重定向时地址栏会改变,request中存储的数据会丢失。转发时地址栏显示的是请求⻚⾯的地址,request数据可以保存。
- b.转发属于⼀次请求⼀次响应,重定向属于两次请求(地址栏修改了两次)两次响应。
- 补充:使⽤out对象往⻚⾯中输出js或html,css。使⽤js跳转⻚⾯,也会丢失request中的数据;
1,修改UsersServlet
2,程序运行后,键入FirstHTML页面
3,点击提交(地址栏不改变,只是返回了所需要的页面内容)
1,修改UsersServlet
2,程序运行后,键入FirstHTML页面
3,点击提交
request存的值只能在单次请求中保存,保存的数据不能跨⻚⾯,当重定向时,request存的值会丢失。
然而在浏览大型网站时,比如某宝,不管跳转到哪个页面,账户信息都是一直存在且不会丢失的。
这时就引入了会话对象:
会话的概念:从打开浏览器到关闭浏览器,期间访问服务器就称为⼀次会话,会话中可以包括n次request请求
1,void setAttribute(String key,Object value)
以key/value的形式保存对象值,将数据存储在服务器端
2,Object getAttribute(String key)
通过key获取对象值
3,void invalidate()
设置session对象失效
4,String getId()
获取sessionid,当第⼀次登录成功后,session会产⽣⼀个唯⼀的id,浏览器之后访问时如果发现id值还是之前id,那么说明 当前访问的属于同⼀个会话
5,void setMaxInactiveInterval(int interval)
设定session的⾮活动时间
示例:
⽅式1: session.setMaxInactiveInterval(10*60);//设置有效时间为10分钟
⽅式2:修改web.xml
10 //单位:分钟
6,int getMaxInactiveInterval()
获取session的有效⾮活动时间(以秒为单位),默认的有效时间:30分钟
7,void removeAttribute(String key)
从session中删除指定名称(key)所对应的对象
8,⼩结 :让session失效的⽅式
request.setCharacterEncoding("utf-8");代码的耦合度太⾼,不便于后期维护修改。可以通过初始化参数实现
1,web.xml中先定义初始化参数
encoding
utf-8
2,servlet中获得初始化参数,重写init()⽅法
public void init(ServletConfig config) throws ServletException {
encoding= config.getInitParameter("encoding");
}
注意:这种⽅式的初始化参数仅限于当前servlet中使⽤。
1, 定义,context-param是和servlet标签同级别
bianma
utf-8
2,获得数据
@Override // 请求->init()->service()->doget/dopost->destory();
public void init(ServletConfig config) throws ServletException {
bianhao=config.getServletContext().getInitParameter("bianma");
}
1,修改web.xml。添加UsersServlet局部初始化参数,和全局初始化参数
2,修改UsersServlet和TestServlet
public class UsersServlet extends HttpServlet {
@Override
public void init(ServletConfig config) throws ServletException {
//局部初始化参数
System.out.println("UsersServlet-init->myparam"+config.getInitParameter("myparam"));
//全局初始化参数
System.out.println("UsersServlet-init->allparam"+config.getServletContext().getInitParameter("encoding"));
}
}
public class TestServlet extends HttpServlet {
@Override
public void init(ServletConfig config) throws ServletException {
//局部初始化参数
System.out.println("TestServlet-init->myparam"+config.getInitParameter("myparam"));
//全局初始化参数
System.out.println("TestServlet-init->allparam"+config.getServletContext().getInitParameter("encoding"));
}
}
3,运行测试
如果一直采用在web.xml中插入标签的方法,该文件会变得非常冗杂。所以引入了注解的方式:
从Servlet3.0开始,配置Servlet⽀持注解⽅式,但还是保留了配置web.xml⽅式,所有使⽤Servlet有两种⽅式:
1,创建StudentServlet
package web;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
//name 可有可无 urlPatterns={"","",""}表示匹配多个模式
@WebServlet(urlPatterns = "/stu/test",
name = "myname",
initParams = {
@WebInitParam(name="init-stu",value = "myinitparam"),
@WebInitParam(name="pwd",value = "123456")
},
loadOnStartup = 1
)
public class StudentServlet extends HttpServlet {
@Override
public void init(ServletConfig config) throws ServletException {
System.out.println("StudentServlet-init"+config.getInitParameter("init-stu"));
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("do-get-StudentServlet");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
super.doPost(req, resp);
}
}
2,地址栏输入地址
可以看出程序正确执行
标记容器是否在启动应⽤时就加载Servlet。
实例://斜杠必须
@WebServlet(value="/test1",loadOnStartup=1)
可以指定也可以不指定,通过getServletName()可以获取到,若不指定,则为Servlet的完整类名,如:cn.edu.njit.servlet.UserServlet
String[]类型,可以配置多个映射,如:urlPatterns={"/user/test","/user/example"}实例:
//斜杠必须
@WebServlet(loadOnStartup=1,urlPatterns= {"/test1","/test2"})
根元素中不能配置属性metadata-complete="true",否则⽆法加载Servlet。
(5).urlPatterns的常⽤规则:
章节汇总在这里(づ ̄3 ̄)づ╭❤~@&再见萤火虫&【06-JavaWEB】
对学习Java感兴趣的同学欢迎加入QQ学习交流群:1126298731
有问题欢迎提问,大家一起在学习Java的路上打怪升级!(o゜▽゜)o☆[BINGO!]