标签:write idea 生成 1.7 welcome dac 空闲 tps 技术分享
很久没有新搭建过框架了,今天搭建一遍。以往都是在eclipse中搭建,今天换Idea吧,目前来说Idea用的还是很多的,但是用习惯了eclipse的朋友,可能会不太习惯
ok.....开始:
注意区分诺~。看不清楚容易出错↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
以后再说聚合的事情,
咳咳~~注意哈 别多写空格~~
ok 项目已经创建好了
接下来就是修改项目信息配置了
这里创建好文件夹之后,需要配置文件夹属性,
分割一下
---------------------------------------------------------另一种方式开始--------------------------------------------------------------------------------
---------------------------------------------------------另一种方式结束(上面的方法看懂的可以忽略分割线内的内容)--------------------------------------------------------------------------------
............项目创建完毕。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
启动测试一下~~
点击ok结束,这时,
就会出来启动器,选择普通启动,还是maven启动,就看你了
ok。。。。正文来袭。。。。项目创建好了,开始整合框架~~·~~~怎么感觉这么墨迹呢。。弄了那么多还没开始~~~ -_-||
开始了 见证奇迹的时刻来了哦
版本: Spring 4.0.2 RELEASE
Spring MVC 4.0.2 RELEASE
MyBatis 3.2.6
Maven引入需要的JAR包
<properties> <!-- spring版本号 --> <spring.version>4.0.2.RELEASE</spring.version> <!-- mybatis版本号 --> <mybatis.version>3.2.6</mybatis.version> <!-- log4j日志文件管理包版本 --> <slf4j.version>1.7.7</slf4j.version> <log4j.version>1.2.17</log4j.version> </properties> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <!-- 表示开发的时候引入,发布的时候不会加载此包 --> <scope>test</scope> </dependency> <!-- spring核心包 --> <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> <!-- 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> <!-- 导入java ee jar 包 --> <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> <version>7.0</version> </dependency> <!-- 导入Mysql数据库链接jar包 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.30</version> </dependency> <!-- 导入dbcp的jar包,用来在applicationContext.xml中配置数据库 --> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.2.2</version> </dependency> <!-- JSTL标签类 --> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <!-- 日志文件管理包 --> <!-- log start --> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>${log4j.version}</version> </dependency> <!-- 格式化对象,方便输出日志 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.1.41</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 --> <!-- 映入JSON --> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> <version>1.9.13</version> </dependency> <!-- 上传组件包 --> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.1</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.4</version> </dependency> <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.9</version> </dependency> </dependencies>
先进行Spring与MyBatis的整合,,,,,
创建jdbc属性文件
1 driver=com.mysql.jdbc.Driver 2 url=jdbc:mysql://192.168.1.228:3306/ssmsg 3 username=root 4 password=root 5 #定义初始连接数 6 initialSize=0 7 #定义最大连接数 8 maxActive=20 9 #定义最大空闲 10 maxIdle=20 11 #定义最小空闲 12 minIdle=1 13 #定义最长等待时间 14 maxWait=60000 15 16 17 #注意根据自己的数据库修改
然后就是spring-mybatis.xml文件
<?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:p="http://www.springframework.org/schema/p" 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-3.1.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"> <!-- 自动扫描 --> <context:component-scan base-package="com.jj" /> <!-- 引入配置文件 --> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="location" value="classpath:jdbc.properties" /> </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="${initialSize}"></property> <!-- 连接池最大数量 --> <property name="maxActive" value="${maxActive}"></property> <!-- 连接池最大空闲 --> <property name="maxIdle" value="${maxIdle}"></property> <!-- 连接池最小空闲 --> <property name="minIdle" value="${minIdle}"></property> <!-- 获取连接最大等待时间 --> <property name="maxWait" value="${maxWait}"></property> </bean> <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <!-- 自动扫描mapping.xml文件 --> <property name="mapperLocations" value="classpath:mapping/*.xml"></property> </bean> <!-- DAO接口所在包名,Spring会自动查找其下的类 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.jj.dao" /> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property> </bean> <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> </beans>
接下来配置上Log4j 来记录日志之类的,,我就不详细解释了。
1 #定义LOG输出级别 2 log4j.rootLogger=INFO,Console,File 3 #定义日志输出目的地为控制台 4 log4j.appender.Console=org.apache.log4j.ConsoleAppender 5 log4j.appender.Console.Target=System.out 6 #可以灵活地指定日志输出格式,下面一行是指定具体的格式 7 log4j.appender.Console.layout = org.apache.log4j.PatternLayout 8 log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n 9 10 #文件大小到达指定尺寸的时候产生一个新的文件 11 log4j.appender.File = org.apache.log4j.RollingFileAppender 12 #指定输出目录 13 log4j.appender.File.File = logs/ssm.log 14 #定义文件最大大小 15 log4j.appender.File.MaxFileSize = 10MB 16 # 输出所以日志,如果换成DEBUG表示输出DEBUG以上级别日志 17 log4j.appender.File.Threshold = ALL 18 log4j.appender.File.layout = org.apache.log4j.PatternLayout 19 log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n
ok下面咱们进行测试。。为了方便我直接创建了一张简单的user表
1 /* 2 Navicat MySQL Data Transfer 3 4 Source Server : 本机 5 Source Server Version : 50019 6 Source Host : 192.168.1.228:3306 7 Source Database : ssmsg 8 9 Target Server Type : MYSQL 10 Target Server Version : 50019 11 File Encoding : 65001 12 13 Date: 2017-09-27 16:57:53 14 */ 15 16 SET FOREIGN_KEY_CHECKS=0; 17 18 -- ---------------------------- 19 -- Table structure for `user` 20 -- ---------------------------- 21 DROP TABLE IF EXISTS `user`; 22 CREATE TABLE `user` ( 23 `id` int(11) NOT NULL auto_increment COMMENT ‘id‘, 24 `t_name` varchar(255) default NULL COMMENT ‘用户名‘, 25 `t_pws` varchar(255) default NULL COMMENT ‘密码‘, 26 `t_create_date` varchar(255) default NULL COMMENT ‘创建时间‘, 27 `t_status` varchar(255) default NULL COMMENT ‘状态‘, 28 `t_modification_time` varchar(255) default NULL COMMENT ‘修改时间‘, 29 `t_file` varchar(255) default NULL COMMENT ‘图片‘, 30 PRIMARY KEY (`id`) 31 ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 32 33 -- ---------------------------- 34 -- Records of user 35 -- ---------------------------- 36 INSERT INTO `user` VALUES (‘1‘, ‘11‘, ‘6512bd43d9caa6e02c990b0a82652dca‘, ‘11‘, ‘11‘, ‘11‘, null); 37 INSERT INTO `user` VALUES (‘4‘, ‘12‘, ‘c20ad4d76fe97759aa27a0c99bff6710‘, ‘17-9-5 ??1:38‘, ‘0‘, ‘17-9-5 ??1:38‘, null); 38 INSERT INTO `user` VALUES (‘5‘, ‘13‘, ‘c51ce410c124a10e0db5e4b97fc2af39‘, ‘17-9-5 ??1:41‘, ‘0‘, ‘17-9-5 ??1:41‘, null); 39 INSERT INTO `user` VALUES (‘6‘, ‘111‘, ‘6512bd43d9caa6e02c990b0a82652dca‘, ‘17-9-5 ??3:25‘, ‘0‘, ‘17-9-5 ??3:25‘, null); 40 INSERT INTO `user` VALUES (‘7‘, ‘113‘, ‘6512bd43d9caa6e02c990b0a82652dca‘, ‘17-9-5 ??3:29‘, ‘0‘, ‘17-9-5 ??3:29‘, null);
然后咱们利用Generator,来生成咱们的实体类
然后放到项目中
至于Generator如何使用,自行百度吧,如果实在不会~~可以留言给我~·、
注意一个问题~~~你们有没有注意到~我的mapping文件夹放在哪了~ -_-!! sorry~~抱歉~~图我就不换了 你们记得把它放在resources下面~~~
注意奥 千万要注意换 别看着图就上~~照片虽好,LU的多了也伤身~~所以来实际上手,别只意淫
在我们创建接口实现类的时候,idea可能会出现这个报红,解决方法为:
解决方法:
File – Settings – Inspections。在Spring Core – Autowring for Bean Class 中将Severity的级别由之前的error改成warning。
给大家贴上图吧:
ok解决 继续下一步:
给大家贴上代码,看着更清晰
1 package com.jj.service; 2 3 import com.jj.pojo.User; 4 5 public interface UserService { 6 7 public User getUser(Integer id);//传一个id进行查询 8 }
1 package com.jj.service.impl; 2 3 import com.jj.dao.UserDao; 4 import com.jj.pojo.User; 5 import com.jj.service.UserService; 6 import org.springframework.stereotype.Service; 7 8 import javax.annotation.Resource; 9 10 @Service("userService") 11 public class UserServiceImpl implements UserService{ 12 @Resource 13 private UserDao userDao; 14 15 public User getUser(Integer id) { 16 17 return this.userDao.selectByPrimaryKey(id); 18 } 19 }
1 package com.jj.dao; 2 3 import com.jj.pojo.User; 4 5 public interface UserDao { 6 int deleteByPrimaryKey(Integer id); 7 8 int insert(User record); 9 10 int insertSelective(User record); 11 12 User selectByPrimaryKey(Integer id); 13 14 int updateByPrimaryKeySelective(User record); 15 16 int updateByPrimaryKey(User record); 17 }
接下来进行测试
第一次测试报错
因为我个人喜欢叫UserDao 而MyBatis默认是mapper 所以在这里就将mapping.xml中所有的包结构改对,而我这里是因为只有一个查询 所以我就全部删除了 只留了一个select
再次测试
package com.jj.test; import com.jj.pojo.User; import com.jj.service.UserService; import org.apache.log4j.Logger; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import javax.annotation.Resource; @RunWith(SpringJUnit4ClassRunner.class) //表示继承了SpringJUnit4ClassRunner类 @ContextConfiguration(locations = {"classpath:spring-mybatis.xml"}) public class TestUser { private static Logger logger = Logger.getLogger(TestUser.class);//使用log4j打印日志 @Resource //注入service private UserService userService; @Test//Junit测试注释 我想你们懂得 public void getId(){ User user = userService.getUser(1); logger.info(user.toString()); } }
测试类也写好了。接下来贴出来运行状态
========================================上面已经整合好了Spring和MyBatis 接下来是SpringMVC========================================
这里首先Spring-MVC文件单独放 代码:
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:p="http://www.springframework.org/schema/p" 4 xmlns:context="http://www.springframework.org/schema/context" 5 xmlns:mvc="http://www.springframework.org/schema/mvc" 6 xsi:schemaLocation="http://www.springframework.org/schema/beans 7 http://www.springframework.org/schema/beans/spring-beans-3.1.xsd 8 http://www.springframework.org/schema/context 9 http://www.springframework.org/schema/context/spring-context-3.1.xsd 10 http://www.springframework.org/schema/mvc 11 http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"> 12 <!-- 自动扫描该包,使SpringMVC认为包下用了@controller注解的类是控制器 --> 13 <context:component-scan base-package="com.jj.controller" /> 14 <!--避免IE执行AJAX时,返回JSON出现下载文件 --> 15 <bean id="mappingJacksonHttpMessageConverter" 16 class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"> 17 <property name="supportedMediaTypes"> 18 <list> 19 <value>text/html;charset=UTF-8</value> 20 </list> 21 </property> 22 </bean> 23 <!-- 启动SpringMVC的注解功能,完成请求和注解POJO的映射 --> 24 <bean 25 class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> 26 <property name="messageConverters"> 27 <list> 28 <ref bean="mappingJacksonHttpMessageConverter" /> <!-- JSON转换器 --> 29 </list> 30 </property> 31 </bean> 32 <!-- 定义跳转的文件的前后缀 ,视图模式配置--> 33 <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 34 <!-- 这里的配置我的理解是自动给后面action的方法return的字符串加上前缀和后缀,变成一个 可用的url地址 --> 35 <property name="prefix" value="/WEB-INF/jsp/" /> 36 <property name="suffix" value=".jsp" /> 37 </bean> 38 39 <!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 --> 40 <bean id="multipartResolver" 41 class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> 42 <!-- 默认编码 --> 43 <property name="defaultEncoding" value="utf-8" /> 44 <!-- 文件大小最大值 --> 45 <property name="maxUploadSize" value="10485760000" /> 46 <!-- 内存中的最大值 --> 47 <property name="maxInMemorySize" value="40960" /> 48 </bean> 49 50 </beans>
一定要注意包结构~~我这人容易犯低级错误
接下来是web.xml主要是配置视图解析什么的
1 <?xml version="1.0" encoding="UTF-8"?> 2 <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 3 xmlns="http://java.sun.com/xml/ns/javaee" 4 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" 5 version="3.0"> 6 <display-name>Archetype Created Web Application</display-name> 7 <!-- Spring和mybatis的配置文件 --> 8 <context-param> 9 <param-name>contextConfigLocation</param-name> 10 <param-value>classpath:spring-mybatis.xml</param-value> 11 </context-param> 12 <!-- 编码过滤器 --> 13 <filter> 14 <filter-name>encodingFilter</filter-name> 15 <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> 16 <async-supported>true</async-supported> 17 <init-param> 18 <param-name>encoding</param-name> 19 <param-value>UTF-8</param-value> 20 </init-param> 21 </filter> 22 <filter-mapping> 23 <filter-name>encodingFilter</filter-name> 24 <url-pattern>/*</url-pattern> 25 </filter-mapping> 26 <!-- Spring监听器 --> 27 <listener> 28 <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 29 </listener> 30 <!-- 防止Spring内存溢出监听器 --> 31 <listener> 32 <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class> 33 </listener> 34 35 <!-- Spring MVC servlet --> 36 <servlet> 37 <servlet-name>SpringMVC</servlet-name> 38 <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 39 <init-param> 40 <param-name>contextConfigLocation</param-name> 41 <param-value>classpath:spring-mvc.xml</param-value> 42 </init-param> 43 <load-on-startup>1</load-on-startup> 44 <async-supported>true</async-supported> 45 </servlet> 46 <servlet-mapping> 47 <servlet-name>SpringMVC</servlet-name> 48 <!-- 此处可以可以配置成*.do,对应struts的后缀习惯 --> 49 <url-pattern>/</url-pattern> 50 </servlet-mapping> 51 <welcome-file-list> 52 <welcome-file>/index.jsp</welcome-file> 53 </welcome-file-list> 54 55 </web-app>
好 下面写controller层
1 package com.jj.controller; 2 3 import com.alibaba.fastjson.JSONObject; 4 import com.jj.model.User; 5 import com.jj.service.UserService; 6 import com.jj.utils.BaseController; 7 import com.jj.utils.Json; 8 import com.jj.utils.TqUtil; 9 import org.apache.log4j.Logger; 10 import org.springframework.stereotype.Controller; 11 import org.springframework.web.bind.annotation.RequestMapping; 12 13 import javax.annotation.Resource; 14 import javax.servlet.http.HttpServletRequest; 15 import javax.servlet.http.HttpServletResponse; 16 17 @Controller 18 @RequestMapping("/userController") 19 public class UserController extends BaseController{ 20 private static Logger logger = Logger.getLogger(UserController.class); 21 @Resource 22 private UserService userService; 23 @RequestMapping("/user") 24 public String getUser(HttpServletRequest request, HttpServletResponse response){ 25 int userId = Integer.parseInt(request.getParameter("id")); 26 User user = userService.getUser(userId); 27 request.getSession().setAttribute("user",user); 28 return "showUser"; 29 30 } 31 @RequestMapping("/tianqi") 32 public void getTqYb(HttpServletRequest request, HttpServletResponse response) { 33 Json j = new Json(); 34 String tq = TqUtil.getTq("北京"); 35 if (tq!=null){ 36 request.getSession().setAttribute("tq",tq); 37 j.setObject(tq); 38 j.setSuccess(true); 39 j.setMsg("查询成功"); 40 } 41 super.writeJson(j,response); 42 } 43 44 }
接下来启动项目的时候报了一个错。我也不怕丢人 给大家贴出来 然后说一下怎么解决的:
就是这个错误~~给大家说一下解决方法,如果你们遇到这中问题
将
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-api</artifactId>
<version>7.0</version>
</dependency>
修改为
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-api</artifactId>
<version>7.0</version>
<scope>provided</scope>
</dependency>
便解决问题了,特此记录
可以看到。启动没有任何问题 接下来我们去浏览器发送一下请求
http://localhost:8080/maven_ssm/userController/getUser.do
这里的话是对应了一个jsp页面的
贴一下最终包结构
ok~~~~好了 整合完毕~~以后的话我会在这个项目的基础上整个各种技术,如果有需要的话各位可以评论下你们所需要的技术,我会尽可能的将它融合起来,
就到这了 如果各位看我的博客搭建这个环境有问题的话提出来 我会尽快改正
欢迎转载~请注明出处哦
SSM框架—详细整合教程(Spring+SpringMVC+MyBatis)
标签:write idea 生成 1.7 welcome dac 空闲 tps 技术分享
原文地址:http://www.cnblogs.com/gulangly/p/7602843.html