国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

java實現用戶自動登錄

2019-11-26 14:30:06
字體:
來源:轉載
供稿:網友

自動登錄,是為了幫助用戶多次使用這個網頁時,不用再次輸入用戶名和密碼就可以登錄。

自動登錄是指用戶將用戶的登錄信息,人,保存到本地的文件中Cookie中。

Name,value -聲明時 new Cookie(key,value); 

Path-默認值,即為當前保存cookie的這個serlvet所在的路徑。

如果Cookie在這樣的路徑:http://loclhost:8080/project/abc/AServlet

則Cookie的路徑為: http://loclhost/project/abc

則說明:

所在在http://loclhost/project/abc目錄下的servlet才可以讀取這個cookie的值。 

如果:

保存Cookie類:http://loclhost:8080/project/a/b/AServlet

則Cookie的默認path為http://loclhost/project/a/b

第一步:開發一個登錄頁面

<c:choose>  <c:when test="${empty sessionScope.name}">    <form name="x" method="post" action="<c:url value='/LoginServlet'/>">      Name:<input type="text" name="name"/><br/>      auto:      <input type="radio" name="auto" value="-1">不自動登錄      <br/>      <input type="radio" name="auto" value="1">1天<br/>      <input type="radio" name="auto" value="7">1周<br/>      <input type="submit"/>    </form>  </c:when>  <c:otherwise>    你已經登錄了:${name}<br/>    <a href="<c:url value='/LoginServlet'/>">退出</a>  </c:otherwise></c:choose>

第二步:成功保存cookie

public void doPost(HttpServletRequest request, HttpServletResponse response)      throws ServletException, IOException {    //接收用戶姓名    String name = request.getParameter("name");    String auto = request.getParameter("auto");    //將用戶信息放到session    request.getSession().setAttribute("name",name);    //判斷auto是否是-1    if(!auto.equals("-1")){      int day = Integer.parseInt(auto);//1|7      int seconds = 60*60*24*day;      //聲明cookie      Cookie c = new Cookie("autoLogin",name);      c.setMaxAge(seconds);      c.setPath(request.getContextPath());      //保存cookie      response.addCookie(c);         }  }

第三步:要求訪問本網點中任何一個頁面都應該實現自動登錄

寫一個過慮器,對所有url=/*進行過慮。在doFilter中讀取所有cookie。是否存在名稱為autoLogin的名稱cookie。

永遠都放行。

public void doFilter(ServletRequest request, ServletResponse response,      FilterChain chain) throws IOException, ServletException {    //在這兒讀取cookie    HttpServletRequest req = (HttpServletRequest) request;    //獲取所的有cookie    Cookie[] cs = req.getCookies();    if(cs!=null){      for(Cookie c:cs){       if(c.getName().equals("autoLogin")){//如果存在自動登錄的cookie         String value = c.getValue();//用戶名稱         //登錄成功是指         req.getSession().setAttribute("name", value);         break;       }      }    }    //不管是否自動登錄成    chain.doFilter(request, response);  }

第四涉:配置到web.xml中對所有url=/*

<filter>  <filter-name>auto</filter-name>  <filter-class>cn.itcast.filter.AutoFilter</filter-class> </filter> <filter-mapping>  <filter-name>auto</filter-name>  <url-pattern>/*</url-pattern> </filter-mapping>

第五步:開發退出

System.err.println("用戶退出");    //刪除整個session    request.getSession().invalidate();    Cookie c = new Cookie("autoLogin", "ddd");    c.setMaxAge(0);    c.setPath(request.getContextPath());    response.addCookie(c);//   request.getSession().removeAttribute("name");    response.sendRedirect(request.getContextPath()+"/index.jsp");

第六步:優化代碼

由于用戶在做手工登錄時,也會進入AutoFiilter的doFilter方法,且讀取所有Cookie遍歷一次。而這次遍歷對用戶來說是多余。

所以應該將LoginServet這個url在doFiler中不過過慮。

且對退出也不能自動登錄。

補充知識點:

驗證用戶是否已經登錄

package cn.hongxin.filter;import java.io.IOException;import javax.servlet.Filter;import javax.servlet.FilterChain;import javax.servlet.FilterConfig;import javax.servlet.ServletException;import javax.servlet.ServletRequest;import javax.servlet.ServletResponse;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import javax.servlet.http.HttpSession; public class LoginFilter implements Filter{  public void init(FilterConfig filterConfig) throws ServletException {  }  public void doFilter(ServletRequest request, ServletResponse response,      FilterChain chain) throws IOException, ServletException {    //將request強轉成htt...    HttpServletRequest req = (HttpServletRequest) request;    //獲取session    HttpSession ss = req.getSession();    //從session中獲取user    if(ss.getAttribute("user")==null){      System.err.println("你還沒有登錄");      req.getSession().setAttribute("msg", "請你先登錄");      //重定向到登錄      HttpServletResponse resp = (HttpServletResponse) response;      resp.sendRedirect(req.getContextPath()+"/index.jsp");[W2]     }else{      //放行      chain.doFilter(request, response);    }  }  public void destroy() {  }}

配置到web.xml中且對jsps/*進行過慮:

<filter>  <filter-name>login</filter-name>  <filter-class>cn.itcast.filter.LoginFilter</filter-class> </filter> <filter-mapping>  <filter-name>login</filter-name>  <url-pattern>/jsps/*</url-pattern>  <url-pattern>/views/*</url-pattern> </filter-mapping>

以上就是本文的全部內容,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 金山区| 白水县| 大宁县| 永宁县| 错那县| 浙江省| 乐业县| 十堰市| 望谟县| 无极县| 封丘县| 兴义市| 平果县| 得荣县| 应城市| 阳信县| 天门市| 刚察县| 宁化县| 荔波县| 林甸县| 苍梧县| 新化县| 奈曼旗| 资兴市| 宁阳县| 彭山县| 彝良县| 涟源市| 南京市| 开封县| 郴州市| 高雄市| 双柏县| 赤峰市| 湘潭县| 云和县| 无锡市| 读书| 开化县| 伊宁市|