发表于: 2019-10-21 22:47:27
1 1074
今日想法:
再次重写一遍任务三,因为上次的问题实在是找不到解决方案。
1.建表设计表。
2.创建新的任务三项目。
2.1.添加pom依赖。
2.2.写mybatis/spring/springmvc/web/jdbc/log4j的配置文件。
2.3.写pojo表格类。
2.4.写mapper接口。
2.5.写mapper接口实现。
2.6.写service接口。
2.7.写service接口实现。
2.8.写一个小的查询测试,对已经写好的接口进行测试。
2.9.对已经写好的接口测试过后,改错,跑通。
3.写json格式的jsp返回文件。
4.写controller的接口。
5.配置tomcat,对写好的controller的接口进行测试。
6.排错,改错,直到跑通为止。
(上述流程,会在细节上进行一一记录,包括排错改错的学习过程。)
今日作为:
建表设计表
创建新的项目并且添加好自己需要的依赖包
springmvc的配置文件
<!--这里让扫描controller,指定controller的包-->
<context:component-scan base-package="com.clxs_wxx_1.controller"/>
<!-- 注解驱动:配置处理器映射器和适配器 -->
<mvc:annotation-driven/>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 配置jsp路径的前缀 -->
<property name="prefix" value="/WEB-INF/jsp"/>
<!-- 配置jsp路径的后缀 -->
<property name="suffix" value=".jsp"/>
</bean>
<!--静态资源映射-->
<mvc:resources mapping="/css/**" location="/WEB-INF/css/"/>
<mvc:resources mapping="/js/**" location="/WEB-INF/js"/>
spring-mybatis的配置文件
<?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>
<!-- 配置别名 -->
<typeAliases>
<!-- 批量扫描 别名-->
<package name="com.clxs_wxx_1.pojo"/>
</typeAliases>
</configuration>
链接数据库必备加载
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/clxs_wxx_1?characterEncoding=utf-8
jdbc.username=root
jdbc.password=root
打印日志文件配置
# Global logging configuration
log4j.rootLogger=DEBUG, stdout
# MyBatis logging configuration...
log4j.logger.com.how2java=TRACE
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n
spring-dao的配置
<!--开启注解模式-->
<context:annotation-config />
<!-- 加载配置文件 -->
<context:property-placeholder location="classpath:properties/jdbc.properties"/>
<!-- 数据库连接池 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
destroy-method="close">
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="maxActive" value="10"/>
<property name="minIdle" value="5"/>
</bean>
<!-- 让spring管理sqlsessionfactory 使用mybatis和spring整合包中的 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 数据库连接池 -->
<property name="dataSource" ref="dataSource"/>
<!-- 加载mybatis的全局配置文件 -->
<property name="configLocation" value="classpath:mybatis/SqlMapConfig.xml"/>
</bean>
<!--配置mapper扫描包-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.clxs_wxx_1.mapper"/>
spring-service的配置文件
<!--自动扫描service-->
<context:component-scan base-package="com.clxs_wxx_1.service" />
<!-- 事务管理器 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 数据源 -->
<property name="dataSource" ref="dataSource"/>
</bean>
<!-- 通知 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!-- 传播行为 -->
<tx:method name="save*" propagation="REQUIRED" />
<tx:method name="insert*" propagation="REQUIRED" />
<tx:method name="add*" propagation="REQUIRED" />
<tx:method name="create*" propagation="REQUIRED" />
<tx:method name="delete*" propagation="REQUIRED" />
<tx:method name="update*" propagation="REQUIRED" />
<tx:method name="find*" propagation="SUPPORTS" read-only="true" />
<tx:method name="select*" propagation="SUPPORTS" read-only="true" />
<tx:method name="get*" propagation="SUPPORTS" read-only="true" />
</tx:attributes>
</tx:advice>
<!-- 切面 -->
<aop:config>
<aop:advisor advice-ref="txAdvice"
pointcut="execution(* com.clxs_wxx_1.service.*.*(..))" />
</aop:config>
web文件配置
<!-- log4j配置文件地址 -->
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>classpath:properties/log4j.properties</param-value>
</context-param>
<!-- Log4j的监听器要放在spring监听器前面 -->
<listener><listener-class>
org.springframework.web.util.Log4jConfigListener
</listener-class>
</listener>
<!-- 加载spring容器 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/applicationContext.xml</param-value>
</context-param>
<listener><listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
<!--前端控制器-->
<servlet>
<servlet-name>taotao-manager</servlet-name><servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<!-- contextConfigLocation配置springmvc记载的配置文件
(配置处理器映射器、适配器等等)
如果不配置contextConfigLocation。
默认加载的是/WEB-INF/servlet名称-servlet.xml
-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/springMvc.xml</param-value>
</init-param>
<!-- 配置服务器启动后立即加载Spring MVC配置文件 -->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>taotao-manager</servlet-name>
<!--第一种:*.action,访问以action结尾由DispatcherServlet进行解析
第二种:/,所有的访问的地址都由DispatcherServlet进行解析,对于静态的文件我们希望不用DispatcherServlet解析,需要在springMvc.xml中添加静态资源映射!!。
使用此种方法可以实现RESTful风格的url
第三种:/*,这种配置不对,使用这种配置,最终要转发到一个jsp页面时,仍然会由DispatcherServlet解析jsp,不能根据jsp页面找到handler,会报错
-->
<url-pattern>/</url-pattern>
</servlet-mapping>
<!-- post乱码过滤器 -->
<filter>
<filter-name>CharacterEncodingFilter</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>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
至此,mybatis/spring/springmvc/jdbc/web/log4j等配置文件都已经写完,可以开始写详细的接口了。
这次写的接口是分级查询和模糊查询两个接口。
今日问题:
今日学习:
明日想法:
评论