ExceptionTranslationFilter

ExceptionTranslationFilterSecurity Filter)允许将AccessDeniedExceptionAuthenticationException转换为HTTP响应。ExceptionTranslationFilter作为Security Filters之一插入到FilterChainProxy中。

在这里插入图片描述

  1. 首先,ExceptionTranslationFilter调用FilterChain.doFilter(request, response),即调用应用程序的其余部分(出现异常才执行自己的逻辑)。
    在这里插入图片描述
    在这里插入图片描述
  2. 如果用户未经身份验证或是身份验证异常,则启动身份验证。
    在这里插入图片描述
    1. 清除SecurityContextHolder的身份验证(SEC-112:清除SecurityContextHolder的身份验证,因为现有身份验证不再有效)。
    2. HttpServletRequest保存在RequestCache中。当用户成功进行身份验证时,RequestCache用于重现原始请求。
    3. AuthenticationEntryPoint用于从客户端请求凭据。例如,它可能会重定向到登录页面或发送WWW-Authenticate标头。
      在这里插入图片描述
  3. 否则,如果是AccessDeniedException,则拒绝访问。调用AccessDeniedHandler来处理拒绝的访问。
    在这里插入图片描述

想要了解Spring Security的过滤器链如何在Spring应用程序中发挥作用,可以阅读下面这篇博客:

  • Spring Security:介绍 & 初体验 & 源码与日志分析

AuthenticationEntryPoint

ExceptionTranslationFilter会使用AuthenticationEntryPoint启动身份验证方案。

public interface AuthenticationEntryPoint {/*** 启动身份验证方案* ExceptionTranslationFilter将在调用此方法之前使用请求的目标URL填充名为AbstractAuthenticationProcessingFilter.SPRING_SECURITY_SAVED_REQUEST_KEY的HttpSession属性* 实现应根据需要修改ServletResponse上的标头以开始身份验证过程*/void commence(HttpServletRequest request, HttpServletResponse response,AuthenticationException authException) throws IOException, ServletException;
}

BasicAuthenticationEntryPoint

ExceptionTranslationFilter用于通过BasicAuthenticationFilter开始身份验证。一旦使用BASIC对用户代理进行身份验证,注销需要关闭浏览器或发送未经授权的 (401) 标头。 实现后者最简单的方法是调用BasicAuthenticationEntryPoint类的commence(HttpServletRequest, HttpServletResponse, AuthenticationException)方法。 这将向浏览器指示其凭据不再被授权,导致它提示用户再次登录。

public class BasicAuthenticationEntryPoint implements AuthenticationEntryPoint,InitializingBean {// 领域名称private String realmName;// 检查属性public void afterPropertiesSet() {Assert.hasText(realmName, "realmName must be specified");}public void commence(HttpServletRequest request, HttpServletResponse response,AuthenticationException authException) throws IOException {// 填充响应response.addHeader("WWW-Authenticate", "Basic realm=\"" + realmName + "\"");response.sendError(HttpStatus.UNAUTHORIZED.value(), HttpStatus.UNAUTHORIZED.getReasonPhrase());}...
}

DelegatingAuthenticationEntryPoint

AuthenticationEntryPoint实现,它根据RequestMatcher匹配选择(委托)一个具体的AuthenticationEntryPoint

