1. SpringBoot项目打包成war并部署到外置tomcat中
1.1 修改打包形式
在pom.xml里设置
<packaging>war</packaging>
1.2 移除嵌入式tomcat插件
在pom.xml里找到spring-boot-starter-web
依赖节点,在其中添加如下代码:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<!-- 移除嵌入式tomcat插件 -->
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
1.3 添加servlet-api的依赖
下面两种方式都可以,任选其一
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-servlet-api</artifactId>
<version>8.0.36</version>
<scope>provided</scope>
</dependency>
1.4 修改启动类,并重写初始化方法
我们平常用main方法启动的方式,都有一个App的启动类,代码如下:
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
我们需要类似于web.xml的配置方式来启动spring上下文了,在Application类的同级添加一个SpringBootStartApplication类,其代码如下:
/**
* 修改启动类,继承 SpringBootServletInitializer 并重写 configure 方法
*/
public class SpringBootStartApplication extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
// 注意这里要指向原先用main方法执行的Application启动类
return builder.sources(Application.class);
}
}
1.5 打包部署
在项目根目录下(即包含pom.xml的目录),在命令行里输入:mvn clean package
即可, 等待打包完成,出现[INFO] BUILD SUCCESS
即为打包成功。
然后把target目录下的war包放到tomcat的webapps目录下,启动tomcat,即可自动解压部署。
最后在浏览器中输入http://localhost:[端口号]/[打包项目名]/
发布成功
2. Mybatis
2.1 Mybatis使用注解别名不起作用
结论:mybatis单独使用注解是不行的,得在配置文件中指定使用注解的包路径
2.2 连接MySQL报 CLIENT_PLUGIN_AUTH is required
原来是版本的问题,原来用的6.x版本,替换回5.x版本就OK了。
3. SpringBoot读取application.properties文件
SpringBoot读取application.properties文件,通常有3种方式
3.1 @Value
@Value("${spring.profiles.active}")
private String profileActive;
------相当于把properties文件中的spring.profiles.active注入到变量profileActive中
3.2 @ConfigurationProperties
例如:
@Component
@ConfigurationProperties(locations = "classpath:application.properties",prefix="test")
public class TestProperties {
String url;
String key;
}
其他类中使用时,就可以直接注入该TestProperties 进行访问相关的值
3.3 使用Enviroment
例如:
private Enviroment env;
env.getProperty("test.url");
-----而env方式效率较低
注:@ConfigurationProperties也可用于其他.properties文件,只要locations指定即可
4. SpringBoot 手动new对象
可以通过SpringContext来new对象
- 创建ApplicationContextProvider,通过ApplicationContext.getBean方法获取class的实例:
/**
* 设置Sping的上下文
*/
@Component
public class ApplicationContextProvider implements ApplicationContextAware {
private static ApplicationContext context;
private ApplicationContextProvider(){}
@Override
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
context = applicationContext;
}
public static <T> T getBean(String name,Class<T> aClass){
return context.getBean(name,aClass);
}
}
- 然后定义我们的自己的类,此类可以是单例模式也可以是原型模式:
@Component("Task")
@Scope("prototype/singleton")
public class MoniotrTask extends Thread {
final static Logger logger= LoggerFactory.getLogger(MoniotrTask.class);
private Monitor monitor;
public void setMonitor(Monitor monitor) {
this.monitor = monitor;
}
@Override
public void run() {
logger.info("线程:"+Thread.currentThread().getName()+"运行中.....");
}
}
- 然后就可以通过以下方式获取类的实例:
@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes =ApplicationMain.class)
public class SpingContextTest {
@Test
public void show()throws Exception{
MoniotrTask m1 = ApplicationContextProvider.getBean("Task", MoniotrTask.class);
MoniotrTask m2 = ApplicationContextProvider.getBean("Task", MoniotrTask.class);
MoniotrTask m3 = ApplicationContextProvider.getBean("Task", MoniotrTask.class);
System.out.println(m1+" => "+m1.greaterDaoImpl);
System.out.println(m2+" => "+m2.greaterDaoImpl);
System.out.println(m3+" => "+m3.greaterDaoImpl);
}
}