JAVA實用操作(一)IDEA用maven建立springMVC專案和配置
最近做使用者畫像需要使用API的方式訪問hbase表,這裡構建使用java web專案使用java語言進行API開發,這裡簡單回顧下java web的構建方式。
一.回顧建立SpringMVC
Spring MVC 框架在 Java 的 Web 專案中應該是無人不知的吧,你不會搭建一個 Spring 框架?作為身為一個剛剛學習Java的我都會,如果你不會的話,那可真令人憂傷。 工具準備:IDEA2016.3 Java jdk 1.8 1、DEA建立專案 新建一個maven project,並且選擇webapp原型。
然後點選next
這裡的GroupId和ArtifactID隨意填寫,但是ArtifactID最好和你的專案一名一樣然後next
<mirror>
<id>alimaven</id>
<mirrorOf>central</mirrorOf>
<name>aliyun maven</name>
<url>http://maven.aliyun.com/nexus/content/repositories/central/</url>
</mirror>
這個是阿里的庫,所以很快。做完之後我們回到idea,點選next,然後填寫專案名,然後finish。 接下來idea開始建立專案,這裡你要把maven自動匯入開啟。
二、新增pom依賴
建立好之後的專案目錄如圖所示 我們開啟其中的pom.xml,新增我們的依賴。這裡我把我的依賴全部放出來,複製到你的pom.xml的dependencies標籤之間就可以了,pom檔案中也會給你一個示例。 我的依賴如下
<!--測試-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<!--日誌-->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.21</version>
</dependency>
<!--J2EE-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.2</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<!--mysql驅動包-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.35</version>
</dependency>
<!--springframework-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>4.2.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>4.2.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>4.2.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>4.2.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>4.2.6.RELEASE</version>
</dependency>
<dependency>
<groupId>com.github.stefanbirkner</groupId>
<artifactId>system-rules</artifactId>
<version>1.16.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.8.9</version>
</dependency>
<!--其他需要的包-->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.4</version>
</dependency>
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.1</version>
</dependency>
一旦你複製過去之後,maven就會開始下載相應的jar檔案,等待下載完成即可。可能包有點多,不過用了阿里的映象之後還是挺快的。
三、新增框架支援
配置完pom.xml之後,我們在idea中要新增一下框架的支援。 右擊我們的專案資料夾,選擇add framework support
然後在視窗中分別選中spring和springmvc,並且選擇spring是,記得勾選springconfig.xml
因為我們之前下載過相應的檔案,所以這裡直接用我們下載好的spring檔案。 點選ok之後,我們會發現WEB-INF資料夾下多出了兩個檔案 這個就是我們之後要配置的檔案,先不用管。
四、完善目錄結構
首先我們在src/main資料夾下建立java資料夾,你會發現這個資料夾不能建立java的類檔案和package,別急,先把必須的資料夾全部建立好。請按照下圖建立資料夾 。
然後在java資料夾中新增需要的包。最後的完整目錄如下
這樣我們配置前的工作就完成了,接下來就是對springmvc進行配置。我把兩種配置的方法分成兩部分,以供參考。
5、基於XML 的配置
5.1、配置web.xml idea建立的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_3_1.xsd"
version="3.1">
<display-name>Archetype Created Web Application</display-name>
<!--welcome pages-->
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<!--配置springmvc DispatcherServlet-->
<servlet>
<servlet-name>springMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<!--配置dispatcher.xml作為mvc的配置檔案-->
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/dispatcher-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
<async-supported>true</async-supported>
</servlet>
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--把applicationContext.xml加入到配置檔案中-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
</web-app>
上面程式碼的意思主要就是建立一箇中央的控制器,都有簡單的註釋,如果有需要,請自行百度。
5.2 配置dispatcher-servlet.xml 這個檔案負責mvc的配置。
<?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 http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!--此檔案負責整個mvc中的配置-->
<!--啟用spring的一些annotation -->
<context:annotation-config/>
<!-- 配置註解驅動 可以將request引數與繫結到controller引數上 -->
<mvc:annotation-driven/>
<!--靜態資源對映-->
<!--本專案把靜態資源放在了webapp的statics目錄下,資源對映如下-->
<mvc:resources mapping="/css/**" location="/WEB-INF/statics/css/"/>
<mvc:resources mapping="/js/**" location="/WEB-INF/statics/js/"/>
<mvc:resources mapping="/image/**" location="/WEB-INF/statics/image/"/>
<!-- 對模型檢視名稱的解析,即在模型檢視名稱新增前後綴(如果最後一個還是表示資料夾,則最後的斜槓不要漏了) 使用JSP-->
<!-- 預設的檢視解析器 在上邊的解析錯誤時使用 (預設使用html)- -->
<bean id="defaultViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
<property name="prefix" value="/WEB-INF/views/"/><!--設定JSP檔案的目錄位置-->
<property name="suffix" value=".jsp"/>
<property name="exposeContextBeansAsAttributes" value="true"/>
</bean>
<!-- 自動掃描裝配 -->
<context:component-scan base-package="example.controller"/>
</beans>
直接複製即可,都有註釋,如果有需要,請自行百度。
5.3、 配置applicationContext.xml 其實這個檔案沒什麼好配置的,這個檔案主要負責一些非mvc元件(或者其他元件)的配置,暫時沒有,所以是空的,但你也可以掃描一下。
<?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"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<context:component-scan base-package="example"/>
</beans>
5.4、 測試 三個配置檔案配置好之後,就可以測試了。首先在controller資料夾下建立一個IndexController,程式碼如下:
@Controller
@RequestMapping("/home")
public class IndexController {
@RequestMapping("/index")
public String index() {
return "index";
}
}
views資料夾下建立index.jsp,
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Index</title>
<link rel="stylesheet" type="text/css" href="<c:url value="/css/test.css"/> "/>
</head>
<body>
<p>Spring MVC based on XML config success!</p>
</body>
</html>
statics/css/下建立test.css
{
background-color: brown;
font-family: "Courier New";
font-size:100px;
}
接下來配置tomcat,如果沒有,去官網下載tomcat7以上的版本。 配置相關資訊 還有deployment 選擇第二個
這裡的名稱和專案名一樣。
然後點選ok完成。
最後執行tomcat,在瀏覽器輸入http://localhost:8080/Demo/home/index 即可。
執行成功。
六、基於Java配置
java配置也是參考spring in action 第四版這個書,所以具體的原理不去詳解,所以我這裡更加傾向於把java配置和xml配置中的相同功能的部分進行比較,也是能對java配置又以有一個更加直觀的認識。 首先我們先完成準備工作,也就是本文的前四個直到檔案目錄完成,但是目錄需要一點小的修改,因為多了配置類,如下圖。 可以看到我們多了一個config包,這個裡面就是放配置類的。
6.1 、去除web.xml web.xml裡面的內容可以刪掉了。 在config中建立WebXml類
public class WebXml extends AbstractAnnotationConfigDispatcherServletInitializer {
/*
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
*/
@Override
protected Class<?>[] getRootConfigClasses() {
return new Class<?>[] {ApplicationContextXml.class};
}
/*
<servlet>
<servlet-name>springMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<!--配置dispatcher.xml作為mvc的配置檔案-->
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/dispatcher-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
<async-supported>true</async-supported>
</servlet>
*/
@Override
protected Class<?>[] getServletConfigClasses() {
return new Class<?>[] {DispatcherServletXml.class};
}
/*
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
*/
@Override
protected String[] getServletMappings() {
return new String[] {"/"};
}
}
6.2、去除dispatcher-servle.xml
@Configuration
@EnableWebMvc
@ComponentScan("web.example.controller")
public class DispatcherServletXml extends WebMvcConfigurerAdapter{
/*
<bean id="defaultViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
<property name="prefix" value="/WEB-INF/views/"/><!--設定JSP檔案的目錄位置-->
<property name="suffix" value=".jsp"/>
<property name="exposeContextBeansAsAttributes" value="true"/>
</bean>
*/
@Bean
public ViewResolver viewResolver() {
InternalResourceViewResolver resolver = new InternalResourceViewResolver();
resolver.setViewClass(org.springframework.web.servlet.view.JstlView.class);
resolver.setPrefix("/WEB-INF/views/");
resolver.setSuffix(".jsp");
resolver.setExposeContextBeansAsAttributes(true);
return resolver;
}
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable();
super.configureDefaultServletHandling(configurer);
}
// 靜態資源配置
/*
<mvc:resources mapping="/css/**" location="/WEB-INF/statics/css/"/>
<mvc:resources mapping="/js/**" location="/WEB-INF/statics/js/"/>
<mvc:resources mapping="/image/**" location="/WEB-INF/statics/image/"/>
*/
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/css/**").addResourceLocations("/WEB-INF/statics/css/");
registry.addResourceHandler("/js/**").addResourceLocations("/WEB-INF/statics/js/");
registry.addResourceHandler("/image/**").addResourceLocations("WEB-INF/statics/image/");
super.addResourceHandlers(registry);
}
}
6.3、去除applicationContext.xml
複製程式碼
@Configuration
@ComponentScan(basePackages = {"web"},
excludeFilters = {
@ComponentScan.Filter(type = FilterType.ANNOTATION, value = EnableWebMvc.class)
})
public class ApplicationContextXml {
}
上面三個配置類中的每一個設定我都對應的給出了原xml文件中的對應部分,兩邊對照著看,應該很容易理解。 然後按照之前的測試方法,測試成功