public class DelegatingAuthenticationEntryPoint implements AuthenticationEntryPoint,InitializingBean {private final Log logger = LogFactory.getLog(getClass());// RequestMatcher与AuthenticationEntryPoint的映射private final LinkedHashMap<RequestMatcher, AuthenticationEntryPoint> entryPoints;// 默认AuthenticationEntryPointprivate AuthenticationEntryPoint defaultEntryPoint;// 构造方法public DelegatingAuthenticationEntryPoint(LinkedHashMap<RequestMatcher, AuthenticationEntryPoint> entryPoints) {this.entryPoints = entryPoints;}// 构造方法public void commence(HttpServletRequest request, HttpServletResponse response,AuthenticationException authException) throws IOException, ServletException {// 迭代entryPointsfor (RequestMatcher requestMatcher : entryPoints.keySet()) {if (logger.isDebugEnabled()) {logger.debug("Trying to match using " + requestMatcher);}// 如果RequestMatcher匹配请求if (requestMatcher.matches(request)) {// 获取匹配请求的RequestMatcher对应的AuthenticationEntryPointAuthenticationEntryPoint entryPoint = entryPoints.get(requestMatcher);if (logger.isDebugEnabled()) {logger.debug("Match found! Executing " + entryPoint);}// 委托给匹配请求的RequestMatcher对应的AuthenticationEntryPointentryPoint.commence(request, response, authException);return;}}if (logger.isDebugEnabled()) {logger.debug("No match found. Using default entry point " + defaultEntryPoint);}// 没有匹配的入口,使用defaultEntryPointdefaultEntryPoint.commence(request, response, authException);}/*** 没有RequestMatcher返回true时使用的EntryPoint(默认)*/public void setDefaultEntryPoint(AuthenticationEntryPoint defaultEntryPoint) {this.defaultEntryPoint = defaultEntryPoint;}// 检查属性public void afterPropertiesSet() {Assert.notEmpty(entryPoints, "entryPoints must be specified");Assert.notNull(defaultEntryPoint, "defaultEntryPoint must be specified");}
}

DigestAuthenticationEntryPoint

SecurityEnforcementFilter用于通过DigestAuthenticationFilter开始身份验证。发送回用户代理的随机数将在setNonceValiditySeconds(int)指示的时间段内有效,默认情况下为300秒。 如果重放攻击是主要问题,则应使用更短的时间。如果性能更受关注,则可以使用更大的值。当nonce过期时,此类正确显示stale=true标头,因此正确实施的用户代理将自动与新的nonce值重新协商(即,不向用户显示新的密码对话框)。

public class DigestAuthenticationEntryPoint implements AuthenticationEntryPoint,InitializingBean, Ordered {private static final Log logger = LogFactory.getLog(DigestAuthenticationEntryPoint.class);// 用于验证用户身份的字符串键值private String key;// 领域名称private String realmName;// nonce有效时间private int nonceValiditySeconds = 300;// private int order = Integer.MAX_VALUE; ...// 检查属性public void afterPropertiesSet() {if ((realmName == null) || "".equals(realmName)) {throw new IllegalArgumentException("realmName must be specified");}if ((key == null) || "".equals(key)) {throw new IllegalArgumentException("key must be specified");}}public void commence(HttpServletRequest request, HttpServletResponse response,AuthenticationException authException) throws IOException {HttpServletResponse httpResponse = response;// 计算随机数(由于代理,请勿使用远程IP地址)// 随机数格式为:base64(expirationTime + ":" + md5Hex(expirationTime + ":" + key))// 过期时间long expiryTime = System.currentTimeMillis() + (nonceValiditySeconds * 1000);// 由下面三个步骤计算随机数String signatureValue = DigestAuthUtils.md5Hex(expiryTime + ":" + key);String nonceValue = expiryTime + ":" + signatureValue;String nonceValueBase64 = new String(Base64.getEncoder().encode(nonceValue.getBytes()));// 用于填充响应的验证HeaderString authenticateHeader = "Digest realm=\"" + realmName + "\", "+ "qop=\"auth\", nonce=\"" + nonceValueBase64 + "\"";if (authException instanceof NonceExpiredException) {authenticateHeader = authenticateHeader + ", stale=\"true\"";}if (logger.isDebugEnabled()) {logger.debug("WWW-Authenticate header sent to user agent: "+ authenticateHeader);}// 填充响应httpResponse.addHeader("WWW-Authenticate", authenticateHeader);httpResponse.sendError(HttpStatus.UNAUTHORIZED.value(),HttpStatus.UNAUTHORIZED.getReasonPhrase());}// 设置key属性public void setKey(String key) {this.key = key;}...
}

Http403ForbiddenEntryPoint

在预验证的验证案例中(与CAS不同),用户已经通过某种外部机制被识别,并且在调用security-enforcement过滤器时建立了一个安全上下文。因此,此类实际上并不负责身份验证的入口,就像其他提供者的情况一样。 如果用户被AbstractPreAuthenticatedProcessingFilter拒绝,它将被调用,从而导致null身份验证。commence方法将始终返回HttpServletResponse.SC_FORBIDDEN403 错误,除非拥有授权否则服务器拒绝提供所请求的资源)。

