SpringMVC进阶(自定义拦截器以及异常处理)

news2024/11/26 23:50:16

文章目录

    • 1.自定义拦截器
        • 1.基本介绍
          • 1.说明
          • 2.自定义拦截器的三个方法
          • 3.流程图
        • 2.快速入门
          • 1.Myinterceptor01.java
          • 2.FurnHandler.java
          • 3.springDispatcherServlet-servlet.xml配置拦截器
          • 4.单元测试
        • 3.拦截特定路径
          • 1.拦截指定路径
          • 2.通配符配置路径
        • 4.细节说明
        • 5.多个拦截器
          • 1.执行流程图
          • 2.应用实例
            • 1.FurnHandler.java目标方法
            • 2.拦截器
            • 3.结果展示
    • 2.异常处理
        • 1.基本介绍
        • 2.局部异常处理器
          • 1.需求分析
          • 2.抛出问题
            • 1.MyExceptionHandler.java
            • 2.不处理异常则交给tomcat处理
          • 3.局部异常实例
            • 1.MyExceptionHandler.java
            • 2.exception_mes.jsp
            • 3.结果展示
        • 3.全局异常处理器
        • 1.基本介绍
        • 2.全局异常实例
            • 1.MyGlobalException.java
            • 2.global_exception.jsp
            • 3.结果展示
        • 3.细节说明
          • 1.局部异常优先级高于全局异常
          • 2.处理异常机制
        • 4.自定义异常
          • 1.基本介绍
          • 2.自定义异常应用实例
            • 1.SelfException.java
            • 2.selfex.java
            • 3.结果展示
          • 3.可以使用有参构造,抛出异常交给异常处理器接管
            • 1.SelfException.java
            • 2.selfex.java抛出自定义异常并制定message
            • 3.MyGlobalException.java捕获自定义异常
            • 4.结果展示
        • 5.统一异常处理器
          • 1.基本介绍
          • 2.需求分析
          • 3.具体实现
            • 1.MyExceptionHandler.java抛出数组越界异常
            • 2.springDispatcherServlet-servlet.xml配置统一异常处理器
            • 3.arrEx.jsp异常处理页面
            • 4.结果展示
        • 6.对未知异常进行统一处理
          • 1.具体实现
            • 1.MyExceptionHandler.java抛出异常
            • 2.springDispatcherServlet-servlet.xml修改统一异常处理器
            • 3.allEx.jsp所有未知异常的处理
            • 4.结果展示
        • 7.异常处理的优先级
          • 1.局部异常处理器
          • 2.全局异常处理器
          • 3.统一异常处理器
          • 4.Tomcat默认机制
    • 3.springMVC阶段的配置文件
        • 1.springDispatcherServlet-servlet.xml
        • 2.web.xml

1.自定义拦截器

1.基本介绍
1.说明

image-20240229191836862

2.自定义拦截器的三个方法

image-20240229191851734

3.流程图

image-20240229192327787

image-20240229192339458

2.快速入门
1.Myinterceptor01.java
package com.sun.web.interceptor;

import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * @author 孙显圣
 * @version 1.0
 */
@Component //注入容器
public class Myinterceptor01 implements HandlerInterceptor {
    /**
     * 在目标方法执行前被调用,如果返回false,目标方法不会被执行
     *
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("preHandle");
        return true;
    }

    /**
     * 在目标方法执行后被调用,可以获取目标方法返回的ModelAndView,可以根据业务进行二次处理
     *
     * @param request
     * @param response
     * @param handler
     * @param modelAndView
     * @throws Exception
     */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("postHandle");
    }

    /**
     * 在渲染之后会被调用,可以进行资源清理工作
     *
     * @param request
     * @param response
     * @param handler
     * @param ex
     * @throws Exception
     */
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("afterCompletion");
    }
}

2.FurnHandler.java
package com.sun.web.interceptor;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

/**
 * @author 孙显圣
 * @version 1.0
 */
