SSM框架整合教程 新手篇
分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow
也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!
SSM框架整合教程(新手篇)
ssm框架
ssm框架是由Spring、SpringMVC、MyBatis三個開源框架整合而成的框架,本篇教程可針對對此框架完全不瞭解的同學第一次對它進行整合以及瞭解。本篇教程小編以一個簡單的留言板(BBS)專案來進行講解,專案用的是jsp頁面進行前後端的互動,是小編用了不到一下午編出來的,簡單易懂,希望能夠對大家有所幫助。必須的工具
1.Tomcat 2.Maven 3.Mysql 4.JDK 5.Intellij IDEA整合步驟詳解
在開始之前,確保上面的這些必須用到的東西已經全部搞定了,其中一個出了問題,我們在整合過程都不會成功。 首先,點選左上角File,New->Project接下來點選Maven來建立Maven專案,勾選上面的Create from archetype,然後選擇下面如圖的選項。
注意,這裡可能會有一個問題,可能有些同學進去的時候發現maven專案內一直處於loading狀態,這裡的解決方法是File->Settings->Build,Execution,Deployment->Build Tools->Maven->Importing,然後將VM options for importer設定為: -Xmx1024m,在重新建立Maven專案,就不再一直是loading,如果已經是-Xmx1024m的,就改回-Xmx512m.
這裡需要填寫GroupId、ArtifactId(groupId一般是域名的反寫,也作為專案中類的包名,artifactId是工程名,也就是根資料夾名)。接下來可以一直Next,填寫好專案名稱和專案路徑之後點選Finish,專案的建立就完成了O(∩_∩)O。
專案創立好之後,一開始是有一個基礎架構的,那麼這裡我們先手動建立一些資料夾和檔案到如圖的程度:
我們先把這些資料夾和檔案創好,接下來小編再一個一個的對這些檔案進行說明。 建立好後我們需要對專案的結構進行一些調整:
對main的resources資料夾:右鍵->make directory as—>Resources root
對test的java資料夾:右鍵->make directory as—>Test Sources root
對test的resources資料夾:右鍵->make directory as—>Test Resources root
接下來我們進行對Maven所有需要引入的jar包進行引入,開啟pom.xml檔案,將以下內容貼上進去:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.bbs</groupId> <artifactId>BBS</artifactId> <packaging>war</packaging> <version>1.0-SNAPSHOT</version> <name>BBS Maven Webapp</name> <url>http://maven.apache.org</url> <properties> <!-- spring版本號 --> <spring.version>4.2.5.RELEASE</spring.version> <!-- mybatis版本號 --> <mybatis.version>3.2.4</mybatis.version> <!-- log4j日誌檔案管理包版本 --> <slf4j.version>1.6.6</slf4j.version> <log4j.version>1.2.12</log4j.version> </properties> <dependencies> <!-- spring核心包 --> <!-- springframe start --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-oxm</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>${spring.version}</version> </dependency> <!-- springframe end --> <!-- mybatis核心包 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <!-- mybatis/spring包 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.2.2</version> </dependency> <!-- mysql驅動包 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.29</version> </dependency> <!-- junit測試包 --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <scope>test</scope> </dependency> <!-- jstl --> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.2.1-b03</version> <scope>provided</scope> </dependency> <!-- servlet --> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> <scope>provided</scope> </dependency> <!-- json資料 --> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>2.7.1</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> <version>2.7.1</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.7.1</version> </dependency> <dependency> <groupId>net.sf.json-lib</groupId> <artifactId>json-lib</artifactId> <version>2.4</version> <classifier>jdk15</classifier> </dependency> <!-- commons --> <dependency> <groupId>commons-lang</groupId> <artifactId>commons-lang</artifactId> <version>2.4</version> </dependency> <dependency> <groupId>commons-logging</groupId> <artifactId>commons-logging</artifactId> <version>1.1</version> </dependency> <dependency> <groupId>commons-pool</groupId> <artifactId>commons-pool</artifactId> <version>1.5.6</version> </dependency> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.4</version> </dependency> <dependency> <groupId>commons-beanutils</groupId> <artifactId>commons-beanutils</artifactId> <version>1.8.3</version> </dependency> <dependency> <groupId>commons-httpclient</groupId> <artifactId>commons-httpclient</artifactId> <version>3.1</version> </dependency> <dependency> <groupId>commons-collections</groupId> <artifactId>commons-collections</artifactId> <version>3.1</version> </dependency> <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.9</version> </dependency> <dependency> <groupId>javax.annotation</groupId> <artifactId>jsr250-api</artifactId> <version>1.0</version> </dependency> <dependency> <groupId>net.sf.ezmorph</groupId> <artifactId>ezmorph</artifactId> <version>1.0.6</version> </dependency> <dependency> <groupId>javax.activation</groupId> <artifactId>activation</artifactId> <version>1.1</version> </dependency> <dependency> <groupId>taglibs</groupId> <artifactId>standard</artifactId> <version>1.1.2</version> </dependency> <!-- 日誌檔案管理包 --> <!-- log start --> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>${log4j.version}</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>${slf4j.version}</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>${slf4j.version}</version> </dependency> <!-- log end --> </dependencies> <build> <finalName>BBS</finalName> <plugins> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</version> <configuration> <!--允許移動生成的檔案--> <verbose>true</verbose> <!--允許覆蓋生成的檔案--> <overwrite>true</overwrite> </configuration> </plugin> </plugins> </build></project>
這裡的name可以自己調整(名字隨便改),最下面的build標籤中的內容是一個
MyBatis的外掛,小編在後面會進行講解,其他的基本有註釋,大家可以自己看一下。
如果在引入的過程中出現了紅色的報錯的話,那麼表示需要我們進行下載,把游標移到那一行,alt+enter -> update,下載即可。
開啟剛剛建立好的jdbc.properties檔案,這裡這個檔案用於對資料庫進行配置,將以下的程式碼貼上進去:
driver=com.mysql.jdbc.Driverurl=jdbc:mysql://localhost:3306/bbsusername=rootpassword=123456#定義初始連線數initialSize=0#定義最大連線數maxActive=20#定義最大空閒maxIdle=20#定義最小空閒minIdle=1#定義最長等待時間maxWait=60000#entity 包名和 java目錄modelPackage=com.bbs.entitymodelProject=src/main/java#sqlmap包名 和resources目錄sqlPackage=sqlmapsqlProject=src/main/resources#mapper包名和 java目錄mapperPackage=com.bbs.daomapperProject=src/main/javatable=reply
這個檔案的作用是自動掃描,自動注入,配置資料庫,後面的Mybaits外掛反向匯入資料庫內容的地方還會提到,這裡的引數也是有註釋的,可以根據實際情況進行調整。
開啟剛剛建立好的applicationContent.xml檔案,此檔案用於spring和MyBaits的整合,以及spring和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:beans="http://www.springframework.org/schema/beans" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd" > <!-- ①:對bbs包中的所有類進行掃描,以完成Bean建立和自動依賴注入的功能 --> <context:component-scan base-package="com.bbs"/> <mvc:annotation-driven /> <!-- 靜態資源訪問 --> <mvc:resources location="/assets/" mapping="/assets/**"/> <mvc:resources location="/editor/" mapping="/editor/**"/> <mvc:resources location="/images/" mapping="/images/**"/> <mvc:resources location="/scripts/" mapping="/scripts/**"/> <mvc:resources location="/styles/" mapping="/styles/**"/> <mvc:resources location="/upload/" mapping="/upload/**"/> <mvc:resources location="/pdfjs/" mapping="/pdfjs/**"/> <!-- Configures the @Controller programming model <mvc:annotation-driven />--> <!-- ②:啟動Spring MVC的註解功能,完成請求和註解POJO的對映 --> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> <property name="messageConverters"> <list> <ref bean="mappingJacksonHttpMessageConverter"/> </list> </property> </bean> <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>application/json;charset=UTF-8</value> </list> </property> </bean> <!-- 配置檢視解析器,把控制器的邏輯視訊對映為真正的檢視 --> <!-- /WEB-INF/jsp/start.jsp --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> <!-- 配置dbcp資料庫連線池 --> <!-- <context:property-placeholder location="classpath:db.properties"/> --> <!--資料庫配置 --> <bean id = "propertyConfigurer" class = "org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:jdbc.properties</value> </list> </property> </bean> <!-- 資料庫連線池 --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> <property name="initialSize" value="1"/> <property name="maxActive" value="100"/> <property name="maxIdle" value="5"/> <property name="maxWait" value="80000"/> </bean> <!-- 配置會話工廠SqlSessionFactory --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 資料來源 --> <property name="dataSource" ref="dataSource"/> <property name="mapperLocations" value="classpath:sqlmap/*Mapper.xml"/> <property name="typeAliasesPackage" value="com.bbs.entity" /> </bean> <!-- 在spring容器中配置mapper的掃描器產生的動態代理物件在spring的容器中自動註冊,bean的id就是mapper類名(首字母小寫)--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <!-- 指定掃描包的路徑,就是mapper介面的路徑,多個包中間以 半形逗號隔開 --> <property name="basePackage" value="com.bbs.dao"/> <!-- 配置sqlSessionFactoryBeanName --> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/> </bean> <!-- 配置事務管理器 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> <!-- 檔案上傳的配置 --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="104857600" /> <property name="maxInMemorySize" value="4096" /> <property name="defaultEncoding" value="utf-8" /> </bean> <!-- 攔截器 --> <mvc:interceptors> <!-- 國際化操作攔截器 如果採用基於(請求/Session/Cookie)則必需配置 --> <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" /> </mvc:interceptors></beans>
這裡的一些配置是以小編的專案為例,所有的引數基本都是可以改動的,大家可以根據其中的註釋進行了解,再根據情況進行調整。
接下來說下Log4j的配置,首先,這個配置不是必須的,只是用日誌的形式檢視資訊方便我們進行除錯,如果需要配置的話,開啟剛剛建立好的log4j.properties檔案,講一下程式碼貼上進去:
### set log levels ###log4j.rootLogger = INFO,D###\u8f93\u51fa\u5230\u63a7\u5236\u53f0 ###log4j.logger.toConsole=debug,stdoutlog4j.appender.stdout = org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.Target = System.outlog4j.appender.stdout.layout = org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern =%d{yyyy-MM-dd HH\:mm\:ss} [%5p] - %c -%F(%L) -%m%n### \u8f93\u51fa\u5230\u65e5\u5fd7\u6587\u4ef6 ##### \u5176\u4e2dFile \u53ef\u4ee5\u91c7\u7528\u7edd\u5bf9\u8def\u5f84 \u4ea6\u53ef\u4ee5\u91c7\u7528\u76f8\u5bf9\u8def\u5f84 catalina.home \u662ftomcat\u76ee\u5f55 \u5982\u679c\u6ca1\u6709logs\u6587\u4ef6\u5939 \u5c06\u4f1a\u62a5\u9519 #### \u66f4\u52a0\u503e\u5411\u4e8e\u5c06\u65e5\u5fd7\u6587\u4ef6\u653e\u5728 tomcat\u7684\u65e5\u5fd7\u76ee\u5f55\u4e0b${catalina.home}/logs/salesmanb2bError.log#### \u7edd\u5bf9\u8def\u5f84\u5982\uff1ae:/salesmanb2bError.log##log4j.logger.daily=INFO,Dlog4j.appender.D = org.apache.log4j.DailyRollingFileAppenderlog4j.appender.D.File = ${catalina.home}/logs/bbs.loglog4j.appender.D.Append = truelog4j.appender.D.Threshold = INFOlog4j.appender.D.layout = org.apache.log4j.PatternLayoutlog4j.appender.D.layout.ConversionPattern =%d{yyyy-MM-dd HH\:mm\:ss} [%5p] - %c -%F(%L) -%m%n##log4j.logger.org.apache.ibatis=debug,stdout##log4j.logger.java.sql=debug,stdout
這裡的路徑中的${catalina.home}表示的我們Tomcat的路徑,可以根據實際情況進行更改。
接下來我們可以進行JUnit測試,經過以上步驟(log4j不配也沒影響),我們已經完成了Spring和mybatis的整合,這樣我們就可以編寫一段測試程式碼來試試是否成功了。
首先,我們回到剛剛的jdbc.properties的檔案裡面,在這個檔案中,小編的資料庫路徑選擇的是小編自己本地的Mysql,這裡,我建立了一個BBS資料庫:
那麼在jdbc.properties中最後一欄table中,分別改為我們需要匯入的表格。 接下來說MyBatis Generator的用法,這個外掛就是剛剛在pom.xml中最後面新增的外掛。開啟generatorConfig.xml檔案,這個檔案用於此外掛的配置,將以下的程式碼貼上進去:
<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"><generatorConfiguration> <!--匯入屬性配置 --> <properties resource="jdbc.properties"/> <classPathEntry location="C:\Users\14615\.m2\repository\mysql\mysql-connector-java\5.1.29\mysql-connector-java-5.1.29.jar" /> <context id="context1"> <!-- 註釋 --> <commentGenerator> <property name="suppressAllComments" value="true" /><!-- 是否取消註釋 --> <property name="suppressDate" value="true" /> <!-- 是否生成註釋代時間戳 --> </commentGenerator> <jdbcConnection driverClass="${driver}" connectionURL="${url}" userId="${username}" password="${password}" /> <!-- 型別轉換 --> <javaTypeResolver> <!-- 是否使用bigDecimal, false可自動轉化以下型別(Long, Integer, Short, etc.) --> <property name="forceBigDecimals" value="false" /> </javaTypeResolver> <javaModelGenerator targetPackage="${modelPackage}" targetProject="${modelProject}" /> <sqlMapGenerator targetPackage="${sqlPackage}" targetProject="${sqlProject}" /> <javaClientGenerator targetPackage="${mapperPackage}" targetProject="${mapperProject}" type="XMLMAPPER" /> <!-- 如果需要通配所有表 直接用sql的萬用字元 %即可 --> <table schema="" tableName="${table}" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"/> </context></generatorConfiguration>
注意,這裡第七行的location是mysql-connector-java-5.1.29.jar的本地位置,當然並不需要我們去C盤裡慢慢找,可以在左邊下面的External Libraries中找到它,然後右鍵->copy path,再將其貼上到location裡,入下圖:
如果這裡什麼東西都沒有點選右側的maven的重新整理按鈕,進行重新整理。 執行maven的mybatis-generator操作,雙擊即可生成對應的檔案
接下來我們在service檔案中建立介面類和實現類
這裡小編以MemberService為例子進行講解。 這裡是小編MemberService中的介面和實現,方法分別是插入,查詢以及更新: MemberService:
package com.bbs.service;import com.bbs.entity.Member;import org.springframework.stereotype.Service;@Servicepublic interface MemberService { public int insertMember(Member member); public Member selectMember(int userid); public int selectByUserid(int userid); public int modifyInfo(Member member);}
MemberServicelmpl:
package com.bbs.service;import com.bbs.dao.MemberMapper;import com.bbs.entity.Member;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.ArrayList;@Servicepublic class MemberServiceImpl implements MemberService { @Autowired public MemberMapper memberMapper; public int insertMember(Member member) { return memberMapper.insertSelective(member); } public Member selectMember(int userid) { Member member = new Member(); member.setUserid(userid); ArrayList<Member> members = memberMapper.selectSelective(member); if(members.size() > 0) { return members.get(0); } else return null; } public int selectByUserid(int userid) { Member member = new Member(); member.setUserid(userid); ArrayList<Member> members = memberMapper.selectSelective(member); return members.size(); } public int modifyInfo(Member member) { int result= memberMapper.updateByPrimaryKeySelective(member); return result; }}
然後小編講解一下測試類,在 MemberService.java裡面,將游標移到public interface MemberService後面,然後alt+enter->creat test,建立完成後,在test->java中就有了測試類:
在MemberServiceTest中,編寫好測試的程式碼:
package com.bbs.service;import com.bbs.entity.Member;import org.junit.After;import org.junit.Before;import org.junit.Test;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;import static org.junit.Assert.*;public class MemberServiceTest { private ApplicationContext applicationContext; @Autowired private MemberService memberService; @Before public void setUp() throws Exception { applicationContext = new ClassPathXmlApplicationContext( "classpath:spring/applicationContext.xml");//載入spring配置檔案 memberService=applicationContext.getBean(MemberService.class);//在這裡匯入要測試的 } @After public void tearDown() throws Exception { } @Test public void insertMemberTest() throws Exception { Member member = new Member(); member.setUserid(123); member.setUsername("RaAlGhul"); member.setPassword("123"); member.setAdmin(1); int res = memberService.insertMember(member); System.out.println(res); } @Test public void selectMemberTest() throws Exception { Member member = new Member(); member = memberService.selectMember(15058130); System.out.println(member.getUsername()); } @Test public void selectByUseridTest() throws Exception { int res = memberService.selectByUserid(15058130); System.out.println(res); } @Test public void modifyInfoTest() throws Exception { Member member = memberService.selectMember(123); member.setUsername("admin"); int res = memberService.modifyInfo(member); System.out.println(res); }}
每一個方法我們都可以點選左側的箭頭進行測試,小編這裡的例子大家可以看著學習並模仿一下,用在自己的專案中。
上面已經完成了2大框架的整合,接下來在web.xml中對SpringMVC進行配置整合。 如果在剛剛的applicationContent.xml檔案中最上面出現了Application context not configured for this file的提示,那麼點進去,選擇第一個。 開啟web.xml檔案,將以下的程式碼貼上進去:
<?xml version="1.0" encoding="UTF-8"?><web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"> <display-name>BBS</display-name> <!-- 配置編碼方式--> <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> <!--<!– 限制為登入使用者訪問資源–>--> <!--<filter>--> <!--<filter-name>AuthFilter</filter-name>--> <!--<filter-class>com.drp.util.filter.AuthFilter</filter-class>--> <!--</filter>--> <!--<filter-mapping>--> <!--<filter-name>AuthFilter</filter-name>--> <!--<url-pattern>*.jsp</url-pattern>//表示對所有jsp檔案有效--> <!--</filter-mapping>--> <!-- SpringMvc配置--> <!-- 配置springmvc的前端控制器 指向spring-mvc.xml 程式在啟動的時候就載入springmvc 可以接受所有請求 load-on-startup:表示啟動容器時初始化該Servlet; --> <servlet> <servlet-name>springServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- 可以自定義servlet.xml配置檔案的位置和名稱, 預設為WEB-INF目錄下,名稱為[<servlet-name>]-servlet.xml,如spring-servlet.xml --> <init-param> <param-name>contextConfigLocation</param-name> <param-value> classpath:spring/applicationContext.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <!-- 將前端URL請求和後臺處理方法controller建立對應關係--> <servlet-mapping> <servlet-name>springServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <!-- Spring配置 --> <listener> <listener-class> org.springframework.web.context.ContextLoaderListener </listener-class> </listener> <!-- 取消對某一類檔案的攔截--> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.md</url-pattern> </servlet-mapping> <context-param> <param-name>contextConfigLocation</param-name> <param-value> classpath:spring/applicationContext.xml</param-value> </context-param> <!-- 歡迎頁面--> <welcome-file-list> <welcome-file>/WEB-INF/views/welcome.jsp</welcome-file> </welcome-file-list> <!--404錯誤--> <error-page> <error-code>404</error-code> <location>/WEB-INF/views/404.jsp</location> </error-page> <!--設定session失效時間為30分鐘 --> <session-config> <session-timeout>600</session-timeout> </session-config></web-app>
這裡的配置內容都有註釋,大家根據實際情況進行調整。
到此為止基本算整合完畢了,那麼我們現在配置一下Tomcat 在右上角找到編輯的地方:
然後點選加好,找到Tomcat,新增一個local的Tomcat,新增好後會在下面出現一個warning,點選右邊的fix,選擇第二個war exploded即可。
到這裡我們就全部完成了,現在我們可以直接點選左上角的箭頭進行執行,如果配置成功的話,那麼執行結果應該是在web.xml檔案中配置的那個初始頁面。
到這裡就是小編的整個新手教程,對於這個框架的學習,小編頗有感受,相信很多同學一開始會和小編一樣一臉懵逼,開發就是要學會多看以及多寫(多看很重要,千萬不要忽略這一點),小編在下載中同時給出整個bbs專案的完整程式碼,免費下載,如果有需要的可以去下載來看看。整篇教程小編寫了很久,花費了很多心血,希望對大家有所幫助O(∩_∩)O~~
給我老師的人工智慧教程打call!http://blog.csdn.net/jiangjunshow
你好! 這是你第一次使用 **Markdown編輯器** 所展示的歡迎頁。如果你想學習如何使用Markdown編輯器, 可以仔細閱讀這篇文章,瞭解一下Markdown的基本語法知識。新的改變
我們對Markdown編輯器進行了一些功能拓展與語法支援,除了標準的Markdown編輯器功能,我們增加了如下幾點新功能,幫助你用它寫部落格:
- 全新的介面設計 ,將會帶來全新的寫作體驗;
- 在創作中心設定你喜愛的程式碼高亮樣式,Markdown 將程式碼片顯示選擇的高亮樣式 進行展示;
- 增加了 圖片拖拽 功能,你可以將本地的圖片直接拖拽到編輯區域直接展示;
- 全新的 KaTeX數學公式 語法;
- 增加了支援甘特圖的mermaid語法1 功能;
- 增加了 多螢幕編輯 Markdown文章功能;
- 增加了 焦點寫作模式、預覽模式、簡潔寫作模式、左右區域同步滾輪設定 等功能,功能按鈕位於編輯區域與預覽區域中間;
- 增加了 檢查列表 功能。
功能快捷鍵
撤銷:Ctrl/Command + Z
重做:Ctrl/Command + Y
加粗:Ctrl/Command + B
斜體:Ctrl/Command + I
標題:Ctrl/Command + Shift + H
無序列表:Ctrl/Command + Shift + U
有序列表:Ctrl/Command + Shift + O
檢查列表:Ctrl/Command + Shift + C
插入程式碼:Ctrl/Command + Shift + K
插入連結:Ctrl/Command + Shift + L
插入圖片:Ctrl/Command + Shift + G
合理的建立標題,有助於目錄的生成
直接輸入1次#,並按下space後,將生成1級標題。
輸入2次#,並按下space後,將生成2級標題。
以此類推,我們支援6級標題。有助於使用TOC
語法後生成一個完美的目錄。
如何改變文字的樣式
強調文字 強調文字
加粗文字 加粗文字
標記文字
刪除文字
引用文字
H2O is是液體。
210 運算結果是 1024.
插入連結與圖片
連結: link.
圖片:
帶尺寸的圖片:
當然,我們為了讓使用者更加便捷,我們增加了圖片拖拽功能。
如何插入一段漂亮的程式碼片
去部落格設定頁面,選擇一款你喜歡的程式碼片高亮樣式,下面展示同樣高亮的 程式碼片
.
// An highlighted block var foo = 'bar';
生成一個適合你的列表
- 專案
- 專案
- 專案
- 專案
- 專案1
- 專案2
- 專案3
- 計劃任務
- 完成任務
建立一個表格
一個簡單的表格是這麼建立的:
專案 | Value |
---|---|
電腦 | $1600 |
手機 | $12 |
導管 | $1 |
設定內容居中、居左、居右
使用:---------:
居中
使用:----------
居左
使用----------:
居右
第一列 | 第二列 | 第三列 |
---|---|---|
第一列文字居中 | 第二列文字居右 | 第三列文字居左 |
SmartyPants
SmartyPants將ASCII標點字元轉換為“智慧”印刷標點HTML實體。例如:
TYPE | ASCII | HTML |
---|