public class Http403ForbiddenEntryPoint implements AuthenticationEntryPoint {private static final Log logger = LogFactory.getLog(Http403ForbiddenEntryPoint.class);/*** 始终向客户端返回403错误代码*/public void commence(HttpServletRequest request, HttpServletResponse response,AuthenticationException arg2) throws IOException {if (logger.isDebugEnabled()) {logger.debug("Pre-authenticated entry point called. Rejecting access");}response.sendError(HttpServletResponse.SC_FORBIDDEN, "Access Denied");}
}

HttpStatusEntryPoint

发送通用HttpStatus作为响应的AuthenticationEntryPoint。对于由于浏览器拦截响应而无法使用Basic身份验证的JavaScript客户端很有用。

public final class HttpStatusEntryPoint implements AuthenticationEntryPoint {// 用于设置响应的状态码private final HttpStatus httpStatus;/*** 构造方法*/public HttpStatusEntryPoint(HttpStatus httpStatus) {Assert.notNull(httpStatus, "httpStatus cannot be null");this.httpStatus = httpStatus;}public void commence(HttpServletRequest request, HttpServletResponse response,AuthenticationException authException) {// 根据httpStatus属性的值,设置响应的状态码response.setStatus(httpStatus.value());}
}

LoginUrlAuthenticationEntryPoint

ExceptionTranslationFilter用于通过UsernamePasswordAuthenticationFilter开始表单登录身份验证。在loginFormUrl属性中保存登录表单的URL,并使用它来构建到登录页面的重定向URL。或者,可以在此属性中设置绝对URL,并将其专门使用。

使用相对URL时,可以将forceHttps属性设置为true,以强制用于登录表单的协议为HTTPS,即使原始截获的资源请求使用HTTP协议。发生这种情况时,在成功登录(通过 HTTPS)后,原始资源仍将通过原始请求URL作为HTTP访问。如果使用绝对URL,则forceHttps的值将不起作用。