@Controller
public class FurnHandler {
    @RequestMapping("/hi")
    public String hi() {
        System.out.println("hi方法被调用");
        return "success";
    }

    @RequestMapping("/hello")
    public String hello() {
        System.out.println("hello方法被调用");
        return "success";
    }
}

3.springDispatcherServlet-servlet.xml配置拦截器
    <!--配置拦截器-->
    <mvc:interceptors>
        <!--直接引用配置好的拦截器,这种配置方式会对所有的目标方法生效-->
        <ref bean="myinterceptor01"/>
    </mvc:interceptors>
4.单元测试

image-20240229195032847

3.拦截特定路径
1.拦截指定路径
    <!--配置拦截器-->
    <mvc:interceptors>
        <!--这样配置的拦截器可以指定路径-->
        <mvc:interceptor>
            <mvc:mapping path="/hi"/>
            <ref bean="myinterceptor01"/>
        </mvc:interceptor>
    </mvc:interceptors>

image-20240229200251647

2.通配符配置路径
    <!--配置拦截器-->
    <mvc:interceptors>
        <!--拦截器可以使用通配符配置路径-->
        <mvc:interceptor>
            <!--匹配所有/h。。。的路径-->
            <mvc:mapping path="/h*"/>
            <!--排除掉/hi的路径-->
            <mvc:exclude-mapping path="/hi"/>
            <ref bean="myinterceptor01"/>
        </mvc:interceptor>
    </mvc:interceptors>

image-20240229200737823

4.细节说明

image-20240229201207944

5.多个拦截器
1.执行流程图

image-20240229205530687

2.应用实例

image-20240229212432036

1.FurnHandler.java目标方法
    @RequestMapping("/topic")
    public String topic() {
        System.out.println("topic执行!");
        return "success";
    }
2.拦截器
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        //只要参数中有topic是topic就直接响应
        String topic = request.getParameter("topic");
        if (topic.equals("topic")) {
            response.setContentType("text/html;charset=utf-8");
            response.getWriter().write("<h1>请不要乱说话!!</h1>");
        }
        //后面的不再执行
        return false;
    }
3.结果展示

image-20240229212753792

2.异常处理

1.基本介绍

image-20240229213057838

2.局部异常处理器
1.需求分析

image-20240301082909238

2.抛出问题
1.MyExceptionHandler.java
package com.sun.web.exception;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;

/**
 * @author 孙显圣
 * @version 1.0
 */
@Controller
public class MyExceptionHandler {
    @RequestMapping("/getNum/{num}")
    public String getNUm(@PathVariable("num") Integer num) {
        //这里如果传进来的是0则会出现异常
        System.out.println(10 / num);
        return "success";
    }
}

2.不处理异常则交给tomcat处理

image-20240301083829770

3.局部异常实例
1.MyExceptionHandler.java
package com.sun.web.exception;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;

import javax.servlet.http.HttpServletRequest;

/**
 * @author 孙显圣
 * @version 1.0
 */
@Controller
public class MyExceptionHandler {
    @RequestMapping("/getNum/{num}")
    public String getNUm(@PathVariable("num") Integer num) {
        //这里如果传进来的是0则会出现异常
        System.out.println(10 / num);
        return "success";
    }
    //处理异常
    @ExceptionHandler({ArithmeticException.class, NullPointerException.class}) //参数是一个数组,可以接受多个异常类型
    public String exceptionHandler(Exception ex, HttpServletRequest request) { //当出现异常时,异常会自动封装到ex中(数据绑定)
        System.out.println("异常的信息=" + ex.getMessage());
        //可以将异常信息请求转发给下一个页面
        request.setAttribute("reason", ex.getMessage());
        return "exception_mes";
    }

}

2.exception_mes.jsp
<%--
  Date: 2024/3/1
  Time: 8:47
  User: 孙显圣
  Version:1.0
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<h3>出现异常</h3>
<h4>异常信息是${requestScope.reason}</h4>
</body>
</html>

3.结果展示

image-20240301085027684

3.全局异常处理器
1.基本介绍

