使用基与maven的构建插件在构建阶段压缩css,js并为压缩后的文件追加版本号

本文介绍如何使用Maven插件优化构建过程,包括自动为CSS和JS文件添加版本号以解决缓存问题,以及自动压缩这些文件以提高加载速度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


最近负责公司一个项目框架的搭建,由于我们这边是后端团队,没有专业的前端工程师支持我们,我就在这个搭建过程中遇到了一些前端问题,给大家分享一下。
 
要分享点:
  1. 构建项目时自动在css,js文件名中加入版本号     解决新上线版本时,样式文件在浏览器的缓存问题
  2. 构建项目时自动压缩css,js资源文件 ,加快样式文件响应速度

buildnumber-maven-plugin

buildnumber 插件可以在maven的某个构建生命周期阶段执行(一般生命周期配置在validate阶段),生成构建的版本号,版本号的形式有3种,

  1. 如果项目是svn或git管理,可以用当前的管理工具生成的版本号作为插件生成的版本号
  2. 另外一种最常用的方式是通过构建项目时的时间戳作为buildnum生成的版本号
  3. 还有一种是自己定义版本生成的格式,这种情况需要自己基于buildnum开发下自己的扩展

下面这是一种以构建项目时的时间错作为版本号的方式,此时在maven的整个构建生命周期,会增加一个环境变量,timestamp,如果需要这个变量,可以通过 ${timestamp} 获得

<plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>buildnumber-maven-plugin</artifactId>
        <version>1.3</version>
        <executions>
             <execution>
                 <phase>validate</phase>
                 <goals>
                     <goal>create-timestamp</goal>
                 </goals>
             </execution>
        </executions>
             <configuration>
                 <format>{0,date,yyyy-MM-dd HH:mm:ss}</format>
                 <items>
                     <item>timestamp</item>
                 </items>
             </configuration>
</plugin>


yuicompressor-maven-plugin

yuicompressor插件可以用来压缩js,css文件,是google公司开发的一款基于maven的插件,可以通过配置在maven的某个构建周期中压缩某些目录下的js,css文件, 一般压缩js和css文件后,我们可能还要解决样式文件在浏览器缓存的问题,这时候,上面介绍的buildnum插件就起到它的作用了,我们用${timestamp}作为压缩后文件的后缀 每次有新的样式文件需要构建时,可以更新这些文件的版本号,下面是部分配置,具体配置可以参考这个项目的pom文件,执行mvn install,可以看到执行压缩的log

<plugin>
        <groupId>net.alchim31.maven</groupId>
        <artifactId>yuicompressor-maven-plugin</artifactId>
        <version>1.5.0</version>
        <executions>
            <execution>
                <phase>${assert.compress}</phase>
                <goals>
                    <goal>compress</goal>
                </goals>
            </execution>
        </executions>
        <configuration>
            <!--<nosuffix>true</nosuffix>-->
            <suffix>.${timestamp}</suffix>
            <force>true</force>
            <encoding>utf-8</encoding>
            <excludes>
                <exclude>**/*.pack.js</exclude>
                <exclude>**/compressed.css</exclude>
                <exclude>**/*.min.css</exclude>
                <exclude>**/*.min.js</exclude>
            </excludes>
        </configuration>
</plugin>

关于插件具体使用信息请看:http://davidb.github.io/yuicompressor-maven-plugin/index.html

参照code-demo请看:https://github.com/WangJunTYTL/myapp/tree/master/yuicompressor-demo


如果你喜欢请给星哦 

### Spring Boot 3.3 配置 Druid 数据库连接池教程 #### 1. 添加依赖项 为了使项目能够使用 Druid 数据库连接池,在 `pom.xml` 文件中添加以下 Maven 依赖: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.2.8</version> </dependency> ``` 该版本号应根据实际需求调整,确保当前使用的 Spring Boot 版本相匹配。 #### 2. 应用属性文件配置 编辑项目的 `application.properties` 或者 `application.yml` 文件来设置数据库连接参数和其他必要的选项。以下是于 `.properties` 的例子: ```properties spring.datasource.type=com.alibaba.druid.pool.DruidDataSource spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=password ``` 这些本配置指定了要使用的数据源类型、驱动类名、URL 和认证凭证等信息[^1]。 #### 3. 启用并自定义过滤器 (Filters) 如果希望启用某些特定功能比如 SQL 注入防护或慢查询日志记录,则可以在同一配置文件内继续追加相应的 filter 设置: ```yaml spring: datasource: druid: filters: stat,wall,log4j web-stat-filter: enabled: true url-pattern: /* exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*" stat-view-servlet: enabled: true login-username: admin login-password: test123 reset-enable: false ``` 上述 YAML 格式的片段展示了如何开启统计视图 Servlet 及其登录保护措施;同时也激活了一个 Web 统计 Filter 来跟踪 HTTP 请求模式[^3]。 #### 4. 创建控制器用于测试连通性 编写一个简单的 RESTful 控制器来进行初步验证工作: ```java @RestController @RequestMapping("/db") public class DbController { @Autowired private DataSource dataSource; @GetMapping("/testConnection") public String testDbConnection() throws SQLException { try (Connection connection = dataSource.getConnection()) { return "Database connected successfully!"; } } } ``` 这段 Java 代码实现了一个名为 `/db/testConnection` 的 GET 接口,当调用此接口时会尝试获取来自已配置的数据源的一个 Connection 实例,并返回成功消息给客户端[^5]。 #### 注意事项 - **版本兼容性**:尽管 Druid 是广泛支持多种框架和技术栈的选择之一,但在选用具体版本之前仍需确认官方文档中的说明以保证最佳实践下的稳定性。 - **安全性考量**:对于生产环境中部署的应用程序而言,务必妥善保管敏感信息如用户名和密码,并考虑采用更高级别的加密手段传输此类资料。 - **性能优化建议**:合理设定最大活跃数 (`maxActive`)、最小闲置数量 (`minIdle`) 等参数有助于提高应用程序的整体响应速度和服务质量。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值