zoukankan      html  css  js  c++  java
  • jwt rsa 签名 demo

    使用RSA算法签名,生成jwt令牌,这里用spring-security-jwt库,也可以使用jjwt库。

    只支持keystore为jks类型的证书。私钥加密,公钥验签。

    1、生成jwt

    public class CreateJwtTest {
    
        /***
         * 创建令牌测试
         */
        @Test
        public void testCreateToken(){
            //证书文件路径
            String key_location="abc.jks";
            //秘钥库密码
            String key_password="abc";
            //秘钥密码
            String keypwd = "abc";
            //秘钥别名
            String alias = "abc";
    
            //访问证书路径
            ClassPathResource resource = new ClassPathResource(key_location);
    
            //创建秘钥工厂
            KeyStoreKeyFactory keyStoreKeyFactory = new KeyStoreKeyFactory(resource,key_password.toCharArray());
    
            //读取秘钥对(公钥、私钥)
            KeyPair keyPair = keyStoreKeyFactory.getKeyPair(alias,keypwd.toCharArray());
    
            //获取私钥
            RSAPrivateKey rsaPrivate = (RSAPrivateKey) keyPair.getPrivate();
    
            //定义Payload
            Map<String, Object> tokenMap = new HashMap<>();
            tokenMap.put("id", "1");
            tokenMap.put("name", "me");
            tokenMap.put("roles", "ROLE_POWER,ROLE_USER");
    
            //生成Jwt令牌
            Jwt jwt = JwtHelper.encode(JSON.toJSONString(tokenMap), new RsaSigner(rsaPrivate));
    
            //取出令牌
            String encoded = jwt.getEncoded();
            System.out.println(encoded);
        }
    }

    2、取出令牌

    public class ParseJwtTest {
    
        /***
         * 校验令牌
         */
        @Test
        public void testParseToken(){
            //令牌
            String token = "略";
    
            //公钥
            String publickey = "略";
    
            //校验Jwt并生成jwt对象
            Jwt jwt = JwtHelper.decodeAndVerify(token, new RsaVerifier(publickey));
    
            //获取Jwt原始内容
            String claims = jwt.getClaims();
            System.out.println(claims);
    //jwt令牌 String encoded = jwt.getEncoded(); System.out.println(encoded); } }
  • 相关阅读:
    CentOS 7.3离线安装 JDK
    七:程序是在何种环境下运行的
    六:亲自尝试压缩数据
    五:内存和磁盘的亲密关系
    四:熟练使用有棱有角的内存
    三:计算机进行小数运算时出错的原因
    二:数据是用二进制数表示的
    一:对程序员来说CPU是什么?
    单元测试的艺术-入门篇
    蔡康永的说话之道2-透过说话,懂得把别放在心上
  • 原文地址:https://www.cnblogs.com/asker009/p/13355636.html
Copyright © 2011-2022 走看看