image-20240301085551521

2.全局异常实例
1.MyGlobalException.java
package com.sun.web.exception;

import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;

import javax.servlet.http.HttpServletRequest;

/**
 * @author 孙显圣
 * @version 1.0
 */
@ControllerAdvice //表示这个是处理全局异常的类
public class MyGlobalException {
    @ExceptionHandler(ArithmeticException.class) //这个是处理算数异常的算数异常处理器
    public String globalException(Exception ex, HttpServletRequest request) {
        System.out.println("全局异常信息是=" + ex.getMessage());
        //将全局异常信息请求转发
        request.setAttribute("reason", ex.getMessage());
        return "global_exception";
    }

}

2.global_exception.jsp
<%--
  Date: 2024/3/1
  Time: 9:02
  User: 孙显圣
  Version:1.0
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<h3>出现异常</h3>
<h4>全局异常信息是${requestScope.reason}</h4>
</body>
</html>

3.结果展示

image-20240301090535405

3.细节说明
1.局部异常优先级高于全局异常
2.处理异常机制
  • 先从发生异常的方法所在的类中查找有@ExceptionHandler 注解的方法,如果异常不匹配则进行下一步
  • 从有@ControllerAdvice 注解的类查找有@ExceptionHandler 注解的方法,如果匹配异常则处理,无法匹配则交给tomcat处理
4.自定义异常
1.基本介绍

image-20240301091749206

2.自定义异常应用实例
1.SelfException.java
package com.sun.web.exception;

import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.ResponseStatus;

/**
 * @author 孙显圣
 * @version 1.0
 */
//reason指的是返回的异常原因信息,value指的是返回的响应状态
@ResponseStatus(reason = "年龄需要在1-120之间", value = HttpStatus.BAD_REQUEST)
public class SelfException extends RuntimeException{

}

2.selfex.java
package com.sun.web.exception;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

/**
 * @author 孙显圣
 * @version 1.0
 */
@Controller
public class selfex {
    @RequestMapping("/selfex")
    public void ex() {
        throw new SelfException();
    }
}

3.结果展示

image-20240301093453282

3.可以使用有参构造,抛出异常交给异常处理器接管
1.SelfException.java
package com.sun.web.exception;

import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.ResponseStatus;

/**
 * @author 孙显圣
 * @version 1.0
 */
//reason指的是返回的异常原因信息,value指的是返回的响应状态
@ResponseStatus(reason = "年龄需要在1-120之间", value = HttpStatus.BAD_REQUEST) //注意这个是给tomcat看的
public class SelfException extends RuntimeException{
    public SelfException() {
    }

    //这样就可以从全局异常里获取message了
    public SelfException(String message) {
        super(message);
    }
}

2.selfex.java抛出自定义异常并制定message
package com.sun.web.exception;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

/**
 * @author 孙显圣
 * @version 1.0
 */
@Controller
public class selfex {
    @RequestMapping("/selfex")
    public void ex() {
        throw new SelfException("年龄需要在1-100"); //指定message
    }
}

3.MyGlobalException.java捕获自定义异常
package com.sun.web.exception;

import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;

import javax.servlet.http.HttpServletRequest;

/**
 * @author 孙显圣
 * @version 1.0
 */
@ControllerAdvice //表示这个是处理全局异常的类
public class MyGlobalException {

    //处理自定义异常
    @ExceptionHandler(SelfException.class)
    public String selfex(Exception ex, HttpServletRequest request) {
        //将全局异常信息请求转发
        request.setAttribute("reason", ex.getMessage());
        return "global_exception";
    }

}
4.结果展示

image-20240301094532487

5.统一异常处理器
1.基本介绍

image-20240301095021696

2.需求分析

image-20240301095108246

3.具体实现
1.MyExceptionHandler.java抛出数组越界异常
package com.sun.web.exception;

import org.springframework.stereotype.Controller;


import org.springframework.web.bind.annotation.RequestMapping;



/**
 * @author 孙显圣
 * @version 1.0
 */
