java由servlet实现登录的简单功能,并把用户名用cookie保存起来,读取cookie

14 篇文章 0 订阅
3 篇文章 0 订阅

1.编写登录界面

<!DOCTYPE html>
<html>
  <head>
    <title>Login.html</title>
	
    <meta name="keywords" content="keyword1,keyword2,keyword3">
    <meta name="description" content="this is my page">
    <meta name="content-type" content="text/html; charset=UTF-8">
    <title>登录界面</title>
  </head>
  
  <body>
      <h3>登录系统</h3>
    <form action="/myJavaEELearnDemo/Login" method="post">
    <label for="用户名:">用户名:</label><input type="text" name="userName" width="100px">
    </br>
    </br>
    <label for="用户名:">密 码:</label><input type="password" name="passWord" width="100px">
    </br>
    </br>
    <input type="submit" value="登录" />       <input type="reset" value="重新填写"/>
    </form>
  </body>
</html>

2.网页提交表单响应servlet并在web.xml中配置servlet

  <servlet>
    <servlet-name>Login</servlet-name>
    <servlet-class>com.lyh.serlet.Login</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>Login</servlet-name>
    <url-pattern>/Login</url-pattern>
  </servlet-mapping>

3.登录servlet 关键 源码:

获得用户名,并加密保存

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

		sun.misc.BASE64Encoder base64Encoder= new sun.misc.BASE64Encoder();
		ByteArrayOutputStream classBytes = new ByteArrayOutputStream();
		ObjectOutputStream oos = new ObjectOutputStream(classBytes);
		oos.writeObject(new MyCookie());
		oos.close();
		String classStr=base64Encoder.encode(classBytes.toByteArray());
		Cookie cookie= new Cookie("mycookie", classStr);
		cookie.setMaxAge(60*60*24);
		response.addCookie(cookie);
		RequestDispatcher readCookieDispatcher=getServletContext().getRequestDispatcher("/ReadCookie");
	        readCookieDispatcher.include(request, response);
}
ReadCookie关键源码

public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.setContentType("text/html");
		PrintWriter out = response.getWriter();
		out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">");
		out.println("<HTML>");
		out.println("  <HEAD><TITLE>A Servlet</TITLE></HEAD>");
		out.println("  <BODY>");
        
        try {
			sun.misc.BASE64Decoder base64Decoder = new sun.misc.BASE64Decoder();
			Cookie cookie2=getCookieValue(request.getCookies(), "mycookie");
			if (cookie2 == null) {
				return ;
				
			}
			String classStr=cookie2.getValue();
			out.println("<br/>"+classStr+"<br/>");
			byte[] classBytes = base64Decoder.decodeBuffer(classStr);
			ObjectInputStream ois=new ObjectInputStream(new ByteArrayInputStream(classBytes));
			MyCookie myCookie= (MyCookie)ois.readObject();
			out.println(myCookie.getMsg());
			
		} catch (Exception e) {
			// TODO: handle exception
		}
        
        
        
        
		out.println("  </BODY>");
		out.println("</HTML>");
		out.flush();
		out.close();
		
		
		
		
		
	}
    protected  Cookie getCookieValue(Cookie[] cookies,String name) {
	 if (cookies!=null) {
		for (Cookie c:cookies) {
			 if (c.getName().equals(name)) {
				return c;
			}
		}
	  }
	  return null;
    }







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值