注解开发总结

1.当文件放在WEB-INF文件下如何访问

首先说明一下将文件放在WB-INF文件下,文件相对安全,一般情况会将较重要的文件放在里面

首先说明的是静态资源的释放(在该目录下所有的文件浏览器是不能直接访问的,需要转发):

1.新建java类继承 WebMvcConfigurationSupport 重写父类的 addResourceHandlers 方法,在方法中添加可以释放的静态资源文件

2.1代码如下(方式一)

    @Override
    protected void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/WEB-INF/page/**").
                addResourceLocations("/WEB-INF/page/");
    }

2.2代码如下(方式二)(这种方式非常推荐)

新建java类继承 WebMvcConfigurationSupport 重写父类的 addResourceHandlers 方法,同时在SpringMvcConfig配置类中定义视图解析器(注意该配置只要放在可以被扫描的地方都可以)

    @Bean
    public ViewResolver viewResolver(){
        InternalResourceViewResolver resolver = new InternalResourceViewResolver();
        resolver.setPrefix("/WEB-INF");
        resolver.setSuffix("");
        resolver.setExposeContextBeansAsAttributes(true);
        return resolver;
    }
    @Override
    protected void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/WEB-INF/page/**").
                addResourceLocations("/WEB-INF/page/");
    }

2.拦截器

2.1首先创建一个拦截器类,实现 该 HandlerInterceptor 接口,重写该接口的三个方法,同时添加注解便于SpringMvc扫描,如果不想被扫描,可以导入到SpringMvc配置类中。

代码如下:

@Component
public class ProjectInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("我进来了");
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        HandlerInterceptor.super.postHandle(request, response, handler, modelAndView);
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        HandlerInterceptor.super.afterCompletion(request, response, handler, ex);
    }
}

2.2 接下来创建类继承 WebMvcConfigurationSupport 接口,重写方法 addInterceptors

拦截器可以拦截文件和请求同时也可以要求放行文件和请求

代码如下:

注意:

/**
 * 第一个参数:
 *          HandlerInterceptor handlerInterceptor
 *          传递的是创建的拦截器(该拦截器创建时交给容器管理,此时自动注入即可)
 * 第二个参数:
 *          List<String> patterns
 *          需要添加拦截的路径()
 * 第三个参数:
 *          List<String> patterns
 *          需要添加被释放的路径(释放的目录下面若有多个一般 /目录/**)
 */
 protected void addInterceptors(InterceptorRegistry registry) {
        /**
         * 第一个参数:
         *          HandlerInterceptor handlerInterceptor
         *          传递的是创建的拦截器(该拦截器创建时交给容器管理,此时自动注入即可)
         * 第二个参数:
         *          List<String> patterns
         *          需要添加拦截的路径()
         * 第三个参数:
         *          List<String> patterns
         *          需要添加被释放的路径(释放的目录下面若有多个一般 /目录/**)
         */
        registry.addInterceptor(urlincterceptor)
                .addPathPatterns("/**")
                .excludePathPatterns("/css/**","/js/**","/images/","/pages/**",
                        "/code/getCode","/user/SearchOne","/user/SelectList");

    }

3.文件的上传和下载

3.1 首先需要引入相关的jar包依赖,在pom.xml添加依赖

<!-- 两个下载是需要的依赖jar包 -->
    <dependency>
      <groupId>commons-fileupload</groupId>
      <artifactId>commons-fileupload</artifactId>
      <version>1.3.1</version>
    </dependency>
    <dependency>
      <groupId>commons-io</groupId>
      <artifactId>commons-io</artifactId>
      <version>2.4</version>
    </dependency>

3.2 SpringMVC ⽤的是 的MultipartFile来进⾏⽂件上传 所以我们⾸先要配置MultipartResolver:⽤于处理表单中的文件,接下来在SpringMvc配置类中定义文件上传下载的bean

代码如下:

     /**
     * 文件上传解析器
     * @return
     */
    @Bean
    public MultipartResolver multipartResolver(){
        return new StandardServletMultipartResolver();
    }

3.3 在web配置类中配置

代码如下:

    @Override
    protected void customizeRegistration(ServletRegistration.Dynamic registration) {
        registration.setMultipartConfig(new MultipartConfigElement("")
        );
    }

3.4 请求发送

function f() {
                axios({
                    method:"post",
                    url:"",
                    data:new FormData($("form")[0]),
                    processData:false,
                    contentType:false
                })
            }

3.5 接受

public String show(MultipartFile file, String name, String password){
        String originalFilename = file.getOriginalFilename();
        System.out.println(originalFilename);
        return "";
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
EqualsAndHashCode注解是一个Java注解,用于自动生成equals()和hashCode()方法。当我们需要比较对象的相等性或者将对象用作哈希键时,通常需要重写这两个方法。但是手动编写这些方法比较繁琐且容易出错。使用EqualsAndHashCode注解可以简化这个过程。 通过在类上添加@EqualsAndHashCode注解,编译器会自动生成equals()和hashCode()方法的实现。自动生成的equals()方法会比较对象的所有字段是否相等,而hashCode()方法会根据对象的字段生成哈希码。 默认情况下,@EqualsAndHashCode注解会使用所有非静态和非transient字段来生成equals()和hashCode()方法。如果需要自定义生成规则,可以在注解中使用参数来配置。 例如: ``` import lombok.EqualsAndHashCode; @EqualsAndHashCode public class MyClass { private int id; private String name; } ``` 在上述示例中,使用@EqualsAndHashCode注解生成了equals()和hashCode()方法。默认情况下,这两个方法会比较并使用所有非静态、非transient字段来判断对象的相等性和生成哈希码。 需要注意的是,使用EqualsAndHashCode注解时,应该确保选择合适的字段进行比较和哈希码生成,以避免不必要的性能开销或者错误的结果。同时,如果类中存在父类,则需要显式地调用@EqualsAndHashCode注解来包含父类的字段。 总结起来,@EqualsAndHashCode注解可以简化equals()和hashCode()方法的编写,提高开发效率,但需要注意选择合适的字段来确保对象的相等性和哈希码的唯一性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值