发表于: 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 使用mybatisspring整合包中的 -->
<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等配置文件都已经写完,可以开始写详细的接口了。

这次写的接口是分级查询和模糊查询两个接口。

今日问题:


今日学习:


明日想法:


返回列表 返回列表
评论

    分享到