91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ssm項目如何實現用戶登陸持久化

發布時間:2021-04-30 10:53:59 來源:億速云 閱讀:250 作者:小新 欄目:開發技術

小編給大家分享一下ssm項目如何實現用戶登陸持久化,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

用戶登錄持久化就是每次訪問不用賬號密碼來校驗身份,在用戶登錄第一次之后會返回一個token字符串,之后的訪問客戶端將這個token加到請求體里發給服務器就可以驗證身份了。

利用Jedis和JWT創建用戶token

1、JWT創建token

maven依賴:

<dependency>
            <groupId>com.auth0</groupId>
            <artifactId>java-jwt</artifactId>
            <version>3.3.0</version>
        </dependency>

創建JWT工具類

用于創建token和解析token

import com.auth0.jwt.JWT;
import com.auth0.jwt.JWTVerifier;
import com.auth0.jwt.algorithms.Algorithm;
import com.auth0.jwt.interfaces.Claim;
import com.auth0.jwt.interfaces.DecodedJWT;
 
public class JWTUtils {
 
    /**
     * 公鑰
     */
    private static String SECRET = "qiang";  //此處隨便設置一個自己的加密符號
    public static String createToken(int id, String username,
                                      String type) throws Exception {
        // 簽發時間
        Date iatDate = new Date();
 
        // 過期時間,7天時間
        Calendar nowTime = Calendar.getInstance();
        nowTime.add(Calendar.HOUR, 24 * 7);
        Date experiesDate = nowTime.getTime();
 
        Map<String, Object> map = new HashMap<String, Object>();
        map.put("alg", "HS256");
        map.put("typ", "JWT");
        String token = JWT.create()
                .withHeader(map)
                .withClaim("id", id)
                .withClaim("username", username)
                .withClaim("type", type)
                .withExpiresAt(experiesDate) // 設置過期的日期
                .withIssuedAt(iatDate) // 簽發時間
                .sign(Algorithm.HMAC256(SECRET)); // 加密
        return token;
    }
 
    /**
     * 解密
     */
 
    public static Map<String, Claim> verifyToken(String token) throws Exception {
        JWTVerifier verifier = JWT.require(Algorithm.HMAC256(SECRET)).build();
        DecodedJWT jwt = null;
        try {
            jwt = verifier.verify(token);  //核實token
        } catch (Exception e) {
            throw new Exception("登錄過期");
        }
        return jwt.getClaims();  //返回的是解析完的token,是一個map,里面有id,username,type鍵值對
    }
}

2、JedisUtil緩存token

首先講講Jedis,Jedis是集成了redis的一些命令操作,將其封裝的java客戶端,一般在其上封裝一層作為業務使用,封裝如下:

首先導入maven包,這里也需要啟動redis服務

<dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>2.9.0</version>
        </dependency>

然后設計一個Jedis工具類將其封裝

import redis.clients.jedis.Jedis;
 
public class JedisUtils {
 
    private static Jedis jedis;
    //初始化
    private static void init() {
        jedis = new Jedis("localhost");
    }
    //在redis中設置鍵值對存儲
    public static void setToken(String id, String token, int day) {
        int second = day * 60 * 60 * 24;
        JedisUtils.init();
        jedis.set(String.valueOf(id), token); //根據id存儲token
        jedis.expire(String.valueOf(id), second);  //設置token持續時間
    }
 
    public static String getToken(String id) {
        JedisUtils.init();
        String token = jedis.get(String.valueOf(id));  //獲取token
        return token;
    }
}

以上是“ssm項目如何實現用戶登陸持久化”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

ssm
AI

南木林县| 色达县| 德格县| 平遥县| 绿春县| 庆阳市| 体育| 库车县| 永昌县| 平邑县| 龙门县| 泰来县| 珲春市| 南部县| 武宁县| 科尔| 南康市| 固始县| 海城市| 洪湖市| 大庆市| 沧州市| 日土县| 林口县| 磐安县| 巴楚县| 鄂尔多斯市| 牡丹江市| 临城县| 龙口市| 永新县| 神池县| 新和县| 郧西县| 平山县| 大田县| 崇左市| 平顺县| 弋阳县| 泗洪县| 桓仁|