public class LoginUrlAuthenticationEntryPoint implements AuthenticationEntryPoint,InitializingBean {private static final Log logger = LogFactory.getLog(LoginUrlAuthenticationEntryPoint.class);// 向调用者提供有关哪些HTTP端口与系统上的哪些HTTPS端口相关联的信息private PortMapper portMapper = new PortMapperImpl();// 端口解析器,基于请求解析出端口private PortResolver portResolver = new PortResolverImpl();// 登陆页面URLprivate String loginFormUrl;// 默认为false,即不强制Https转发或重定向private boolean forceHttps = false;// 默认为false,即不是转发到登陆页面,而是进行重定向private boolean useForward = false;private final RedirectStrategy redirectStrategy = new DefaultRedirectStrategy();/*** loginFormUrl – 可以找到登录页面的URL* 应该是相对于web-app上下文路径(包括前导/)或绝对URL*/public LoginUrlAuthenticationEntryPoint(String loginFormUrl) {Assert.notNull(loginFormUrl, "loginFormUrl cannot be null");this.loginFormUrl = loginFormUrl;}// 检查属性public void afterPropertiesSet() {Assert.isTrue(StringUtils.hasText(loginFormUrl)&& UrlUtils.isValidRedirectUrl(loginFormUrl),"loginFormUrl must be specified and must be a valid redirect URL");if (useForward && UrlUtils.isAbsoluteUrl(loginFormUrl)) {throw new IllegalArgumentException("useForward must be false if using an absolute loginFormURL");}Assert.notNull(portMapper, "portMapper must be specified");Assert.notNull(portResolver, "portResolver must be specified");}/*** 允许子类修改应该适用于给定请求的登录表单URL*/protected String determineUrlToUseForThisRequest(HttpServletRequest request,HttpServletResponse response, AuthenticationException exception) {return getLoginFormUrl();}/*** 执行到登录表单URL的重定向(或转发)*/public void commence(HttpServletRequest request, HttpServletResponse response,AuthenticationException authException) throws IOException, ServletException {String redirectUrl = null;// 如果使用转发if (useForward) {if (forceHttps && "http".equals(request.getScheme())) {// 首先将当前请求重定向到HTTPS// 当收到该请求时,将使用到登录页面的转发redirectUrl = buildHttpsRedirectUrlForRequest(request);}// 重定向地址为nullif (redirectUrl == null) {// 获取登陆表单URLString loginForm = determineUrlToUseForThisRequest(request, response,authException);if (logger.isDebugEnabled()) {logger.debug("Server side forward to: " + loginForm);}// RequestDispatcher用于接收来自客户端的请求并将它们发送到服务器上的任何资源RequestDispatcher dispatcher = request.getRequestDispatcher(loginForm);// 进行转发dispatcher.forward(request, response);return;}}else {// 重定向到登录页面// 如果forceHttps为真,则使用httpsredirectUrl = buildRedirectUrlToLoginPage(request, response, authException);}// 进行重定向redirectStrategy.sendRedirect(request, response, redirectUrl);}// 构建重定向URLprotected String buildRedirectUrlToLoginPage(HttpServletRequest request,HttpServletResponse response, AuthenticationException authException) {// 通过determineUrlToUseForThisRequest方法获取URLString loginForm = determineUrlToUseForThisRequest(request, response,authException);// 如果是绝对URL,直接返回if (UrlUtils.isAbsoluteUrl(loginForm)) {return loginForm;}// 如果是相对URL// 构造重定向URLint serverPort = portResolver.getServerPort(request);String scheme = request.getScheme();RedirectUrlBuilder urlBuilder = new RedirectUrlBuilder();urlBuilder.setScheme(scheme);urlBuilder.setServerName(request.getServerName());urlBuilder.setPort(serverPort);urlBuilder.setContextPath(request.getContextPath());urlBuilder.setPathInfo(loginForm);if (forceHttps && "http".equals(scheme)) {Integer httpsPort = portMapper.lookupHttpsPort(serverPort);if (httpsPort != null) {// 覆盖重定向URL中的scheme和porturlBuilder.setScheme("https");urlBuilder.setPort(httpsPort);}else {logger.warn("Unable to redirect to HTTPS as no port mapping found for HTTP port "+ serverPort);}}return urlBuilder.getUrl();}/*** 构建一个URL以将提供的请求重定向到HTTPS* 用于在转发到登录页面之前将当前请求重定向到HTTPS*/protected String buildHttpsRedirectUrlForRequest(HttpServletRequest request)throws IOException, ServletException {int serverPort = portResolver.getServerPort(request);Integer httpsPort = portMapper.lookupHttpsPort(serverPort);if (httpsPort != null) {RedirectUrlBuilder urlBuilder = new RedirectUrlBuilder();urlBuilder.setScheme("https");urlBuilder.setServerName(request.getServerName());urlBuilder.setPort(httpsPort);urlBuilder.setContextPath(request.getContextPath());urlBuilder.setServletPath(request.getServletPath());urlBuilder.setPathInfo(request.getPathInfo());urlBuilder.setQuery(request.getQueryString());return urlBuilder.getUrl();}// 通过警告消息进入服务器端转发logger.warn("Unable to redirect to HTTPS as no port mapping found for HTTP port "+ serverPort);return null;}/*** 设置为true以强制通过https访问登录表单* 如果此值为true(默认为false),并且触发拦截器的受保护资源的传入请求还不是https* 则客户端将首先重定向到https URL,即使serverSideRedirect(服务器端转发)设置为true*/public void setForceHttps(boolean forceHttps) {this.forceHttps = forceHttps;}.../*** 是否要使用RequestDispatcher转发到loginFormUrl,而不是302重定向*/public void setUseForward(boolean useForward) {this.useForward = useForward;}...
}

Debug分析

项目结构图:
在这里插入图片描述

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.kaven</groupId><artifactId>security</artifactId><version>1.0-SNAPSHOT</version><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.3.6.RELEASE</version></parent><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency></dependencies></project>

application.yml

spring:security:user:name: kavenpassword: itkaven
logging:level:org:springframework:security: DEBUG

MessageController(定义接口):

package com.kaven.security.controller;import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class MessageController {@GetMapping("/message")public String getMessage() {return "hello spring security";}
}

启动类:

package com.kaven.security;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class);}
}

formLogin

SecurityConfigSpring Security的配置类,不是必须的,因为有默认的配置):

