一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語言 - JAVA教程 - java驗(yàn)證用戶是否已經(jīng)登錄 java實(shí)現(xiàn)自動(dòng)登錄

java驗(yàn)證用戶是否已經(jīng)登錄 java實(shí)現(xiàn)自動(dòng)登錄

2020-04-17 12:04lijiao JAVA教程

這篇文章主要介紹了java驗(yàn)證用戶是否已經(jīng)登錄,java實(shí)現(xiàn)自動(dòng)登錄,感興趣的小伙伴們可以參考一下

本文為大家分享了java驗(yàn)證用戶是否已經(jīng)登錄與實(shí)現(xiàn)自動(dòng)登錄的詳細(xì)代碼,供大家參考,具體內(nèi)容如下

1、驗(yàn)證用戶是否已經(jīng)登錄

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
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強(qiáng)轉(zhuǎn)成htt...
 
    HttpServletRequest req = (HttpServletRequest) request;
 
    //獲取session
 
    HttpSession ss = req.getSession();
 
    //從session中獲取user
 
    if(ss.getAttribute("user")==null){
 
      System.err.println("你還沒有登錄");
 
      req.getSession().setAttribute("msg", "請(qǐng)你先登錄");
 
      //重定向到登錄
 
      HttpServletResponse resp = (HttpServletResponse) response;
 
      resp.sendRedirect(req.getContextPath()+"/index.jsp");[W2]
 
    }else{
 
      //放行
 
      chain.doFilter(request, response);
 
    }
 
  }
 
  public void destroy() {
 
  }
 
}

配置到web.xml中且對(duì)jsps/*進(jìn)行過慮:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<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>

2、實(shí)現(xiàn)自動(dòng)登錄 

自動(dòng)登錄,是為了幫助用戶多次使用這個(gè)網(wǎng)頁時(shí),不用再次輸入用戶名和密碼就可以登錄。

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

 Name,value – 聲明時(shí) new Cookie(key,value);

 Path        - 默認(rèn)值,即為當(dāng)前保存cookie的這個(gè)serlvet所在的路徑。

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

 則說明:

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

如果:

保存Cookie類:http://loclhost:8080/project/a/b/AServlet,則Cookie的默認(rèn)path為;http://loclhost/project/a/b

第一步:開發(fā)一個(gè)登錄頁面

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<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">不自動(dòng)登錄
 
      <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>
 
    你已經(jīng)登錄了:${name}<br/>
 
    <a href="<c:url value='/LoginServlet'/>">退出</a>
 
  </c:otherwise>
 
</c:choose>

第二步:成功保存cookie

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
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);
 
   
 
  }
 
}

第三步:要求訪問本網(wǎng)點(diǎn)中任何一個(gè)頁面都應(yīng)該實(shí)現(xiàn)自動(dòng)登錄

寫一個(gè)過慮器,對(duì)所有url=/*進(jìn)行過慮。在doFilter中讀取所有cookie。是否存在名稱為autoLogin的名稱cookie。

永遠(yuǎn)都放行。

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
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")){//如果存在自動(dòng)登錄的cookie
 
         String value = c.getValue();//用戶名稱
 
         //登錄成功是指
 
         req.getSession().setAttribute("name", value);
 
         break;
 
       }
 
      }
 
    }
 
    //不管是否自動(dòng)登錄成
 
    chain.doFilter(request, response);
 
  }

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<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>

 第五步:開發(fā)退出

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
System.err.println("用戶退出");
 
    //刪除整個(gè)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");

第六步:優(yōu)化代碼

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

    所以應(yīng)該將LoginServet這個(gè)url在doFiler中不過過慮。

    且對(duì)退出也不能自動(dòng)登錄。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久精品小视频 | 欧美激情精品久久久久久不卡 | 天堂成人在线观看 | 日本在线播放视频 | 欧美一级在线 | 精品欧美男同同性videos | 国产精品高清在线 | 共妻高h | 4虎影院永久地址www | 亚洲视频一区在线播放 | 免费人成在线观看视频播放 | 女人与d0gxxx| 成年人免费在线播放 | 西西人体大胆啪啪私拍色约约 | 美女张开腿让我了一夜 | 偷偷狠狠的日日高清完整视频 | 免费看日产一区二区三区 | 久久久久久久99精品免费观看 | 好猛好紧好硬使劲好大刺激视频 | 亚洲欧美日韩国产综合专区 | 国产五月天在线 | 国产在线成人精品 | 动漫人物差差差动漫人物免费观看 | 亚洲乱亚洲23p女 | 午夜A级理论片左线播放 | 操姓 | chinese特色video| 亚洲精品乱码久久久久久蜜桃欧美 | 国产成人精品午夜在线播放 | 欧美福利在线播放 | 久久强奷乱码老熟女 | 久久一er精这里有精品 | 久久精品国产免费 | 欧美日本一道高清免费3区 欧美人做人爱a全程免费 | 亚洲美洲国产日产 | 女人全身裸露无遮挡免费观看 | 国产精品久久现线拍久青草 | 美女露奶奶 | 向日葵视频app下载18岁以下勿看 | 娇妻与公陈峰姚瑶最新版 | 午夜神器18以下不能进免费 |