您好,登錄后才能下訂單哦!
首先在整合這個框架的時候,想想其一般的步驟是怎樣的,先有個步驟之后,不至于在后面的搞混了,這樣在整合的時候也比較清晰些。
然后我們就細細的一步一步來整合。
1 創建一個Web項目。
2 導入Mybatis3、Spring4、SpringMVC4、連接數據庫(我使用的數據庫是mysql)的jar包。
我所用的包:
spring-websocket-4.2.0.RELEASE.jar
3 創建Mybatis3、Spring4、SpringMVC4、連接數據庫的配置文件。
4 配置web.xml
1 <?xml version="1.0" encoding="UTF-8"?> 2 <web-app version="2.5" 3 xmlns="http://java.sun.com/xml/ns/javaee" 4 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 5 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 6 http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> 7 8 <!-- 告知javaEE容器,有哪些內容需要添加到上下文中去 --> 9 <context-param>10 <param-name>contextConfigLocation</param-name>11 <param-value>12 /WEB-INF/classes/applicationContext.xml,13 <!-- /WEB-INF/classes/mvc-servlet.xml -->14 </param-value>15 </context-param> 16 17 18 <!-- 加載LOG4J -->19 <context-param>20 <param-name>log4jConfigLocation</param-name>21 <param-value>/WEB-INF/log4j.xml</param-value>22 </context-param>23 24 <context-param>25 <param-name>log4jRefreshInterval</param-name>26 <param-value>60000</param-value>27 </context-param>28 29 <!-- 動態設置項目的運行路徑 -->30 <context-param>31 <param-name>webAppRootKey</param-name>32 <param-value>ssm.root</param-value>33 </context-param>34 35 <!-- 配置靜態資源 -->36 <servlet-mapping>37 <servlet-name>default</servlet-name>38 <url-pattern>/static/*</url-pattern>39 </servlet-mapping>40 41 42 <!-- 配置springmvc的前端控制器 -->43 <servlet>44 <servlet-name>mvc</servlet-name>45 <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>46 <!-- 默認情況下:DispatcherServlet會尋找WEB-INF下,命名規范為[servlet-name]-servlet.xml文件。如:在上例中,它就會找/WEB-INF/spring-servlet.xml47 如果需要修改,需要在web.xml中的<servlet>標記中增加 <init-param>。。。 </init-param>:-->48 <init-param>49 <param-name>contextConfigLocation</param-name>50 <param-value>/WEB-INF/classes/mvc-servlet.xml</param-value>51 </init-param>52 </servlet>53 <servlet-mapping>54 <servlet-name>mvc</servlet-name>55 <url-pattern>/</url-pattern>56 </servlet-mapping>57 58 <!-- spring框架提供的字符集過濾器 -->59 <!-- spring Web MVC框架提供了org.springframework.web.filter.CharacterEncodingFilter用于解決POST方式造成的中文亂碼問題 -->60 <filter>61 <filter-name>encodingFilter</filter-name>62 <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>63 <init-param>64 <param-name>encoding</param-name>65 <param-value>UTF-8</param-value>66 </init-param>67 <!-- force強制,促使 -->68 <init-param>69 <param-name>forceEncoding</param-name>70 <param-value>true</param-value>71 </init-param>72 </filter>73 <filter-mapping>74 <filter-name>encodingFilter</filter-name>75 <url-pattern>/*</url-pattern>76 </filter-mapping>77 78 <!-- 登錄過濾器-->79 <filter>80 <filter-name>loginFilter</filter-name>81 <filter-class>com.cy.ssm.filter.LoginFilter</filter-class>82 </filter>83 <filter-mapping>84 <filter-name>loginFilter</filter-name>85 <url-pattern>/*</url-pattern>86 </filter-mapping>87 <!-- 監聽器 -->88 <listener>89 <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>90 </listener>91 92 <listener>93 <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>94 </listener>95 96 <welcome-file-list>97 <welcome-file>index.jsp</welcome-file>98 </welcome-file-list>99 </web-app>
5 datasource.properties 連接數據庫
1 jdbc.driver=com.mysql.jdbc.Driver2 jdbc.url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=UTF-83 jdbc.username=root4 jdbc.password=root
6 mybatis.cfg.xml文件
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE configuration PUBLIC "-//mybatis.org/DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd" ><configuration> </configuration>
7 mvc-servlet.xml
1 <?xml version="1.0" encoding="UTF-8"?> 2 <beans xmlns="http://www.springframework.org/schema/beans" 3 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" 4 xmlns:mvc="http://www.springframework.org/schema/mvc" 5 xsi:schemaLocation="http://www.springframework.org/schema/beans 6 http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 7 http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd 8 http://www.springframework.org/schema/mvc 9 http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">10 11 <!-- 啟動注解,注冊服務,如驗證框架、全局類型轉換器-->12 <mvc:annotation-driven/>13 14 15 <!-- 啟動自動掃描 -->16 <context:component-scan base-package="com.cy.ssm">17 <!-- 制定掃包規則 ,只掃描使用@Controller注解的JAVA類 -->18 <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>19 </context:component-scan>20 21 22 <!-- 配置視圖解析器 -->23 <!--24 prefix和suffix:查找視圖頁面的前綴和后綴(前綴[邏輯視圖名]后綴),25 比如傳進來的邏輯視圖名為WEB-INF/jsp/hello,則該該jsp視圖頁面應該存放在“WEB-INF/jsp/hello.jsp”; -->26 <bean class="org.springframework.web.servlet.view.UrlBasedViewResolver">27 <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"></property>28 <property name="prefix" value="/"></property> <!-- 我這里的視圖直接放在WebRoot下的 -->29 <property name="suffix" value=".jsp"></property>30 </bean>31 </beans>
8 applicationContext.xml
1 <?xml version="1.0" encoding="UTF-8"?> 2 <beans xmlns="http://www.springframework.org/schema/beans" 3 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" 4 xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" 5 xsi:schemaLocation="http://www.springframework.org/schema/beans 6 http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 7 http://www.springframework.org/schema/aop 8 http://www.springframework.org/schema/aop/spring-aop-3.0.xsd 9 http://www.springframework.org/schema/tx10 http://www.springframework.org/schema/tx/spring-tx-3.1.xsd11 http://www.springframework.org/schema/context12 http://www.springframework.org/schema/context/spring-context-4.2.xsd">13 14 15 <!-- 開啟自動掃包 -->16 <context:component-scan base-package="com.cy.ssm">17 <!--制定掃包規則,不掃描@Controller注解的JAVA類,其他的還是要掃描 -->18 <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>19 </context:component-scan>20 21 <!-- 啟動AOP支持 -->22 <aop:aspectj-autoproxy/>23 24 <!-- 引入外部數據源配置信息 -->25 <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">26 <property name="locations">27 <value>classpath:datasource.properties</value>28 </property>29 </bean>30 31 <!-- 配置數據源 -->32 <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">33 <property name="driverClassName" value="${jdbc.driver}"></property>34 <property name="url" value="${jdbc.url}"></property>35 <property name="username" value="${jdbc.username}"></property>36 <property name="password" value="${jdbc.password}"></property>37 </bean>38 39 40 <!-- 配置Session工廠 -->41 <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">42 <property name="dataSource" ref="dataSource"></property>43 <!-- 加載mybatis.cfg.xml文件 -->44 <property name="configLocation" value="classpath:mybatis.cfg.xml"></property>45 <!-- 自動掃描需要定義類別名的包,將包內的JAVA類的類名作為類別名 -->46 <property name="typeAliasesPackage" value="com.cy.ssm.beans"></property>47 </bean>48 49 <!-- 自動掃描所有的Mapper接口與文件 -->50 <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">51 <property name="basePackage" value="com.cy.ssm.mapper"></property>52 </bean>53 54 <!-- 配置事務管理器 -->55 <bean id="txManager"56 class="org.springframework.jdbc.datasource.DataSourceTransactionManager">57 <property name="dataSource" ref="dataSource"></property>58 </bean>59 60 <!-- 定義個通知,指定事務管理器 -->61 <tx:advice id="txAdvice" transaction-manager="txManager">62 <tx:attributes>63 <tx:method name="delete*" propagation="REQUIRED" read-only="false"64 rollback-for="java.lang.Exception" />65 <tx:method name="save*" propagation="REQUIRED" read-only="false"66 rollback-for="java.lang.Exception" />67 <tx:method name="insert*" propagation="REQUIRED" read-only="false"68 rollback-for="java.lang.Exception" />69 <tx:method name="update*" propagation="REQUIRED" read-only="false"70 rollback-for="java.lang.Exception" />71 <tx:method name="load*" propagation="SUPPORTS" read-only="true"/>72 <tx:method name="find*" propagation="SUPPORTS" read-only="true"/>73 <tx:method name="search*" propagation="SUPPORTS" read-only="true"/>74 <tx:method name="select*" propagation="SUPPORTS" read-only="true"/>75 <tx:method name="get*" propagation="SUPPORTS" read-only="true"/>76 </tx:attributes>77 </tx:advice>78 79 <aop:config>80 <!-- 配置一個切入點 -->81 <aop:pointcut id="serviceMethods" expression="execution(* com.cy.ssm.service.impl.*ServiceImpl.*(..))" />82 <aop:advisor advice-ref="txAdvice" pointcut-ref="serviceMethods" />83 </aop:config>84 85 </beans>
9 配置文件都差不多配置好了,接下來就寫個測試的。
LoginController .java
1 package com.cy.ssm.controller; 2 3 4 import javax.annotation.Resource; 5 import javax.servlet.http.HttpServletRequest; 6 7 import org.apache.log4j.Logger; 8 import org.springframework.stereotype.Controller; 9 import org.springframework.web.bind.annotation.RequestMapping;10 import org.springframework.web.servlet.ModelAndView;11 12 import com.cy.ssm.beans.UserBean;13 import com.cy.ssm.service.ILoginService;14 15 16 17 @Controller18 public class LoginController {19 private Logger log = Logger.getLogger(this.getClass());20 21 @Resource22 private ILoginService loginServiceImpl;23 24 @RequestMapping("/login")25 public ModelAndView login(HttpServletRequest req,UserBean user){26 log.info(user);27 28 ModelAndView mv = new ModelAndView();29 UserBean u=loginServiceImpl.Login(user.getUsername(), user.getPassword());30 31 if(u != null){32 33 req.getSession().setAttribute("user", u);34 mv.addObject("password", u.getPassword());35 System.out.println(u.getPassword());36 }37 mv.setViewName("index");38 return mv;39 }40 41 42 43 }
jsp頁面;
login.jsp
1 <body>2 <form action="<%=basePath%>login" method="post">3 <input type="text" name="username"/>4 <input type="text" name="password"/>5 <input type="submit" value="提交"/>6 </form>
index.jsp
<body>
${password }
</body>
測試:
點擊提交
整體大概就這樣了!
1. 使用阿里巴巴Druid連接池(高效、功能強大、可擴展性好的數據庫連接池、監控數據庫訪問性能、支持Common-Logging、Log4j和JdkLog,監控數據庫訪問)
2. 提供高并發JMS消息處理機制
3. 所有功能模塊化、所有模塊服務化、所有服務原子化的方式,提供可拓展的服務模型,使程序穩定運行,永不宕機
4. 提供Wink Rest、Webservice服務,故可作為獨立服務平臺部署
框架整合:
Springmvc + Mybatis + Shiro(權限) + REST(服務) + WebService(服務) + JMS(消息) + Lucene(搜搜引擎) + Quartz(定時調度) + Bootstrap Html5(支持PC、IOS、Android)
框架簡介:
項目Maven構建,真實大型互聯網架構,做到高并發,大數據處理,整個項目使用定制化服務思想,提供模塊化、服務化、原子化的方案,將功能模塊進行拆分,可以公用到所有的項目中。架構采用分布式部署架構,所有模塊進行拆分,使項目做到絕對解耦,穩定壓倒一切~~
持續集成:
1. 我的待辦工作流服務(提供Webservice服務)
2. 我的待辦工作流集成JMS消息服務(支持高并發,可支持成千上萬系統集成)
3. 我的任務提供Rest服務,完成日常的工作管理,通過定時調度平臺,動態生成我的任務、循環周期任務、定時郵催提醒完成任務等
4. 文件上傳、多線程下載服務化、發送郵件、短信服務化、部門信息服務化、產品信息服務化、信息發布服務化、我的訂閱服務化、我的任務服務化、公共鏈接、我的收藏服務化等
系統模塊:
1. 用戶管理:
用戶信息管理(添加、刪除、修改、用戶授權、用戶欄目管理、查詢等)
用戶組管理(添加、刪除、修改、用戶組欄目授權,欄目授權、查詢、用戶組人員添加查詢等)
用戶角色管理(添加、刪除、修改、用戶角色授權、用戶角色欄目信息查詢設置等)
2. 文章管理:
欄目管理:查詢無限極欄目樹、創建無限極欄目樹分類(導航欄目、圖片列表欄目、文章列表欄目、文章內容欄目等)、刪除、修改欄目信息。
文章管理:創建、刪除、修改文章,多維度文章查詢,包括已發布、未發布、所有文章等。文章富文本編輯器、文章多文件上傳、文章狀態控制等。
3. 系統設置:
數據字典管理:支持中、英文信息,支持無限級別分類配置,動態控制是否可用等。
部門信息管理:支持中、英文無限級別部門信息增加,刪除,修改操作,部門列表、樹心查詢等。
日志管理:系統日志列表查詢、在線查看、在線下載等
路線管理:集成百度地圖API,提供線路查詢管理功能
Druid Monitor(監控):集成阿里巴巴連接池,提供在線連接池監控程序,包括:數據源、SQL監控、URL監控、Session監控、Spring監控等
網站信息管理:通過系統配置文件進行網站內容操作,包括郵件服務器配置、公司基本信息配置等。
4. 集成REST服務,可以用作獨立服務平臺(提供大量實例及測試平臺,包括:文件上傳下載、郵件短信發送、部門、產品、公共連接、我的收藏、我的任務、信息發布等)
5. 集成Quartz調度,可以用作定時調度平臺(動態配置調度類、調度時間,使程序自動執行某些業務)
6. Lucene搜索引擎,可以將文件資料索引化,支持文件內容搜索、關鍵字搜索、高亮關鍵字等,使信息在毫秒內提取查詢出來
7. 用戶設置功能:包括修改用戶信息,修改密碼、發送消息,修改個人圖片,查看角色、查看用戶組,管理員修改角色、用戶、用戶組等。
8. 集成Webservice平臺,包括jaxws服務、CXF框架,配置雙加密的權限認證。使服務集成更加安全。
9. Bootstrap html5提供了兩套前臺開環境,包括CMS和電子商務網站,使您的開發更加的簡潔。
技術點:
1. Springmvc + Mybatis集成、SpringSecurity權限控制、Spring AOP事務處理。
2. Wink Rest服務、Webservice服務:jaxws、CXF等
3. IO 流上傳下載文件,多線程操作
4. 發送郵件,配置郵件服務器,發基于html、純文本格式的郵件
5. MD5加密 (登陸密碼校驗加密等),用戶統一Session、Cookie管理,統一驗證碼校驗等。
6. 數據庫連接池統一配置
7. Quartz定時調度任務集成(直接通過配置即可)
8. Httpclient破解驗證碼,登陸聯通充值平臺
9. 漢字、英文拆分、可以用作文檔關鍵字搜索等。
10. Base64圖片處理,支持PC,Android,IOS
11. Service Socket 、Client Socket 通信技術(已經做過GPRS數據獲取,并用到了項目中)
12. 提供大量工具類,可以直接使用
13. Maven項目構建,您可以直接做架構,可以提升自己的學習能力,使您成為真正的架構師。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。