@Controller
public class MyExceptionHandler {

    //抛出数组越界异常,局部异常处理器和全局异常处理器都没有处理,则会交给统一异常处理器来处理
    @RequestMapping("/arr")
    public String array() {
        int[] ints = {1, 2, 3};
        System.out.println(ints[1222]); //交给统一异常处理器来处理
        return "success";
    }

}

2.springDispatcherServlet-servlet.xml配置统一异常处理器
    <!--配置统一异常处理器-->
    <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver" id="exceptionResolver">
        <property name="exceptionMappings">
            <props>
                <!--这里的arrEx会返回给视图解析器,然后默认视图解析器进行前后缀拼接-->
                <prop key="java.lang.ArrayIndexOutOfBoundsException">arrEx</prop>
            </props>
        </property>
    </bean>
3.arrEx.jsp异常处理页面
<%--
  Date: 2024/3/1
  Time: 10:02
  User: 孙显圣
  Version:1.0
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<h1>数组越界异常</h1>
</body>
</html>

4.结果展示

image-20240301100734501

6.对未知异常进行统一处理
1.具体实现
1.MyExceptionHandler.java抛出异常
package com.sun.web.exception;

import org.springframework.stereotype.Controller;


import org.springframework.web.bind.annotation.RequestMapping;



/**
 * @author 孙显圣
 * @version 1.0
 */
@Controller
public class MyExceptionHandler {


    //没有归类的异常
    @RequestMapping("/test")
    public String test() {
        String str = "hello";
        char c = str.charAt(10); //这里会抛出异常
        return "success";
    }
}

2.springDispatcherServlet-servlet.xml修改统一异常处理器
    <!--配置统一异常处理器-->
    <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver" id="exceptionResolver">
        <property name="exceptionMappings">
            <props>
                <!--这里的arrEx会返回给视图解析器,然后默认视图解析器进行前后缀拼接-->
                <prop key="java.lang.ArrayIndexOutOfBoundsException">arrEx</prop>
                <prop key="java.lang.Exception">allEx</prop>
            </props>
        </property>
    </bean>
3.allEx.jsp所有未知异常的处理
<%--
  Date: 2024/3/1
  Time: 10:12
  User: 孙显圣
  Version:1.0
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<h1>所有未知异常的处理界面</h1>
</body>
</html>

4.结果展示

image-20240301101531345

7.异常处理的优先级
1.局部异常处理器
  • 方法上加@ExceptionHandler({ArithmeticException.class, NullPointerException.class}) //参数是一个数组,可以接受多个异常类型
2.全局异常处理器
  • 类上加@ControllerAdvice //表示这个是处理全局异常的类
  • 方法上加@ExceptionHandler({ArithmeticException.class, NullPointerException.class}) //参数是一个数组,可以接受多个异常类型
3.统一异常处理器
  • 匹配方式是匹配尽可能具体的类型,跟配置的顺序无关
  • 在Spring配置文件中配置
    <!--配置统一异常处理器-->
    <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver" id="exceptionResolver">
        <property name="exceptionMappings">
            <props>
                <!--这里的arrEx会返回给视图解析器,然后默认视图解析器进行前后缀拼接-->
                <prop key="java.lang.ArrayIndexOutOfBoundsException">arrEx</prop>
                <prop key="java.lang.Exception">allEx</prop>
            </props>
        </property>
    </bean>
4.Tomcat默认机制

3.springMVC阶段的配置文件