package com.kaven.security.config;import org.springframework.security.config.Customizer;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {@Overrideprotected void configure(HttpSecurity http) throws Exception {// 任何请求都需要进行验证http.authorizeRequests().anyRequest().authenticated().and()// 记住身份验证.rememberMe(Customizer.withDefaults())// 基于表单登陆的身份验证方式.formLogin(Customizer.withDefaults());}
}

Debug方式启动应用,访问http://localhost:8080/message,请求会被ExceptionTranslationFilter进行处理,该过滤器会调用身份验证入口AuthenticationEntryPointcommence方法,该身份验证入口是LoginUrlAuthenticationEntryPoint实例,并且该实例loginFormUrl属性的值为/login
在这里插入图片描述
在这里插入图片描述
LoginUrlAuthenticationEntryPoint实例会将请求重定向到http://localhost:8080/login
在这里插入图片描述
浏览器上的请求便被重定向到http://localhost:8080/login,输入正确的用户名和密码,点击登陆即可通过身份验证。
在这里插入图片描述
身份验证成功。
在这里插入图片描述
成功访问到资源。
在这里插入图片描述

Basic

修改SecurityConfig类,如下所示:

    @Overrideprotected void configure(HttpSecurity http) throws Exception {// 任何请求都需要进行验证http.authorizeRequests().anyRequest().authenticated().and()// 记住身份验证.rememberMe(Customizer.withDefaults())// 基于Basic方式进行身份验证.httpBasic(Customizer.withDefaults());}

Debug方式启动应用,访问http://localhost:8080/message,请求会被ExceptionTranslationFilter进行处理,该过滤器会调用身份验证入口AuthenticationEntryPointcommence方法,该身份验证入口是DelegatingAuthenticationEntryPoint实例,并且该实例的defaultEntryPoint属性为BasicAuthenticationEntryPoint实例。
在这里插入图片描述
DelegatingAuthenticationEntryPoint实例会委托它的defaultEntryPoint属性进行处理,即BasicAuthenticationEntryPoint实例。
在这里插入图片描述
在这里插入图片描述
Basic身份验证如下图所示:
在这里插入图片描述
输入用户名和密码进行登陆,登陆请求会被BasicAuthenticationFilter进行处理,该过滤器会创建UsernamePasswordAuthenticationToken实例(身份验证令牌)用于验证。
在这里插入图片描述

在这里插入图片描述
最后会验证成功。

成功访问到资源。
在这里插入图片描述

身份验证入口AuthenticationEntryPoint介绍与Debug分析就到这里,如果博主有说错的地方或者大家有不同的见解,欢迎大家评论补充。

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

相关文章

  1. Java中的几种Kafka客户端比较介绍

    在这篇博客中&#xff0c;我介绍了在Java中定义Kafka消费者的各种方法。Spring、Micronaut、Vert.x和Akka Streams在引擎盖下使用kafka-clients库&#xff0c;并提供完整的功能集来消费Kafka消息。 Kafka 是一个著名的事件流平台。我们在很多项目中使用它。没什么不寻常的——…...

    2024/4/14 8:07:35
  2. CentOS 安装 Redis

    还是使用 yum 安装 Redis 1. 下载fedora的 epel 仓库 yum install epel-release2. 安装 redis yum install redis3. 查看 redis 状态 安装完毕后需要启动 # 启动redis service redis start # 停止redis service redis stop # 查看redis运行状态 service redis status # 查…...

    2024/4/17 8:31:11
  3. 相空间重构后,计算信号的时间不可逆性(matlab实现)

    输入三个参数&#xff1a;原始数据data&#xff0c;维度m&#xff0c;时间延迟tau (关于维度m和延迟tau的选取参考另外两篇https://blog.csdn.net/Tonyslp/article/details/122618915?spm1001.2014.3001.5501https://blog.csdn.net/Tonyslp/article/details/122618783?spm10…...

    2024/4/15 23:55:00
  4. Java 基础入门 | 第九章 抽象类和接口

    目录 抽象类 抽象类的定义 抽象类的举例 抽象类的声明 接口 接口的定义 接口的实现 接口的继承 接口的作用 作业 抽象类 抽象类的定义 在面向对象的概念中&#xff0c;所有的对象都是通过类来描绘的&#xff0c;但是反过来&#xff0c;并不是所有的类都是用来描绘…...

    2024/4/5 4:29:10
  5. 黑马JAVA P158 IO流分类、文件字节输入流、读取字节数据、避免乱码的方案

    package com.itheima.d4_byte_stream;import java.io.File; import java.io.FileInputStream; import java.io.InputStream;public class FileInputStreamDemo01 {public static void main(String[] args) throws Exception {//1.创建一个文件字节输入流管道与源文件接通&#…...

    2024/4/24 13:46:29
  6. mysql的配置文件 my.conf

    [client] default-character-setutf8 [mysql] default-character-setutf8 [mysqld] init_ connect‘SET collation_connection utf8_unicode_ci’ init_ connect‘SET NAMES utf8’ character-set-serverutf8 collation-serverutf8_unicode_ci skip-character-set-client-hand…...

    2024/4/14 8:08:26
  7. AndroidStudio Gradle第三依赖统一管理,kotlin开源

    // ------------- ButterKnife ------------- butterknife : ‘com.jakewha rton:butterknife:8.4.0’, butterknifeCompiler : ‘com.jakewharton:butterknife-compiler:8.4.0’, // ------------- LeakCanary ------------- leakcanaryAndroid : ‘com.squareup.leakcana…...

    2024/4/7 16:04:32
  8. 【信息系统项目管理师学习笔记】10大管理|47个过程组:项目整体管理|制定项目章程

    文章目录 一、整体管理概述二、制定项目章程定义项目章程是由项目实施组织外部签发的。项目章程的内容(背诵)1、制定项目章程的过程(背诵输入、工具和技术、输出)2、制定项目章程的依据1)协议2)项目工作说明书3)商业论证4)事业环境因素5)组织过程资产定义分类3、专家判…...

    2024/4/13 22:43:31
  9. R语言packages列表|分类与专题

    教育类 ASSOCShiny: 创建互动式文档 beginr:R初学者函数 BIFIEsurvey:教育中的调查统计工具。 lessR:可视化、描述性统计分析教学 dslabs:可用于数据科学课程和讲习班的数据集和函数可用于数据分析实践、作业和项目。 Chaos Game:混沌游戏。 childesr:实现对CHILDE…...

    2024/4/14 8:08:16
  10. Maven将普通Java项目打包成可执行的JAR

    1、将Maven打包编码设置成UTF-8 将maven的bin目录下的mvn.cmd文件用记事本打开&#xff0c;添加运行参数 MAVEN_OPTS-Dfile.encodingUTF-8 set MAVEN_OPTS-Dfile.encodingUTF-8 2、pom.xml文件中添加打包插件 <build><plugins><!-- 使用maven-shade-plugin插件…...

    2024/4/18 0:01:44
  11. 神器 Typora 开始收费,是什么给了它底气?

    在11月23日&#xff0c;Typora 正式发布 1.0 版本&#xff0c;进入了付费时代。 1.0 版本是一次性付费而非订阅的&#xff0c;只要支付人民币 89 元&#xff0c;可以在 3 台设备里使用。 有的人&#xff0c;可能会说&#xff1a;辣鸡&#xff0c;我用了这么多年&#xff0c;都…...

    2024/4/14 14:38:04
  12. SpringBoot打war包部署Tomcat(最全)

    1. tomcat9 2. jdk8 3. springboot2.x 1 - pom.xml 修改打包方式 <packaging>war</packaging>2 - 加入SpringBoot打包插件(pom.xml) <build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>sprin…...

    2024/4/14 8:08:41
  13. 《查缺补漏》C语言中 puts gets 和 scanf() printf() 之间的区别

    #include<stdio.h> int main(){char a[10];scanf("%s",a);printf("%s\n",a); // gets(a); // printf("%s\n",a); return 0;} scanf &#xff1a;当遇到回车&#xff0c;空格和tab键会自动在字符串后面添加’\0’&#xff0c;但是回车&…...

    2024/4/14 8:08:06
  14. 【杨辉三角 II(1025-go)】

    杨辉三角 II(1025-go) 给定一个非负索引 rowIndex&#xff0c;返回「杨辉三角」的第 rowIndex 行。 在「杨辉三角」中&#xff0c;每个数是它左上方和右上方的数的和。 //119. 杨辉三角 II func getRow(rowIndex int) []int {res : make([][]int, rowIndex1)for i : 0; i < …...

    2024/4/14 8:08:11
  15. [Golang]力扣Leetcode—初级算法—树—二叉树的最大深度

    [Golang]力扣Leetcode—初级算法—树—二叉树的最大深度题目&#xff1a;给定一个二叉树&#xff0c;找出其最大深度。二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。 说明&#xff1a;叶子节点是指没有子节点的节点。 链接&#xff1a; 力扣Leetcode—初级算法—…...

    2024/4/27 18:11:30
  16. 用C语言简单实现三子棋

    一.如何设计 首先我们可以利用函数来把三子棋的实现分成不同的模块&#xff0c;我们可以想一想&#xff0c;一个游戏&#xff0c;首先得有一个目录&#xff0c;让玩家选择玩还是不玩&#xff0c;也即菜单界面&#xff1b;其次&#xff0c;我们得有一个棋盘&#xff0c;接下来就…...

    2024/4/14 8:08:41
  17. 依赖、关联、聚合和组合之间的区别

    原文地址 在学习面向对象设计对象关系时&#xff0c;依赖、关联、聚合和组合这四种关系之间区别比较容易混淆。特别是后三种&#xff0c;仅仅是在语义上有所区别&#xff0c;所谓语义就是指上下文环境、特定情景等。他们在编程语言中的体现却是基本相同的&#xff0c;但是基本…...

    2024/4/14 8:08:31
  18. Qt——如何在QWidget中设置阴影效果

    介绍 这是一个用来设置QWidget控件及其子控件阴影效果的类。父类 继承自:QGraphicsEffect属性 blurRadius:qeal 模糊半径:可以使用 qreal blurRadius() const 和void setBlurRadius(qreal blurRadius)获取和设置当前属性的值&#xff0c;默认值是1。color:QColor 设置阴影颜…...

    2024/4/14 8:08:21
  19. 【lc周赛】 第一次自己做出三题。。。

    算是第一次认真参加周赛&#xff0c;之前都是觉得自己没啥信心&#xff0c;看到题目头很大&#xff0c;这次题目比较简单&#xff0c;简单记录下。 class Solution {public int countElements(int[] nums) {int n nums.length;if(n < 3){return 0;}int res 0;Arrays.sort(…...

    2024/4/14 8:08:06
  20. 魔方玩家的执念采用Python、Java、Android实现的三阶魔方打乱功能

    首先简述一下三阶魔方&#xff0c;魔方可以通过打乱公式进行状态的转变&#xff0c; &#xff08;F,B,U,D,L,R&#xff09;六个字母分别表示&#xff1a;前面顺时针旋转90、背面顺时针旋转90、上面顺时针旋转90、下面顺时针旋转90、左面顺时针旋转90、右面顺时针旋转90。 &am…...

    2024/4/14 8:08:06

