servlet,filter,sessionListener,cookie,session操作

1 篇文章 0 订阅

感谢作者分享,文章转自“:http://blog.csdn.net/tengdazhang770960436/article/details/7075034


servlet配置:


过程:程序根据客户端发送过来的请求,获取客户端要访问的url里面代表访问文件的那一部分,之后去web.xml里面去查找,根据所匹配的<servlet-mapping>来获取对应的servlet-name,根据servlet-name去查找对应的servlet-class所在的位置,根据servlet-class的位置去调用它里面的方法,调用的时候是由apache来实现的.

web.xml中的配置:

<servlet>
<!--servlet的名字-->
<servlet-name>test</servlet-name>
<!--servlet所对应的class所在的位置-->
<servlet-class>dada.test.FirstServlet</servlet-class>
<init-param>
<!--servlet的初始化参数-->
<param-name>name</param-name>
<!--servlet的初始化参数的值-->
<param-value>dada</param-value>
</init-param>
</servlet>

<servlet-mapping>
<!--servlet的名字与servlet对应-->
<servlet-name>test</servlet-name>
<!--出发此servlet的url-->
<url-pattern>/test</url-pattern>
</servlet-mapping>

servlet文件中处理:

private String name;
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {}

@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {}

@Override
public void init(ServletConfig config) throws ServletException {
name = config.getInitParameter("name");
System.out.println(name);
}

filter配置:

web.xml中的配置:

<filter>
<description>filter</description>
<filter-name>encoding</filter-name>
<filter-class>dada.test.EncodingFilter</filter-class>
<init-param>
<description>param</description>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>

<filter-mapping>
<filter-name>encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>


filter文件中处理:

//定义初始化的字符编码
private String encoding="ISO-8859-1";
@Override
public void destroy() {
this.encoding = null;
}

@Override
public void doFilter(ServletRequest req, ServletResponse resp,
FilterChain chain) throws IOException, ServletException {
HttpServletRequest request = (HttpServletRequest) req;
HttpServletResponse response = (HttpServletResponse) resp;
request.setCharacterEncoding(encoding);
System.out.println("当前的编码:"+request.getCharacterEncoding());
chain.doFilter(req, resp);
}


@Override
public void init(FilterConfig config) throws ServletException {
//获取初始化的参数
String encoding1 = config.getInitParameter("encoding");
System.out.println(encoding1);
this.encoding = encoding1==null||encoding1.equals("")?encoding:encoding1;
}

session配置:
web.xml

<listener>
<listener-class>
dada.CounterListener
</listener-class>
</listener>

CounterListener类:

public class CounterListener implements HttpSessionListener {
private static long onlineNumber = 0;


//开放获取在线人数的方法
public static long getOnlineNumber() {
return onlineNumber;
}
//当session创建时执行的方法
public void sessionCreated(HttpSessionEvent arg0) {
System.out.println("created");
onlineNumber++;
}
//当session销毁是执行的方法
public void sessionDestroyed(HttpSessionEvent arg0) {
System.out.println("created");
onlineNumber--;
}
}

调用监听器输出:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@page import="dada.CounterListener"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <body>
本网站目前访问人数:<%=CounterListener.getOnlineNumber()%>
  </body>
</html>

Cookie操作:

setCookie:

public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String username = request.getParameter("username");
Cookie cookie1 = new Cookie("username", username);
//cookie的有效期为1个月
cookie1.setMaxAge(24 * 60 * 60 * 30);
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Cookie cookie2 = new Cookie("lastTime", sdf.format(new Date()));
cookie2.setMaxAge(24 * 60 * 60 * 30);
response.addCookie(cookie1);
response.addCookie(cookie2);
}

getCookie:

public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
Cookie[] cookies = request.getCookies();
Cookie cookie = null;
for (int i = 0; i < cookies.length; i++) {
cookie = cookies[i];
if (cookie.getName().equals("username")) {
out.println("用户名:" + cookie.getValue());
out.println("<br>");
}
if (cookie.getName().equals("lastTime")) {
out.println("上次登录时间:" + cookie.getValue());
out.println("<br>");
}
}
}


session操作:

public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session = request.getSession();
Integer counter = (Integer) session.getAttribute("counter");
if (counter == null) {
counter = new Integer(1);
} else {
counter = new Integer(counter.intValue() + 1);
}
session.setAttribute("counter", counter);
session.setMaxInactiveInterval(3600);

response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
if (session.isNew()) {
out.println("这是一个新建的Session.<br><br>");
} else {
out.println("这不是一个新建的Session.<br><br>");
}
out.println("jsessionid: " + session.getId() + "<br><br>");
out.println("LastAccessedTime: " + session.getLastAccessedTime() + "<br>");
out.println("格式转换以后的LastAccessedTime: " + new Date(session.getLastAccessedTime()) + "<br><br>");
out.println("CreationTime: " + session.getCreationTime() + "<br>");
out.println("格式转换以后的CreationTime: " + new Date(session.getCreationTime()) + "<br><br>");
out.println("MaxInactiveInterval: " + session.getMaxInactiveInterval() + "秒<br>");
out.println("<br>使用Session对象的getAttributeNames<br>");
Enumeration enumer = session.getAttributeNames();
String name = null;
while (enumer.hasMoreElements()) {
name = (String) enumer.nextElement();
out.println("Session name:" + name + "<br>");
out.println("Session value:" + session.getAttribute(name) + "<br>");
}
// session.removeAttribute("counter");
// session.invalidate();
out.println("</body>");
out.println("</html>");
out.flush();
out.close();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值