1.springDispatcherServlet-servlet.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
    <!--容器扫描-->
    <context:component-scan base-package="com.sun.web"/>

    <!--配置视图解析器-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver">
        <!--配置前缀和后缀-->
        <property name="prefix" value="/WEB-INF/pages/"/>
        <property name="suffix" value=".jsp"/>
    </bean>

    <!--配置国际化错误信息的资源处理bean-->
    <bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
        <!--这里是默认到src下的properties文件中去读取的basename配置的就是文件名,所以他会读取src的i18n.properties文件-->
        <property name="basename" value="i18n"></property>
    </bean>

    <!--配置文件上传解析器,注意这里的id必须是接口首字母小写-->
    <bean class="org.springframework.web.multipart.commons.CommonsMultipartResolver" id="multipartResolver"></bean>

    <!--加入两个常规配置-->
    <!--支持SpringMVC的高级功能,比如JSR303校验,映射动态请求-->
    <mvc:annotation-driven></mvc:annotation-driven><!--注意:这个annotation-driven要选择mvc的那个-->
    <!--springMVC不能处理的请求,交给tomcat处理,比如css,js-->
    <mvc:default-servlet-handler/>

    <!--配置拦截器-->
    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/topic"/>
            <ref bean="myinterceptor01"/>
        </mvc:interceptor>
    </mvc:interceptors>

    <!--配置统一异常处理器-->
    <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver" id="exceptionResolver">
        <property name="exceptionMappings">
            <props>
                <!--这里的arrEx会返回给视图解析器,然后默认视图解析器进行前后缀拼接-->
                <prop key="java.lang.ArrayIndexOutOfBoundsException">arrEx</prop>
                <prop key="java.lang.Exception">allEx</prop>
            </props>
        </property>
    </bean>


    <!--视图解析器按照order的大小来决定优先级,默认的视图解析器是最低的优先级MAX_VALUE = 0x7fffffff-->
    <!--配置自定义视图解析器-->
    <!--<bean class="org.springframework.web.servlet.view.BeanNameViewResolver">-->
    <!--    <property name="order" value="99"/>-->
    <!--</bean>-->
