servlet 是运行在服务器端的三大web组件之一 【web三大组件:Servlet Filter Listener】
是处理客户端请求的 还有表单提交的请求
接收请求:接收前端请求
处理请求:去数据库查询,获取数据库的数据
返回结果:
请求与响应的过程:下图
如何写简单的servlet
1)自定义一个servlet类实现servlet接口,实现接口就意味着实现接口的方法
public class AServlet implements Servlet{}
2)在web.xml文件中注册自定义的servlet
<!-- servlet标签用于向服务器注册一个servlet --> <servlet> <!-- servlet-name是我们使用的,我们使用这个servlet-name对servlet进行配置 --> <servlet-name>AServlet</servlet-name> <!-- servlet-class是自定义servlet的全类名,这个全类名是服务器使用,服务器用这个全类名创建一个servlet实例(对象) --> <servlet-class>com.neuedu.Servlet.AServlet</servlet-class> </servlet> <!-- servlet-mapping是用于做映射请求的 也就是输入什么地址会到当前servlet下处理--> <servlet-mapping> <servlet-name>AServlet</servlet-name> <url-pattern>/AServlet</url-pattern> </servlet-mapping> //注意:<url-pattern>标签中指定的映射路径不必和<servlet-name>指定的内容保持一致 只有浏览器地址栏中请求的url和<url-pattern>标签中的映射一致的时候,我们自定义的servlet类才会处理这个请求
servlet 有广义、狭义之分:
广义servlet:实现了Servlet接口的类都是广义的Servlet,自定义的servlet就是广义的
狭义servlet:指jdk中提供的servlet接口
init方法,在创建对象的时候调用,整个生命周期只被调用一次(因为servlet只创建一个对象)
servlet 生命周期 :由产生到销毁
servlet是由tomcat服务器管理
- 构造方法:只会在第一次访问servlet类的时候调用一次,调用一次就说明 servlet是单例的,多线程的!同时也是非线程安全的,也就是说在servlet中尽量不要再service方法中操作全局变量!!
- init方法:只会在第一次访问servlet的时候调用一次,对servlet对象进行初始化操作
- 调用service方法处理请求:在每次访问这个servlet的时候都调用一次,而且我们的业务逻辑也写在service方法
- destroy 销毁:只会在项目卸载的时候调用,也就是服务器关闭,tomcat关闭的时候
处理请求,跳转页面的两种方式
1.转发 --地址不变 只请求一次 不能跨域
request.getRequestDispatcher("要转发到的地址").forward(request,response);//地址栏地址不变
2.重定向 --地址变了 多次请求 可以跨域
response.sendRedirect("要转到的地址");//地址栏地址变了
在jsp页面中写 <form action="abc" method="post"> 用户名<input type="text" name="userid"><br> 密码<input type="password" name="pwd"><br> <input type="submit"> </form>
//action method必须有,method为post或者get,使用get会在地址上显示你输入的值
红框内为输入的值 形式是 name=输入值&name=输入值,但是这样会泄露密码,所以表单提交一般用post 不显示信息
四个作用域 ---配合jstl用
- pageContext --当前页面存放, 只能在当前页面取出
- request --当前页面存放 ,转发页面取出
- session --当前会话 失效时间(在淘宝页面15分钟不动的话,再次动需要重新登陆)不能跨浏览器,换另一个浏览器需重新登录
- aqqlication --当前服务器中 整个服务器共享 服务器不重启就一直有
最常用的 request ;application 几乎不用
优先级:pageContext > request > session > aqqlication
EL表达式:快速取出作用域中的值 ,所有作用域
pageContext.setAttribute("a", "page"); request.setAttribute("a", "request"); session.setAttribute("a", "session"); application.setAttribute("a", "application"); ${ a }//会将四个a全都取出来,但是根据优先级取出pageContext ${requestScope.a }//将取出request,将requestScope中的request换成session就取出session
ServletConfig :是一个接口 ,一个ServletConfig对象只代表当前的servlet类的配置信息!
代表:servlet的配置信息 --xml中的<servlet>
<servlet> <servlet-name>AServlet</servlet-name> <servlet-class>com.neuedu.Servlet.AServlet</servlet-class> </servlet>
获取方法:由服务器创建,通过init方法的参数直接传递给我们,我们直接在init方法中使用
功能:
getServletName( ) :获取当前servlet-name值
getInitParam( ) :获取当前的servlet的初始化参数
getServletConText( ) :获取当前web应用!
ServletConText
代表:当前web应用,也就是web.xml文件中的信息
获取:通过ServletConfig对象的getServletConText
功能:
getInitParameter( ):获取整个web应用的初始化参数,代码就是如下
xml文件中,在<servlet>外写:
<context-param> <param-name>password</param-name> <param-value>123456</param-value> </context-param>
String initParameter2 = config.getServletContext().getInitParameter("password"); System.out.println(initParameter2);
String initParameter2 = config.getServletContext().getRealPath(servletName); System.out.println(initParameter2);
//getrealpath()获取真实路径
- 虚拟路径:http://localhost:8080/day0807-servlet/index.html
- 真实路径:E:\安装软件包\eclipse安装 包\eclipse\working\day0807-servlet\WebContent\index.html
MyGenericServlet
1.定义一个抽象类实现servlet接口,保留service方法不实现,其余方法都实现!
2.自定义抽象类子类,在web.xml文件中注册一下这个子类
3.子类构造器->父类构造器->剩余子类构造器->init方法(如果子类有就调用子类的,没有就调用父类的)
HttpServlet
public CServlet() { super(); // TODO Auto-generated constructor stub } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { System.out.println("doGet请求"); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); }
HttpServletRequest
1.代表:浏览器向服务器发送的请求报文
2.获取:由tomcat服务器创建,然后作为参数传递给我们相对应的doGet或者doPost方法
3.功能:
getParameter( ):获取请求参数,如登陆的用户名和密码等
getContextPath( ):获取当前项目路径
setAttribute( )/getAttribute( ): 本身就是一个域对象
request.getRequestDispatcher("1.html").forward(request, response);//通过request跳转到1.html
getAttribute( ):四个域对象都可以使用,被作为传递对象,返回值是Object
getParameter( ):只可以被request使用,用于接收参数【url,form表单中】,返回值是String类型
HttpServletResponse
1.代表:服务器响应给浏览器的响应报文
2.获取:由服务器创建,然后做为参数传递给我们相对应的doGet或者doPost方法!
3.功能
response.getWriter().println("<h3>hello world!</h3>");//可以返回给浏览器一个页面或者一个页面片段! response.sendRedirect("/day0807-servlet/1.html");//服务器返给浏览器地址,浏览器需要再次访问服务器给的地址
转发和重定向
1.转发:当浏览器向服务器发送请求的时候,服务器自己不处理,而是调用其它的web资源进行处理!
2.重定向:当浏览器向服务器发送请求的时候,服务器返回给浏览器一个特殊的响应,这个特殊的响应告诉浏览器再向另一个地址发送一个请求!
|
发生在浏览器端还是服务器端
|
浏览器的请求次数
|
浏览器地址栏是否发生变化
|
浏览器是否能够感知到
|
request
|
服务器端
|
1
|
不变化
|
感知不到
|
response
|
浏览器端
|
2
|
发生变化
|
感知到
|
get:转发---doGet
重定向----doGet
post:转发---doPost
重定向---doGet
编码问题分析
通信双方在进行通信的时候,实际上是将通信的内容【信息】是按照一定的规则转化为二进制进行通讯的
而这个一定的规则就是字符的编码:ascii,gb2312,gbk,iso8859-1,utf-8;
在请求到达的时候,另一方就需要解码!
乱码原因:
通信双方的编码方式和解码方式不一致造成的,
解决办法:
统一通信双方的编码方式和解码方式,都使用utf-8编码!
编码分类:
请求编码
浏览器编码---》服务器解码iso8859-1
响应编码
服务器编码----》浏览器解码
服务器端默认使用的是iso8859-1编码,而浏览器默认使用的是gb2312,当然我们也可以在页面中告诉浏览器用什么编码方式!
请求编码
get请求
- 统一浏览器和服务器端的编码格式为utf-8编码:在server.xml文件的connector标签中指定编码格式为utf-8编码:URIEncoding="utf8"
post请求
- 我们可以在post方法中在第一次获取请求参数之前通过request.setCharacterEncoding("utf-8");来设置解码格式!
响应编码
可以通过response.setContentType("text/html;charset=utf-8");设置服务器和浏览器的编码和解码格式!
路径问题:
①相对路径和绝对路径
绝对路径:是以 / 开头的路径
相对于当前服务器的绝对路径:
相对于当前web应用的绝对路径:
相对路径:不是以 / 开头的路径
②常见的路径:
url-pattern:
转发的路径:
> 这两个的绝对路径由服务器解析,相对于项目的根目录
http://主机地址:端口号/项目名/
重定向的路径:
页面中的路径:
> 这两个路径有浏览器解析,相对于服务器的根目录
http://主机地址:端口号/
base标签
base标签里面有一个href属性,这个属性允许我们用使用相对路径的方式使用绝对路径!
我们再使用相对路径的时候,相对路径会以这个href属性值作为前缀!