Shiro 会话管理和加密

  • 会话管理
  • 缓存
  • 加密

会话管理

Shiro提供了完整的企业级会话管理功能,不依赖于底层容器(如Tomcat),不管是J2SE还是J2EE环境都可以使用,提供了会话管理,会话事件监听,会话存储/持久化,容器无关的集群,失效/过期支持,对 Web 的透明支持,SSO 单点登录的支持等特性。

会话相关API

  • Subject.getSession():获取会话,等价于 Subject.getSession(true),即如果当前没有创建 session 对象会创建一个;Subject.getSession(false),如果当前没有创建 session 对象则返回 null。
  • session.getId():获取当前会话的唯一标识。
  • session.setAttribute(key,val) :设置会话属性。
  • session.getAttribute(key) :获取会话属性。
  • session.removeAttribute(key):删除会话属性。

SessionDAO
Shiro 提供 SessionDao 用于会话持久化。提供 CRUD 操作。
![在这里插入图片描述](https://img-blog.csdnimg.cn/20200922083219300.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NTg1NzkyNg==,size_16,color_FFFFFF,t_70#pic_center

  • AbstractSessionDAO 提供了 SessionDAO 的基础实现,如生成会话 ID 等。
  • CachingSessionDAO 提供了对开发者透明的会话缓存的功能,需要设置相应的 CacheManager。
  • MemorySessionDAO 直接在内存中进行会话维护。
  • EnterpriseCacheSessionDAO 提供了缓存功能的会话维护,默认情况下使用 MapCache 实现,内部使用 ConcurrentHashMap 保存缓存的会话。

在实际开发中,如果要用到 SessionDAO 组件,可以自定义类实现自 EnterpriseCacheSessionDAO 类,为其注入 sessionIdGenerator 属性,如果用到缓存的话还可以注入一个缓存的名字。最后将这个 SesionDAO 组件注入给 SessionManager(会话管理器),最后将 SessionManager 配置给 SecurityManager。

会话使用
建议在开发中,Controller 层使用原生的 HttpSession 对象,在 Service 层中使用 Shiro 提供的 Session 对象。如果在 Service 层中使用 HttpSession 对象,那么属于侵入式,并不建议这么做。Shiro 提供的 Session 能够很好的解决这个问题。

那么,问题来了,两种方式获取的 session 是否相同呢?

在 Controller 中,通过 request.getSession() 获取会话 session ,该 session 到底来源于
ServletRequest 还是由 Shiro 管理并创建的会话,主要由安全管理器 SecurityManager 和
SessionManager 会话管理器决定。

在使用默认 SessionManager 会话管理器的情况下,不管是通过 request.getSession() 或者 subject.getSession() 获取到 session,操作 session,两者都是等价的,请大家放心使用!
在这里插入图片描述
在这里插入图片描述

缓存

使用第三方的 shiro-redis 集成 redis 实现缓存

  1. 添加依赖
<dependency><groupId>org.crazycake</groupId><artifactId>shiro-redis</artifactId><version>3.1.0</version>
</dependency>
  1. application.properties 配置文件中添加 Redis 配置
# Redis数据库索引(默认为0)
spring.redis.database=0
# Redis服务器地址
spring.redis.host=localhost
# Redis 服务器连接端口
spring.redis.port=6379
# Redis服务器连接密码(默认为空)
spring.redis.password=hxy
#连接池最大连接数(使用负值表示没有限制)默认8
spring.redis.lettuce.pool.max-active=8
#连接池最大阳塞等待时间(使用负值表示没有限制)默认-1
spring.redis.lettuce.pool.max-wait=-1
#连接池中的最大空闲连接默认8
spring.redis.lettuce.pool.max-idle=8
#连接池中的最小空闲连接默认日
spring.redis.lettuce.pool.min-idle=0
#Redis服务超时时间
spring.redis.timeout=5000
  1. ShiroConfig.java
import at.pollux.thymeleaf.shiro.dialect.ShiroDialect;
import com.crm.pojo.Right;
import com.crm.service.RoleService;
import org.apache.shiro.authc.credential.HashedCredentialsMatcher;
import org.apache.shiro.mgt.SecurityManager;
import org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor;
import org.apache.shiro.spring.web.ShiroFilterFactoryBean;
import org.apache.shiro.web.mgt.DefaultWebSecurityManager;
import org.apache.shiro.web.session.mgt.DefaultWebSessionManager;
import org.crazycake.shiro.RedisCacheManager;
import org.crazycake.shiro.RedisManager;
import org.crazycake.shiro.RedisSessionDAO;
import org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;import javax.annotation.Resource;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;@Configuration
public class ShiroConfig {//注入 Redis 参数, 从application.properties获得@Value("${spring.redis.host}")private String host;@Value("${spring.redis.port}")private int port;@Value("${spring.redis.password}")private String password;@Value("${spring.redis.timeout}")private int timeout;@Resourceprivate RoleService roleService; @Beanpublic HashedCredentialsMatcher hashedCredentialsMatcher(){HashedCredentialsMatcher hashedCredentialsMatcher = new HashedCredentialsMatcher();//使用 md5 算法进行加密hashedCredentialsMatcher.setHashAlgorithmName("md5");//设置散列次数, 意为加密几次hashedCredentialsMatcher.setHashIterations(2);return hashedCredentialsMatcher;}@Bean(name = "shiroDialect")public ShiroDialect shiroDialect() {//thymeleaf页面上使用shiro标签return new ShiroDialect();}/*** 开启shiro注解(如@RequiresRoles,@RequiresPermissions),* 需借助SpringAOP扫描使用shiro注解类,并在必要时进行安全逻辑验证* 配置以下两个bean(DefaultAdvisorAutoProxyCreator和AuthorizationAttributeSourceAdvisor)*/@Beanpublic DefaultAdvisorAutoProxyCreator advisorAutoProxyCreator() {DefaultAdvisorAutoProxyCreator advisorAutoProxyCreator = new DefaultAdvisorAutoProxyCreator();advisorAutoProxyCreator.setProxyTargetClass(true);return advisorAutoProxyCreator;}/*** 开启aop注解支持*/@Beanpublic AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor(SecurityManager securityManager) {AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor = new AuthorizationAttributeSourceAdvisor();authorizationAttributeSourceAdvisor.setSecurityManager(securityManager);return authorizationAttributeSourceAdvisor;}public RedisManager redisManager() {RedisManager redisManager = new RedisManager();redisManager.setHost(host);redisManager.setPort(port);redisManager.setPassword(password);redisManager.setTimeout(timeout);return redisManager;}public RedisCacheManager cacheManager() {RedisCacheManager cacheManager = new RedisCacheManager();cacheManager.setRedisManager(redisManager());//缓存名称cacheManager.setPrincipalIdFieldName("userName");//缓存有效时间cacheManager.setExpire(1800);return cacheManager;}//会话操作public RedisSessionDAO redisSessionDAO() {RedisSessionDAO sessionDAO = new RedisSessionDAO();sessionDAO.setRedisManager(redisManager());return sessionDAO;}//会话管理public DefaultWebSessionManager sessionManager(){DefaultWebSessionManager sessionManager = new DefaultWebSessionManager();sessionManager.setSessionDAO(redisSessionDAO());return sessionManager;}@Beanpublic MyShiroRealm myShiroRealm() {//自定义RealmMyShiroRealm shiroRealm = new MyShiroRealm();//设置启用缓存,并设置缓存名称shiroRealm.setCachingEnabled(true);shiroRealm.setAuthorizationCachingEnabled(true);shiroRealm.setAuthorizationCacheName("authorizationCache");//设置凭证匹配器shiroRealm.setCredentialsMatcher(hashedCredentialsMatcher());return shiroRealm;}@Beanpublic SecurityManager securityManager() {//安全管理器SecurityManagerDefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();//注入RealmsecurityManager.setRealm(myShiroRealm());//注入缓存管理器securityManager.setCacheManager(cacheManager());securityManager.setSessionManager(sessionManager());return securityManager;}@Beanpublic ShiroFilterFactoryBean shiroFilterFactory(SecurityManager securityManager) {//Shiro过滤器:权限验证ShiroFilterFactoryBean shiroFilterFactory = new ShiroFilterFactoryBean();//注入SecurityManagershiroFilterFactory.setSecurityManager(securityManager);//权限验证:使用Filter控制资源(URL)的访问shiroFilterFactory.setLoginUrl("/login");shiroFilterFactory.setSuccessUrl("/main");shiroFilterFactory.setUnauthorizedUrl("/403");Map<String, String> filterChainDefinitionMap = new LinkedHashMap<String, String>();//必须使用LinkedHashMap(有序集合)//配置可以匿名访问的资源(URL): 静态资源filterChainDefinitionMap.put("/statics/css/**", "anon");filterChainDefinitionMap.put("/statics/fonts/**", "anon");filterChainDefinitionMap.put("/statics/images/**", "anon");filterChainDefinitionMap.put("/statics/js/**", "anon");filterChainDefinitionMap.put("/statics/localcss/**", "anon");filterChainDefinitionMap.put("/statics/lcaljs/**", "anon");filterChainDefinitionMap.put("/login", "anon");filterChainDefinitionMap.put("/logout", "logout");//注销过滤器,自动注销//配置需要特定权限才能访问的资源(URL)//静态授权:包括全部需要特定权限才能访问的资源(URL)/*filterChainDefinitionMap.put("/list","perms[用户列表]");filterChainDefinitionMap.put("/add","perms[用户添加]");filterChainDefinitionMap.put("/modify","perms[用户编辑]");filterChainDefinitionMap.put("/del","perms[用户删除]");*///动态授权List<Right> rights = roleService.findAllRights();for (Right right : rights) {if (right.getRightUrl() != null && !right.getRightUrl().trim().equals("")) {filterChainDefinitionMap.put(right.getRightUrl(), "perms[" + right.getRightCode() + "]");}}//配置认证访问,其他资源(URL)必须认证通过才能访问filterChainDefinitionMap.put("/**", "authc");//必须放在过滤器链的后面shiroFilterFactory.setFilterChainDefinitionMap(filterChainDefinitionMap);return shiroFilterFactory;}}

在测试中如出现了 java.lang.ClassCastException: com.crm.pojo.User cannot be cast to com.crm.pojo.User 异常, 原因是我们的项目可能使用了热部署, 所以造成类加载器不一致所导致。
解决方案:
在 resource 目录下新建 META-INF 目录,在 META-INF 目录下新建 spring-devtools.properties文件,在 spring-devtools.properties 文件中添加以下两条配置信息:

		restart.include.shiro-redis=/shiro-[\\w-\\.]+jarrestart.include.thymeleaf-extras-shiro=/thymeleaf-extras-[\\w-\\.]+jar

配置完成后重启服务就OK了。

加密

哈希与盐
如果你需要保存密码(比如网站用户的密码),你要考虑如何保护这些密码数据,像下面那样直接将密码写入数据库中是极不安全的,因为任何可以打开数据库的人,都将可以直接看到这些密码,比如之前的600w CSDN账号泄露对用户可能造成很大损失。
在这里插入图片描述
解决的办法是将密码加密后再存储进数据库,比较常用的加密方法是使用哈希函数(散列算法),常见的散列算法如 MD5、SHA 等。哈希函数的具体定义,大家可以在网上或者相关书籍中查阅到,简单地说,它的特性如下:

  • 原始密码经哈希函数计算后得到一个哈希值
  • 改变原始密码,哈希函数计算出的哈希值也会相应改变
  • 同样的密码,哈希值也是相同的

哈希函数是单向、不可逆的。也就是说从哈希值,你无法推算出原始的密码是多少。

一般进行散列时最好提供一个 salt(盐),加密领域的盐 salt,不是炒菜的调料,而是为了提高加密的安全性。不管是对称加密,还是非对称加密,在用户信息和算法可能被泄漏的情况下,都存在密码被反推算出来的可能。在加密环节如果加盐,等于多了一重安全因素。一般来说,盐就是一个不被外界知道的随机字符串,把用户的明文密码加上盐,再进行加密得到密文(密码的加密后的形式)。

比如加密密码 “admin” ,产生的散列值是 “21232f297a57a5a743894aOe4a801fc3”,可以到一些 MD5 解密网站很容易的通过散列值得到密码 “admin”,即如果直接对密码进行散列相对来说破解更容易,此时我们可以加一些只有系统知道的干扰数据,如用户名和 ID(即盐);这样散列的对象是"密码+用户名+ID",这样生成的散列值相对来说更难破解。

@Testpublic void testMd5Hash(){String password = "admin";String salt = "zxcv";Md5Hash  md5Hash = new Md5Hash(password,salt,2);System.out.println(md5Hash.toString());//输出: b8421ab1ac24e33a5cea864549c054e6}

如上代码通过盐 “zxcv” MD5 散列 “admin”。2 表示散列次数,

加密与验证+登录次数限制
加依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

如上的 ShiroConfig :

@Beanpublic HashedCredentialsMatcher hashedCredentialsMatcher(){HashedCredentialsMatcher hashedCredentialsMatcher = new HashedCredentialsMatcher();//使用 md5 算法进行加密hashedCredentialsMatcher.setHashAlgorithmName("md5");//设置散列次数, 意为加密几次hashedCredentialsMatcher.setHashIterations(2);return hashedCredentialsMatcher;}
@Beanpublic MyShiroRealm myShiroRealm() {//自定义RealmMyShiroRealm shiroRealm = new MyShiroRealm();//设置启用缓存,并设置缓存名称shiroRealm.setCachingEnabled(true);shiroRealm.setAuthorizationCachingEnabled(true);shiroRealm.setAuthorizationCacheName("authorizationCache");//设置凭证匹配器shiroRealm.setCredentialsMatcher(hashedCredentialsMatcher());return shiroRealm;}

加 MyShiroRealm.java

import org.apache.shiro.authc.*;
import org.apache.shiro.authz.AuthorizationInfo;
import org.apache.shiro.authz.SimpleAuthorizationInfo;
import org.apache.shiro.crypto.hash.Md5Hash;
import org.apache.shiro.realm.AuthorizingRealm;
import org.apache.shiro.subject.PrincipalCollection;
import org.apache.shiro.util.ByteSource;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.data.redis.core.ValueOperations;import javax.annotation.Resource;
import java.util.Set;
import java.util.concurrent.TimeUnit;public class MyShiroRealm extends AuthorizingRealm {//安全数据源@Resourceprivate UserService userService;@Resourceprivate StringRedisTemplate stringRedisTemplate;//redis中数据的key的前缀private String SHIRO_LOGIN_COUNT = "shiro_login_count_";//登录计数private String SHIRO_IS_LOCK = "shiro_is_lock_";//锁定用户登录@Overrideprotected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) {System.out.println("调用MyShiroRealm.doGetAuthorizationInfo获取权限信息!");//获得权限信息User user = (User) principalCollection.getPrimaryPrincipal();SimpleAuthorizationInfo info = new SimpleAuthorizationInfo();//静态授权:授权主体(用户)相应的角色和权限/*info.addRole(user.getRole().getRoleName());info.addStringPermission("用户列表");//所有用户拥有用户列表权限if("管理员".equals(user.getRole().getRoleName())){//管理员拥有"增删改"权限info.addStringPermission("用户添加");info.addStringPermission("用户编辑");info.addStringPermission("用户删除");}*///动态授权Role role = user.getRole();if(role!=null){info.addRole(user.getRole().getRoleName());Set<Right> rights = role.getRights();if(rights!=null && rights.size()>0){for (Right right :rights){info.addStringPermission(right.getRightCode());}}}return info;}@Overrideprotected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException {System.out.println("调用MyShiroRealm.doGetAuthenticationInfo获取身份信息!");//获得身份信息UsernamePasswordToken token = (UsernamePasswordToken)authenticationToken;String userName = token.getUsername();//每次访问,登录次数+1ValueOperations<String,String> opsForValue = stringRedisTemplate.opsForValue();opsForValue.increment(SHIRO_LOGIN_COUNT+userName,1);//计数大于5时,设置用户被锁定一小时,清空登录计数if (Integer.parseInt(opsForValue.get(SHIRO_LOGIN_COUNT + userName)) > 2) {opsForValue.set(SHIRO_IS_LOCK + userName, "LOCK",1, TimeUnit.MINUTES);stringRedisTemplate.delete(SHIRO_LOGIN_COUNT + userName);}if ("LOCK".equals(opsForValue.get(SHIRO_IS_LOCK + userName))) {throw new DisabledAccountException();}User user = userService.getUserByUserName(userName);if(user==null){throw new UnknownAccountException();//账号错误}if(user.getUserFlag()==null||user.getUserFlag().intValue()==0){throw new LockedAccountException();//账号锁定}SimpleAuthenticationInfo info = new SimpleAuthenticationInfo(user,//身份(根据用户名查询数据库获得的用户)user.getUserPassword(),//凭证(查询数据库获得密码)ByteSource.Util.bytes("zxcv"),//加密使用的saltgetName()//Realm对象的名称);//返回身份信息return info;}}

控制器:

@Controller
public class LoginController {@Resourceprivate UserService userService;@Resourceprivate StringRedisTemplate stringRedisTemplate;private String SHIRO_LOGIN_COUNT = "shiro_login_count_";@RequestMapping(value = "/login", method = RequestMethod.POST)public String login(String userName, String userPassword, Model model, HttpSession session) {try {UsernamePasswordToken token = new UsernamePasswordToken(userName,userPassword);Subject subject = SecurityUtils.getSubject();subject.login(token);//认证,登录stringRedisTemplate.delete(SHIRO_LOGIN_COUNT+userName);//认证(登录)成功User user = (User)subject.getPrincipal();session.setAttribute("loginUser",user);System.out.println(user);return "main";} catch (UnknownAccountException| IncorrectCredentialsException e) {model.addAttribute("userName",userName);model.addAttribute("userPassword",userPassword);model.addAttribute("error","用户名或密码错误,登录失败!");return "login";} catch (LockedAccountException e) {model.addAttribute("userName",userName);model.addAttribute("userPassword",userPassword);model.addAttribute("error","用户被禁用,登录失败!");return "login";} catch (AuthenticationException e) {model.addAttribute("userName",userName);model.addAttribute("userPassword",userPassword);model.addAttribute("error","多次错误,账号已被锁定!");return "login";}}
}

测试时记得启动 Redis

完成

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 准博士经验分享:如何平衡工作与考博备考,做到高效学习

    上一期陈泽宇学长的答疑分享给也想跨专业考博的小伙伴们给予了很大帮助&#xff0c;那么这一次给大家答疑分享的是刘杨学长&#xff0c;那些想平衡工作与考博备考的博友赶紧来看看~ 这些问题答疑都是满满的干货&#xff01;快来看看你的问题学长是怎么解答的~如果觉得对你有帮…...

    2024/5/1 9:45:14
  2. osgEarth版本发行说明

    版本2.10.1&#xff08;2019年4月&#xff09; 基于2.10分支的错误修复和性能发布。 版本2.10&#xff08;2018年11月&#xff09; REX地形引擎升级为默认。旧的MP引擎现在处于旧的支持模式。 从SDK中删除了osgearthqt nodekit&#xff0c;以及所有qt示例 清理内部序列化架构…...

    2024/5/1 9:31:20
  3. android高仿今日头条富文本编辑(发布文章)

    前言&#xff1a; 在经历了几个月的项目期限。我们遇到了前端发布文章&#xff0c;要用到富文本编辑的功能。在一番衡量下最终用到了richeditor-android第三方框架。实现原理就是通过webView和js实现前端富文本。有想了解的可以点开上面链接&#xff0c;研究研究。虽然richedit…...

    2024/5/1 9:46:37
  4. Centos7克隆虚拟机的网络问题(亲测有效版)

    1、vmware的网络配置 我当时局域网通了&#xff0c;但是无法连接外网就是因为vm的网络配置出问题&#xff0c;选择桥接模式就ok了。 2、Centos的配置 2.1、修改hosts跟hostname vim /etc/hosts vim /etc/hostname修改为自己的IP地址。 2.2、查看mac地址 ip addr #查看mac地…...

    2024/4/29 3:07:59
  5. AutoCAD家具设计入门到精通视频教程

    AutoCAD 家具设计入门到精通视频教程 家具图纸设计 链接&#xff1a;https://pan.baidu.com/s/1Dql8hIZ4Rk_aapkHnDyVHA 提取码&#xff1a;w844...

    2024/5/1 10:01:52
  6. [bug]编译报错configure: error: Cannot find pam解决方案

    参考文章 https://mariadb.com/kb/en/installing-correct-libraries-for-pam-and-readline/ 解决方法 对于Centos 和 RHEL-build sudo yum install pam-devel对于Debian/Ubuntu sudo apt-get install libpam0g-dev对于debian6/maverick/natty sudo apt-get install libre…...

    2024/4/30 14:24:27
  7. Docker容器时差、Docker内部Jenkins时差问题

    docker容器采用的是UTC时区&#xff0c;需要将容器指定为UTC8时区 可直接将宿主机的/etc/localtime直接加载到docker卷当中&#xff08;确认宿主机时期时间等没有问题&#xff09; #docer-compose jenkins:image: jenkins/jenkins:ltscontainer_name: jenkinsvolumes:- /etc/…...

    2024/5/1 10:12:57
  8. Registry 容器镜像服务端细节

    引言 通常我们在使用集群或者容器的时候&#xff0c;都会接触到存储在本地的镜像&#xff0c;也或多或少对本地镜像存储有一定的了解。但是服务端的镜像存储细节呢&#xff1f;本文主要介绍容器镜像的服务端存储结构&#xff0c;对于自建镜像服务或是对容器镜像底层原理或优化…...

    2024/4/27 14:20:56
  9. MySQL cmd命令行 执行sql脚本文件

    方法一 直接在命令行输入&#xff0c;无需进入mysql&#xff0c;但是要事先建好数据库&#xff1a; mysql -u用户名 -p密码 -D数据库名 < sql脚本绝对路径例子&#xff1a; mysql -uroot -p123456 -Dtest < C:\data.sql方法二 在命令行进入mysql并进入相应数据库后&…...

    2024/4/29 9:22:40
  10. Code=3000 “未找到应用程序的“aps-environment”的授权字符串“

    极光推送报错Code3000 "未找到应用程序的“aps-environment”的授权字符串"&#xff0c;网上呢一股脑的方案是&#xff1a;描述文件&#xff0c;推送证书与项目中的bundle identifer 不一致&#xff0c;或者什么appid不一致呀&#xff0c;什么证书生成顺序不一致呀&a…...

    2024/4/30 14:40:27
  11. 新手站长怎样租用高性能的美国服务器?

    我们知道很多外贸企业都会选择美国服务器搭建网站&#xff0c;这个也是有一定原因的&#xff0c;尤其是一些大型的电子商务外贸网站&#xff0c;他们对服务器的要求比较高&#xff0c;服务器的性能及配置是这些企业考虑的首要条件&#xff0c;那么对于这些外贸企业新手应该怎样…...

    2024/5/1 8:54:20
  12. Centos7远程桌面

    一、安装环境 云主机&#xff08;8c16g&#xff09; 一块云硬盘&#xff08;2500G&#xff09; 操作系统&#xff1a;CentOS7.5 &#xff08;默认最小化安装&#xff09; 数据库&#xff1a;Oracle Database 12cR2 二、前期准备 1. 关闭防火墙、更新源 setenforce 0 system…...

    2024/4/28 7:51:38
  13. 批量获取微信公众号用户openID及用户信息

    本文代码基于微信开发文档-用户管理-获取用户列表一节开发 在使用代码之前请确认你已阅读并理解上面文档提到的相关知识。 文章目录1、工具类的构建2、数据实体类的构建3、批量获取用户openid4、批量获取用户信息1、工具类的构建 首先创建如下代码到RestTemplateUtil.java文件…...

    2024/4/27 6:18:02
  14. S32DS使用官方SDK建立工程后更改芯片引脚( 以S32K144为例 )

    S32DS 使用官方SDK建立工程后更改芯片引脚( 以S32K144为例 ) 1、新建工程 2、【Window】->【show viwe】->【other】&#xff0c;输入【Component Library】&#xff0c;打开【Component Library】窗口&#xff0c;选择【Processors】&#xff0c;选择【SDK_S32K1xx_15…...

    2024/5/1 7:36:42
  15. 芯片设计

    当初阿里巴巴收购了中天微芯片公司。经过大量注资&#xff0c;在过去短短一年的时间里&#xff0c;达摩院就卖出了两亿多块芯片。除了简单工业模块芯片&#xff0c;达摩院还表示要自研NPU芯片。...

    2024/4/26 19:52:48
  16. 有序列表

    去重&#xff1a;O&#xff08;n&#xff09; 查找&#xff1a;O&#xff08;n&#xff09;...

    2024/4/29 11:17:16
  17. 系统集成项目管理工程师各种口诀技巧分享(2)

    6.信息系统生命周期&#xff1a;花开云消&#xff0c;划分即试验&#xff08;立项&#xff0c;开发&#xff0c;运行&#xff0c;消亡 规划&#xff0c;分析&#xff0c;设计&#xff0c;实施&#xff0c;验收&#xff09; 7.软件维护&#xff1a;就是鱼丸&#xff08;纠错性&a…...

    2024/4/27 20:23:00
  18. Tableau学习笔记-03 | 基本表、凸显表、树形图、气泡图、动态气泡图、词云图

    Tableau学习笔记-03 | 基本表、凸显表、树形图、气泡图、动态气泡图、词云图 一、学习笔记 1、基本表 行&#xff1a;地区文本&#xff1a;记录数2、不同地区酒店数量凸显表 行&#xff1a;地区标签&#xff1a;记录数颜色&#xff1a;记录数标记&#xff1a;方形3、不同地…...

    2024/4/27 5:43:19
  19. 宝塔面板修改端口号无法登陆 改回端口还是不行?

    改了宝塔面板端口后&#xff0c;因为防火墙没有放行对应端口等原因&#xff0c;面板就无法访问了 如果想还原之前端口大概会这么做 网上直接查到的方法 连接终端后执行 /www/server/panel/data/port.pl //查看端口&#xff0c;确实改了但是访问不到echo ‘8888’ > /www/…...

    2024/4/26 19:52:02
  20. Android style AppTheme节点中的部分标签说明

    <!--状态栏颜色--><item name"colorPrimaryDark">color/colorPrimaryDark</item><!--控制各个控件被选中时的颜色--><item name"colorAccent">color/colorAccent</item><!--页面背景色--><item name"an…...

    2024/4/27 23:15:20

最新文章

  1. 网优小工具-基站ID行列转换

    网优小工具&#xff0d;基站ID行列转换 因在日常工作需要对基站ID批量行转列&#xff0c;以方便在网管上批量筛选指定网元&#xff0c;该小工具基于微软Power Query插件编写&#xff0c;工具方便、简洁、易用&#xff0c;共享出来以方便工作。 工作界面 &#xff11;.粘贴需筛…...

    2024/5/1 12:26:16
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. vue想要突破全局样式限制又不影响别的页面样式怎么办

    <!-- 用scope盖不住全局&#xff0c;随意来个class匹配私定&#xff0c;搜索关键词&#xff1a;不要随便改&#xff0c;乱打class名 --> <style> .lkajsdfjkalsfhkljashkflhaskl .el-input.el-input--default.el-input--suffix { width: 160px !important; } …...

    2024/4/30 17:14:20
  4. 大唐杯历届省赛押题训练(6)

    考试-呼叫建立流程 一、单选题 1下面关于T-ADS被叫域选择下面说法正确的是( )1分/1分 A、被叫域选择是由MME发起的信令过程 B、T-ADS,过程是AS向3合1融合数据库查询T-ADS信息的过程 C、被叫域选择由主叫UE发起的域选择过程 D、主要是解决主叫驻留在那个网络的问题 提…...

    2024/4/30 17:16:11
  5. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/1 10:25:26
  6. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/4/30 0:57:52
  7. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/4/29 18:43:42
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/1 4:07:45
  9. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/4/30 23:32:22
  10. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/4/30 23:16:16
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/1 6:35:25
  12. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/1 11:24:00
  13. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/1 4:35:02
  14. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/4/30 14:53:47
  15. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/4/30 22:14:26
  16. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/1 6:34:45
  17. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/4/30 22:57:18
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/4/30 20:39:53
  19. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/1 4:45:02
  20. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/1 8:32:56
  21. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/4/29 3:42:58
  22. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/1 11:51:23
  23. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/1 5:23:20
  24. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/4/30 20:52:33
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57