</beans>
2.web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">
    <!--配置Spring自带的过滤器,解决乱码问题-->
    <filter>
        <filter-name>CharacterEncodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <!--这里指定字符编码-->
        <init-param>
            <param-name>encoding</param-name>
            <param-value>utf-8</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>CharacterEncodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
    <!--&lt;!&ndash;配置过滤器——放到最前面,因为这个应该是最先处理的&ndash;&gt;-->
    <!--<filter>-->
    <!--    <filter-name>MyCharacterFilter</filter-name>-->
    <!--    <filter-class>com.sun.web.filter.MyCharacterFilter</filter-class>-->
    <!--</filter>-->
    <!--&lt;!&ndash;过滤所有请求&ndash;&gt;-->
    <!--<filter-mapping>-->
    <!--    <filter-name>MyCharacterFilter</filter-name>-->
    <!--    <url-pattern>/*</url-pattern>-->
    <!--</filter-mapping>-->

    <!--配置HiddenHttpMethodFilter-->
    <!--把post方式提交的delete和put请求进行转换-->
    <filter>
        <filter-name>HiddenHttpMethodFilter</filter-name>
        <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
    </filter>
    <!--所有请求都经过这个过滤器-->
    <filter-mapping>
        <filter-name>HiddenHttpMethodFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>


    <!--配置中央控制器-->
    <!--只要服务器启动,这个servlet就调用init方法读取spring的配置文件,并且接收所有请求-->
    <servlet>
        <servlet-name>springDispatcherServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!--这里如果不配置init-param,则会按照springDispatcherServlet-servlet.xml在WEB-INF目录下找Spring的配置文件-->
        <!--服务器启动就装载这个servlet,直接创建servlet实例,调用init方法-->
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>springDispatcherServlet</servlet-name>
        <!--所有的请求都交给这servlet处理-->
        <url-pattern>/</url-pattern>
    </servlet-mapping>


</web-app>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1631804.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

七彩虹(Colorful)隐星P16 2023款笔记本电脑原装出厂Win11系统镜像下载 带建Recovery一键还原功能

七彩虹原厂Windows预装OEM专用系统&#xff0c;恢复出厂开箱状态一模一样 适用型号&#xff1a;隐星P16 23 链接&#xff1a;https://pan.baidu.com/s/1Ig5MQMiC8k4VSuCOZRQHUw?pwdak5l 提取码&#xff1a;ak5l 原厂W11系统自带所有驱动、出厂时自带的主题与专用壁纸、系…

第 4 篇 : Netty客户端互发图片和音/视频

说明 因为图片和音/视频不能确定其具体大小, 故引入MinIO。客户端之间只发送消息, 通过上传/下载来获取额外信息 1. MinIO搭建(参考前面文章), 并启动 2. 登录MinIO创建3个Bucket: image、voice、video 3. 客户端改造 3.1 修改 pom.xml <?xml version"1.0" …

浅谈OpenCV 粗略计算工件轮廓面积和外接圆直径(Emgu.CV)

前言 最近领导在做库房工具管理这块的功能&#xff0c;希望能集成OpenCV 粗略的计算出工具的长度&#xff0c;以方便用户再归还工具的时候&#xff0c;提示用户该放在那种尺寸的盒子里面&#xff0c;这便是这篇文章的由来。 我们的系统是基于.net开发的&#xff0c;所以采用的是…

Memory augment is All You Need for image restoration 论文翻译

目录 一.介绍 二.实际工作 A.图像阴影去除 B.图像去雨 C.存储模块的开发 三.网络结构 A.内存扩充 B.损失函数设计 四.实验 A.与最先进方法的比较 B.MemoryNet消融研究 五.结论 CVPR2023 MemoryNet 记忆增强是图像恢复所需要的一切 论文地址https://arxiv.org/abs/…

就业班 第三阶段(nginx) 2401--4.26 day5 nginx5 nginx https部署实战

三、HTTPS 基本原理 1、https 介绍 HTTPS&#xff08;全称&#xff1a;HyperText Transfer Protocol over Secure Socket Layer&#xff09;&#xff0c;其实 HTTPS 并不是一个新鲜协议&#xff0c;Google 很早就开始启用了&#xff0c;初衷是为了保证数据安全。 近些年&…

大型零售企业,适合什么样的企业邮箱大文件解决方案?

大型零售企业通常指的是在全球或特定地区内具有显著市场影响力和知名度的零售商。这些企业不仅在零售业务收入上达到了惊人的规模&#xff0c;而且在全球范围内拥有广泛的销售网络和实体店铺。它们在快速变化的零售行业中持续创新&#xff0c;通过实体店、电商平台等多种渠道吸…

「C++ 内存管理篇 1」C++动态内存分配

目录 〇、C语言的动态内存分配方式 一、C的动态内存分配方式 1. 什么是C的动态内存分配&#xff1f; 2. 为什么需要C的动态内存分配&#xff1f; a. new的优势 b. new的不足 c. delete的优势 d. 总结 3. 怎么使用new和delete? a. 对于内置类型 b. 对于自定义类型 c. 为什么ne…

python学习笔记----循环语句(四)

一、while循环 为什么学习循环语句 循环在程序中同判断一样&#xff0c;也是广泛存在的&#xff0c;是非常多功能实现的基础&#xff1a; 1.1 while循环语法 while 条件表达式:# 循环体# 执行代码这里&#xff0c;“条件表达式”是每次循环开始前都会评估的表达式。如果条件…

【血泪教训】Altium Designer隐藏覆铜层导致PCB电路板未加工隐藏层

Altium Designer隐藏覆铜层导致PCB电路板未加工隐藏层 血泪教训&#xff01;&#xff01;&#xff01; 事情经过是这样的 测试板PCB Layout完成后&#xff0c;隐藏铺铜层&#xff0c;方便check&#xff0c;隐藏操作如下图所示&#xff0c;选择“隐藏所有”或“隐藏选中铺铜”…

Redis基本數據結構 ― String

Redis基本數據結構 ― String 介紹常用命令範例1. 為字串鍵設值/取得字串鍵的值2. 查看字串鍵的過期時間3. 如何為key設置時間?4. 如何刪除指定key?5. 如何增加value的值?6. 獲取value值的長度 介紹 字串鍵是Redis中最基本的鍵值對類型&#xff0c;這種類型的鍵值對會在數據…

【python技术】使用akshare抓取东方财富所有概念板块,并把指定板块概念的成分股保存excel 简单示例

最近有个想法&#xff0c;分析A股某个概念成分股情况进行分析&#xff0c;第一反应是把对应概念板块的成分股爬取下来。说干就干 下面是简单示例 import akshare as ak import pandas as pddef fetch_and_save_concept_stocks(name):# 获取指定股票概念的成分股&#xff0c;并…

机器学习每周挑战——百思买数据

最近由于比赛&#xff0c;断更了好久&#xff0c;从五一开始不会再断更了。这个每周挑战我分析的较为简单&#xff0c;有兴趣的可以将数据集下载下来试着分析一下&#xff0c;又不会的我们可以讨论一下。 这是数据集&#xff1a; import pandas as pd import numpy as np impo…

Leetcode-面试题 02.02. 返回倒数第 k 个节点

目录 题目 图解 代码 面试题 02.02. 返回倒数第 k 个节点 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/kth-node-from-end-of-list-lcci/description/ 题目 实现一种算法&#xff0c;找出单向链表中倒数第 k 个节点。返回该节点的值。 注意&…

保证接口幂等性的多种实现方式(数据库方案)

1. 幂等性的概念 接口幂等性是指在软件工程和Web服务领域中&#xff0c;一个接口&#xff08;通常是HTTP API&#xff09;无论被调用一次还是多次&#xff0c;其对系统产生的副作用应该是相同的&#xff0c;即结果保持一致&#xff0c;不会因为多次请求而有所不同。换句话说&am…

ES练习项目-酒店搜索

目录 1 需求分析2 酒店搜索和分页2.1 请求和响应分析2.2 定义实体类&#xff0c;接收请求参数的JSON对象2.3 编写controller&#xff0c;接收页面的请求2.4 编写业务实现&#xff0c;利用RestHighLevelClient实现搜索、分页 3. 酒店结果过滤3.1 请求和响应分析3.2 修改请求参数…

上位机图像处理和嵌入式模块部署(树莓派4b设置ftp下载)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 作为一个开发板&#xff0c;最好支持ftp下载&#xff0c;这样文件的上传和下载都会比较方便。虽然目前为止&#xff0c;利用mobaxterm和ssh也能实现…

算法学习(5)-图的遍历

目录 什么是深度和广度优先 图的深度优先遍历-城市地图 图的广度优先遍历-最少转机 什么是深度和广度优先 使用深度优先搜索来遍历这个图的过程具体是&#xff1a; 首先从一个未走到过的顶点作为起始顶点&#xff0c; 比如以1号顶点作为起点。沿1号顶点的边去尝试访问其它未…

用Jenkins实现cherry-pick多个未入库的gerrit编译Android固件

背景: 在做Android固件开发的时候,通常我们可以利用gerrit-trigger插件,开发者提交一笔的时候自动触发jenkins编译,如果提交的这一笔的编译依赖其他gerrit才能编译过,我们可以在commit message中加入特殊字段,让jenkins在编译此笔patch的时候同时抓取依赖的gerrit代码下…

selenium在Pycharm中结合python的基本使用、交互、无界面访问

下载 下载与浏览器匹配的浏览器驱动文件&#xff0c;这里一定注意的是&#xff0c;要选择和浏览器版本号相同的驱动程序&#xff0c;否则后面会有很多问题。 &#xff08;1&#xff09;浏览器&#xff08;以google为例&#xff09;版本号的查询&#xff1a; 我这里的版本号是1…

RT-Thread V5.2.0版本尝鲜

文章目录 配置界面的更新新旧内核生成的二进制文件大小差异旧版本V5.1.0内核旧版本V5.2.0内核 配置界面的更新 尝试将手头RT-Thread工程的OS部分源码进行了更新&#xff0c;发现不少新的变化 配置界面变得更醒目&#xff1a; 配置变更保存提醒界面更新&#xff1a; 新旧内核…