最新文章

  1. 一文读懂Mysql数据库索引原理

    MyISAM 存储引擎索引实现&#xff1a; MyISAM 索引文件&#xff08;磁盘上表对应.MYI&#xff09;和数据文件&#xff08;MYD&#xff09;是分离的&#xff08;非聚集&#xff09; InnoDB 存储引擎索引实现&#xff1a; InnoDB 索引实现&#xff08;聚集&#xff09; 表数据文…...

    2024/5/3 15:57:50
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. 数据结构--KMP算法

    数据结构–KMP算法 首先我在这里提出以下问题&#xff0c;一会一起进行探讨 1.什么是最长公共前后缀 2. KMP算法怎么实现对匹配原理 3. 最长公共前后缀怎么求解 KMP算法可以用来解决什么问题&#xff1f; 答&#xff1a;在字符串中匹配子串&#xff0c;也称为模式匹配 分析…...

    2024/5/1 13:00:11
  4. ssm框架中各层级介绍

    1、Spring&#xff08;业务逻辑层&#xff09;&#xff1a; Spring框架提供了依赖注入&#xff08;DI&#xff09;和面向切面编程&#xff08;AOP&#xff09;等功能&#xff0c;可以帮助管理Java应用程序中的对象依赖关系和提供横切关注点的支持。 在SSM框架中&#xff0c;S…...

    2024/5/3 3:42:05
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/5/1 17:30:59
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/5/2 16:16:39
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/29 2:29:43
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/5/2 9:28:15
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/30 9:43:09
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/5/2 15:04:34
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/29 20:46:55
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/30 22:21:04
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/1 4:32:01
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/27 23:24:42
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/30 9:42:22
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/5/2 9:07:46
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/30 9:42:49
  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