Servlet监听-------------例子:显示在线列表,实现踢人功能

显示在线列表,实现踢人功能
1、domain 中的User.java
package com.hbsi.domain;
public class User {
   private String username;
   private String password;
public String getUsername() {
 return username;
}
public void setUsername(String username) {
 this.username = username;
}
public String getPassword() {
 return password;
}
public void setPassword(String password) {
 this.password = password;
}
}

2、servlet中的KickUserServlet.java
public class KickUserServlet extends HttpServlet {
 public void doGet(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  String username = request.getParameter("username");
  username = new String(username.getBytes("iso8859-1"),"UTF-8");
  Map map = (Map) this.getServletContext().getAttribute("map");
  HttpSession session = (HttpSession) map.get(username);
  if(session!=null){
   session.invalidate();
   map.remove(username);
  }
  request.getRequestDispatcher("/listuser.jsp").forward(request,response);
 }
 public void doPost(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  doGet(request, response);
 }
}

3、servlet中的LoginServlet.java
public class LoginServlet extends HttpServlet {
 public void doGet(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  String username = request.getParameter("username");
  String password = request.getParameter("password");
  User user = new User();
  user.setUsername(username);
  user.setPassword(password);
  request.getSession().setAttribute("user",user);//给session添加了属性 
  response.sendRedirect("/Listenertest/index.jsp"); 

 }
 public void doPost(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  doGet(request, response);
 }
}

4、web中的CharseterEncodingFilter.java
public class CharseterEncodingFilter implements Filter {
 private FilterConfig config = null;
 private String defaultCharset = "UTF-8";
 @Override
 public void destroy() {
  // TODO Auto-generated method stub
 }
 @Override
 public void doFilter(ServletRequest request, ServletResponse response,
   FilterChain chain) throws IOException, ServletException {
  String charset = config.getInitParameter("charset");
  if(charset==null){
   charset = defaultCharset;
  }
  request.setCharacterEncoding(charset);
  response.setCharacterEncoding("UTF-8");
  response.setContentType("text/html;charset="+charset);
  chain.doFilter(request, response);
 }
 @Override
 public void init(FilterConfig filterConfig) throws ServletException {
  this.config = filterConfig;

 }
}

5、web中的SessionListener.java
public class SessionListener implements HttpSessionAttributeListener {
 @Override
 public void attributeAdded(HttpSessionBindingEvent arg0) {
  Object obj = arg0.getValue();
  if(obj instanceof User){
   User user =(User)obj;
   HttpSession session = arg0.getSession();
   Map map = (Map) session.getServletContext().getAttribute("map");
   if(map==null){
    map = new HashMap();
    session.getServletContext().setAttribute("map",map);
   }
   map.put(user.getUsername(),session);
  } 
 }
 @Override
 public void attributeRemoved(HttpSessionBindingEvent arg0) {
  
 }
 @Override
 public void attributeReplaced(HttpSessionBindingEvent arg0) {

 }
}

6、页面:
(1)login.jsp
 <body>
   <form action="${pageContext.request.contextPath}/servlet/LoginServlet" method="post">
   用户名:<input type="text" name="username"/><br/>
   密码:<input type="password" name="password"/><br/>
   <input type="submit" value="登陆"/>
   </form>
  </body>

(2)index.jsp
<body>
   欢迎您:${user.username} <br>
  </body>

(3)listuser.jsp
<body>
   当前在线用户为:<br/>
   <c:forEach items="${map}" var="me">
   <c:url value="/servlet/KickUserServlet" var="url">
     <c:param name="username" value="${me.key}"></c:param>
   </c:url>
     ${me.key}<a href="${url}">剔出去</a><br/>
   </c:forEach>
  </body>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值