直接重写service方法 HTTP 304 的理解
2016-05-25 00:00
483 查看
摘要: 直接重写service方法,避免httpServlet分发
以后继承BaseServlet 这个类来代替HttpServlet
对 HTTP 304 的理解
package cn.meeting.core;
import java.io.IOException;
import java.lang.reflect.Method;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* 抽象类,不能配置到web.xml中
*/
public abstract class BaseServlet extends HttpServlet {
/**
* 直接重写service方法,避免httpServlet分发
*/
@Override
public void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 接收一个参数,用于执行用户指定的方法
String methodName = req.getParameter("cmd");
if (methodName == null || methodName.trim().equals("")) {
methodName = "execute";
}
// 通过反射来调用子类的方法
try {
Method method = this.getClass().getMethod(methodName, HttpServletRequest.class, HttpServletResponse.class);
method.invoke(this, req, resp);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
/**
* 要求子类,必须要拥有一个默认的方法
*/
public abstract void execute(HttpServletRequest req, HttpServletResponse resp) throws Exception;
}
HTTP 中的 304 有了一些了解。
304 的标准解释是:Not Modified 客户端有缓冲的文档并发出了一个条件性的请求(一般是提供If-Modified-Since头表示客户只想比指定日期更新的文档)。服务器告诉客户,原来缓冲的文档还可以继续使用。
如 果客户端在请求一个文件的时候,发现自己缓存的文件有 Last Modified ,那么在请求中会包含 If Modified Since ,这个时间就是缓存文件的 Last Modified 。因此,如果请求中包含 If Modified Since,就说明已经有缓存在客户端。只要判断这个时间和当前请求的文件的修改时间就可以确定是返回 304 还是 200 。对于静态文件,例如:CSS、图片,服务器会自动完成 Last Modified 和 If Modified Since 的比较,完成缓存或者更新。但是对于动态页面,就是动态产生的页面,往往没有包含 Last Modified 信息,这样浏览器、网关等都不会做缓存,也就是在每次请求的时候都完成一个 200 的请求。
因此,对于动态页面做缓存加速,首先要在 Response 的 HTTP Header 中增加 Last Modified 定义,其次根据 Request 中的 If Modified Since 和被请求内容的更新时间来返回 200 或者 304 。虽然在返回 304 的时候已经做了一次数据库查询,但是可以避免接下来更多的数据库查询,并且没有返回页面内容而只是一个 HTTP Header,从而大大的降低带宽的消耗,对于用户的感觉也是提高。
以后继承BaseServlet 这个类来代替HttpServlet
对 HTTP 304 的理解
package cn.meeting.core;
import java.io.IOException;
import java.lang.reflect.Method;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* 抽象类,不能配置到web.xml中
*/
public abstract class BaseServlet extends HttpServlet {
/**
* 直接重写service方法,避免httpServlet分发
*/
@Override
public void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 接收一个参数,用于执行用户指定的方法
String methodName = req.getParameter("cmd");
if (methodName == null || methodName.trim().equals("")) {
methodName = "execute";
}
// 通过反射来调用子类的方法
try {
Method method = this.getClass().getMethod(methodName, HttpServletRequest.class, HttpServletResponse.class);
method.invoke(this, req, resp);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
/**
* 要求子类,必须要拥有一个默认的方法
*/
public abstract void execute(HttpServletRequest req, HttpServletResponse resp) throws Exception;
}
HTTP 中的 304 有了一些了解。
304 的标准解释是:Not Modified 客户端有缓冲的文档并发出了一个条件性的请求(一般是提供If-Modified-Since头表示客户只想比指定日期更新的文档)。服务器告诉客户,原来缓冲的文档还可以继续使用。
如 果客户端在请求一个文件的时候,发现自己缓存的文件有 Last Modified ,那么在请求中会包含 If Modified Since ,这个时间就是缓存文件的 Last Modified 。因此,如果请求中包含 If Modified Since,就说明已经有缓存在客户端。只要判断这个时间和当前请求的文件的修改时间就可以确定是返回 304 还是 200 。对于静态文件,例如:CSS、图片,服务器会自动完成 Last Modified 和 If Modified Since 的比较,完成缓存或者更新。但是对于动态页面,就是动态产生的页面,往往没有包含 Last Modified 信息,这样浏览器、网关等都不会做缓存,也就是在每次请求的时候都完成一个 200 的请求。
因此,对于动态页面做缓存加速,首先要在 Response 的 HTTP Header 中增加 Last Modified 定义,其次根据 Request 中的 If Modified Since 和被请求内容的更新时间来返回 200 或者 304 。虽然在返回 304 的时候已经做了一次数据库查询,但是可以避免接下来更多的数据库查询,并且没有返回页面内容而只是一个 HTTP Header,从而大大的降低带宽的消耗,对于用户的感觉也是提高。
相关文章推荐
- Sublime Text Package Control错误另解
- http协议
- 关于浏览器和网络的20项须知-什么是互联网?
- DLNA简介
- 判断网络的连接
- Tomcat的四种基于HTTP协议的Connector性能比较
- iOS开发--监测网络状态
- Lua使用luasocket http请求例子
- Lua使用luasocket http请求例子
- HDU 4940 Destroy Transportation system 无源汇有上下界的网络流
- python读取串口、网络编程、文本处理与文件操作
- Java 网络编程 练习
- Xutils使用手册(四)——网络请求
- Java实现简单的RPC调用(基于TCP协议)
- javaweb中Http协议详解
- USACO4.2 网络流模板题
- 网络编程之五种I/O模型
- HTTP协议详解
- 采用retrofit获取网络数据
- http之错误码