java Servlet
一、servlet简介
Servlet 本身不能独立运行,需要在一个web应用中运行的而一个web应用是部署在tomcat中的 。
二、一个简单登录页面的流程图
当浏览器使用get方式提交数据的时候,servlet需要提供doGet()方法哪些是get方式呢?
1.form默认的提交方式
2.如果通过一个超链访问某个地址
3.如果在地址栏直接输入某个地址ajax指定使用get方式的时候
哪些是post方式呢?
1.在form上显示设置 method="post"的时候ajax指定post方式的时候
三、关于servlet中的service()
LoginServlet继承了HttpServlet,同时也继承了一个方法
//service(HttpServletRequest , HttpServletResponse )
实际上,在执行doGet()或者doPost()之前,都会先执行service()
由service()方法进行判断,到底该调用doGet()还是doPost()
可以发现,service(), doGet(), doPost() 三种方式的参数列表都是一样的。
所以,有时候也会直接重写service()方法,在其中提供相应的服务,就不用区分到底是get还是post了。
四、servlet生命周期
1.实例化
当用户通过浏览器输入一个路径,这个路径对应的servlet被调用的时候,该Servlet就会被实例化
为LoginServlet显式提供一个构造方法 LoginServlet()
无论访问了多少次LoginSerlvet构造方法 只会执行一次,所以Serlvet是单实例的。同时它还是线程不安全的
2.初始化
LoginServlet 继承了HttpServlet,同时也继承了init(ServletConfig) 方法
init 方法是一个实例方法,所以会在构造方法执行后执行。无论访问了多少次LoginSerlvet,init初始化 只会执行一次
3.提供服务
接下来就是执行service()方法,然后通过浏览器传递过来的信息进行判断,是调用doGet()还是doPost()方法,在service()中就会编写我们的业务代码
4.销毁
接着是销毁destroy()在如下几种情况下,会调用destroy()
该Servlet所在的web应用重新启动在serverl.xml中配置该web应用的时候用到了如果把 reloadable="false" 改为reloadable="true" 就表示有任何类发生的更新,web应用会自动重启,当web应用自动重启的时候,destroy()方法就会被调用
关闭tomcat的时候 destroy()方法会被调用,但是这个一般都发生的很快,不易被发现。
5.被回收
当该Servlet被销毁后,就满足垃圾回收的条件了。 当下一次垃圾回收GC来临的时候,就有可能被回收。
五-servlet跳转页面
1.服务器端跳转
//request.getRequestDispatcher("success.html").forward(request, response);
服务端跳转可以看到浏览器的地址依然是之前访问的/login 路径,并不会变成success.html
2.客户端跳转
//response.sendRedirect("fail.html");
六、自启动
在web.xml中,配置Hello Servlet的地方,增加一句
取值范围是1-99,中的10表示启动顺序,如果有多个Servlet都配置了自动启动,小的数字先启动即表明该Servlet会随着Tomcat的启动而初始化。
同时,为HelloServlet提供一个init(ServletConfig) 方法,验证自启动。
七、Servlet文件上传后显示(<img src="">)
1.保存在服务器部署路径
String filename = System.currentTimeMillis() + ".jpg";
String photoFolder =request.getServletContext().getRealPath("uploaded");
响应:《img width='200' height='150' src='uploaded/%s'》
2.保存在服务器,但不在代码部署路径
String photoFolder="D:/img/"+120.jpg:
响应:<img src="file:///D:/img/120.jpg">
八、servlet弊端
一个比较明显的弊端就是在Servlet编写html代码很痛苦,效率不高,可读性差,难以维护。
九、servlet也可以实现前后端分离
1.前台页面
2.后端