IDEA配合Maven的过滤器filter配置作用之一快速切换项目环境配置文件

IDEA配合Maven的过滤器filter配置作用之一快速切换项目环境配置文件

前言

在平时的工作中,我们都会遇到这样的场景:开发、测试和上线发布三个环节的环境配置都不尽相同,那么如何快速的在三种环境中切换呢?这就要讲到我们今天的内容,maven的过滤器filter配置。

工具

maven的pom文件

代码

    <!--不同环境下的配置文件,一个profile代表一个环境-->
    <profiles>
        <!--测试环境配置-->
        <profile>
            <id>test</id>
            <properties>
                <env>test</env>
            </properties>
            <activation>
                <!--默认选用测试环境-->
                <activeByDefault>true</activeByDefault>
            </activation>
            <build>
                <!--测试环境的白名单-->
                <filters>
                    <filter>src/main/filters/test/jdbc-test.properties</filter>
                </filters>
            </build>
        </profile>

        <!--生产环境配置-->
        <profile>
            <id>prod</id>
            <properties>
                <env>prod</env>
            </properties>
            <build>
                <!--生产环境的白名单-->
                <filters>
                    <filter>src/main/filters/prod/jdbc-prod.properties</filter>
                </filters>
            </build>
        </profile>
    </profiles>
	<build>
        <!--白名单规则-->
        <filters>
            <!--env为动态赋值-->
            <filter>src/main/filters/${env}/jdbc-${env}.properties</filter>
        </filters>
        <!--需要打包的配置文件-->
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <!--启用上文的白名单配置 false为不启用-->
                <filtering>true</filtering>
            </resource>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.xml</include>
                </includes>
            </resource>
        </resources>
    </build>

注意

在使用spring替换${}中的变量时,不要再配置文件中写中文注释以及不能直接写“&”等特殊符号,需要再特殊符号后面加上“amp;”,方便spring读取变量值。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是详细的教程: 1. 环境准备 首先,需要准备好以下环境: - IDEA 2020版本 - JDK 1.8或以上 - Maven - Tomcat 2. 创建Maven项目 打开IDEA,选择File -> New -> Project,选择Maven,在左侧选项卡中选择Web Application,点击Next。在下一个页面中输入Group Id和Artifact Id,然后点击Next。 在下一个页面中,输入项目名称和路径,然后点击Finish。IDEA会自动创建一个Maven项目,并且生成一些基本的文件和目录结构。 3. 配置pom.xml 打开项目的pom.xml文件,添加以下依赖: ```xml <!-- Spring依赖 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <!-- MyBatis依赖 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>${mybatis-spring.version}</version> </dependency> <!-- 数据库驱动依赖 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>${mysql.version}</version> </dependency> <!-- Servlet API依赖 --> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>${servlet.version}</version> <scope>provided</scope> </dependency> <!-- JSP API依赖 --> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>javax.servlet.jsp-api</artifactId> <version>${jsp.version}</version> <scope>provided</scope> </dependency> <!-- JSTL依赖 --> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>${jstl.version}</version> </dependency> ``` 其中,${spring.version}、${mybatis.version}、${mybatis-spring.version}、${mysql.version}、${servlet.version}和${jsp.version}都是需要在pom.xml中定义的变量,例如: ```xml <properties> <spring.version>5.2.9.RELEASE</spring.version> <mybatis.version>3.5.6</mybatis.version> <mybatis-spring.version>2.0.6</mybatis-spring.version> <mysql.version>8.0.21</mysql.version> <servlet.version>3.1.0</servlet.version> <jsp.version>2.3.3</jsp.version> <jstl.version>1.2</jstl.version> </properties> ``` 4. 配置web.xml 在src/main/webapp/WEB-INF目录下创建web.xml文件,并添加以下内容: ```xml <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1"> <display-name>SSM Maven Webapp</display-name> <!-- SpringMVC配置 --> <servlet> <servlet-name>dispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcherServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <!-- Spring配置 --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/spring-context.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!-- 编码过滤器 --> <filter> <filter-name>encodingFilter</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> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- JSP和静态资源映射 --> <jsp-config> <jsp-property-group> <url-pattern>*.jsp</url-pattern> <page-encoding>UTF-8</page-encoding> </jsp-property-group> </jsp-config> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app> ``` 5. 编写Spring配置文件 在src/main/resources目录下创建spring目录,并在其中创建spring-context.xml和spring-mvc.xml两个配置文件。 spring-context.xml: ```xml <!-- 数据源配置 --> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC"/> <property name="username" value="root"/> <property name="password" value="123456"/> </bean> <!-- MyBatis配置 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="typeAliasesPackage" value="com.example.demo.entity"/> <property name="mapperLocations" value="classpath:mapper/*.xml"/> </bean> <!-- Mapper扫描配置 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.example.demo.dao"/> </bean> ``` spring-mvc.xml: ```xml <!-- 扫描Controller --> <context:component-scan base-package="com.example.demo.controller"/> <!-- 配置视图解析器 --> <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/"/> <property name="suffix" value=".jsp"/> </bean> <!-- 配置静态资源访问 --> <mvc:default-servlet-handler/> <!-- 配置SpringMVC注解支持 --> <mvc:annotation-driven/> ``` 6. 编写实体类和Mapper接口 在src/main/java目录下创建com.example.demo.entity和com.example.demo.dao两个包。 在com.example.demo.entity包中创建一个User类,用于表示用户信息: ```java public class User { private Integer id; private String name; private Integer age; // 省略getter和setter方法 } ``` 在com.example.demo.dao包中创建一个UserMapper接口,用于定义对User表的增删改查操作: ```java public interface UserMapper { List<User> listAll(); User getById(Integer id); void add(User user); void update(User user); void delete(Integer id); } ``` 7. 编写Mapper映射文件 在src/main/resources目录下创建mapper目录,并在其中创建UserMapper.xml文件,用于实现UserMapper接口中定义的操作: ```xml <mapper namespace="com.example.demo.dao.UserMapper"> <select id="listAll" resultType="com.example.demo.entity.User"> select * from user </select> <select id="getById" parameterType="java.lang.Integer" resultType="com.example.demo.entity.User"> select * from user where id = #{id} </select> <insert id="add" parameterType="com.example.demo.entity.User"> insert into user(name, age) values(#{name}, #{age}) </insert> <update id="update" parameterType="com.example.demo.entity.User"> update user set name = #{name}, age = #{age} where id = #{id} </update> <delete id="delete" parameterType="java.lang.Integer"> delete from user where id = #{id} </delete> </mapper> ``` 8. 编写Controller 在com.example.demo.controller包中创建一个UserController类,用于处理与用户相关的请求: ```java @Controller @RequestMapping("/user") public class UserController { @Autowired private UserMapper userMapper; @RequestMapping("/list") public String list(Model model) { List<User> userList = userMapper.listAll(); model.addAttribute("userList", userList); return "user/list"; } @RequestMapping("/add") public String add() { return "user/add"; } @RequestMapping("/doAdd") public String doAdd(User user) { userMapper.add(user); return "redirect:/user/list"; } @RequestMapping("/edit") public String edit(Integer id, Model model) { User user = userMapper.getById(id); model.addAttribute("user", user); return "user/edit"; } @RequestMapping("/doEdit") public String doEdit(User user) { userMapper.update(user); return "redirect:/user/list"; } @RequestMapping("/delete") public String delete(Integer id) { userMapper.delete(id); return "redirect:/user/list"; } } ``` 9. 编写JSP页面 在src/main/webapp/WEB-INF/views/user目录下创建list.jsp、add.jsp和edit.jsp三个文件,分别用于显示用户列表、添加用户和编辑用户: list.jsp: ```html <%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> <html> <head> <title>User List</title> </head> <body> <h1>User List</h1> <table border="1"> <tr> <th>ID</th> <th>Name</th> <th>Age</th> <th>操作</th> </tr> <c:forEach items="${userList}" var="user"> <tr> <td>${user.id}</td> <td>${user.name}</td> <td>${user.age}</td> <td> <a href="${pageContext.request.contextPath}/user/edit?id=${user.id}">编辑</a> <a href="${pageContext.request.contextPath}/user/delete?id=${user.id}">删除</a> </td> </tr> </c:forEach> </table> <br/> <a href="${pageContext.request.contextPath}/user/add">添加用户</a> </body> </html> ``` add.jsp: ```html <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Add User</title> </head> <body> <h1>Add User</h1> <form action="${pageContext.request.contextPath}/user/doAdd" method="post"> Name: <input type="text" name="name"/><br/> Age: <input type="text" name="age"/><br/> <input type="submit" value="提交"/> </form> </body> </html> ``` edit.jsp: ```html <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Edit User</title> </head> <body> <h1>Edit User</h1> <form action="${pageContext.request.contextPath}/user/doEdit" method="post"> <input type="hidden" name="id" value="${user.id}"/> Name: <input type="text" name="name" value="${user.name}"/><br/> Age: <input type="text" name="age" value="${user.age}"/><br/> <input type="submit" value="提交"/> </form> </body> </html> ``` 10. 部署和运行 在IDEA中点击菜单栏的Run -> Edit Configurations,选择Tomcat Server,点击左侧的“+”按钮,选择Local,并设置Tomcat安装目录和应用访问路径。点击OK后,就可以选择新建的配置并点击Run按钮来启动Tomcat服务器。 启动成功后,打开浏览器,访问http://localhost:8080/SSM_Maven_Webapp/user/list即可看到用户列表页面。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值