尚硅谷SSM-CRUD整合项目
整合配置
- 创建maven工程,在pom文件中引入相关依赖 https://mvnrepository.com/
- 手动配置web.xml文件的地址 src/main/webapp/WEB-INF/web.xml
- 在web中配置
Spring配置文件地址,ContextLoaderListener监听器用来初始化spring
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-config.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
springMVC的前端控制器
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-config.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
字符编码过滤器
<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>
<init-param>
<param-name>forceResponseEncoding</param-name>
<param-value>true</param-value>
</init-param>
<init-param>
<param-name>forceRequestEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
REST风格
<filter>
<filter-name>HiddenHttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>HiddenHttpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
- 配置spring配置文件
- 配置springmvc配置文件
- 配置mybatis配置文件
- 创建对应数据库数据表,使用mybatis的逆向工程生成对应的bean和mapper github地址 官方文档根据官方文档,创建一个配置文件,然后在里面设置细节,比如数据库、bean、mapper文件的目标包,以及映射文件的位置等,然后再从官方文档中选择java代码生成的方式,去运行代码,生成逆向工程。
细节点
- context:component-scan中的use-default-filters
use-default-filters 属性的默认值为 true,即使用默认的 Filter 进行包扫描,而默认的 Filter 对标有 @Service,@Controller和@Repository 的注解的类进行扫描
设置为false时,只对自己指定的包进行扫描
总结:在使用 use-default-filters 属性时要分清楚需要扫描哪些包,是不是需要使用默认的 Filter 进行扫描。即 use-default-filters=“false” 需要和 context:include-filter 一起使用,而不能和 context:exclude-filter 属性一起使用。
<context:component-scan base-package="com.huazi.crud" use-default-filters="false">
<!-- 只扫描控制器-->
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
-
<tx:method … read-only=“true” /> read-only提高查询性能的原因
read-only默认是false,表示是否采用优化的只读事务
如果值为true就会告诉Spring这个方法里面没有insert、update或者delete,你只需要提供只读的数据库Connection就行了,这种执行效率会比read-write的Connection高,所以这是一个最优化提示。
在一些情况下,一些事务策略能够起到显着的最优化效果,例如在使用Object/Relational映射工具(如:Hibernate或TopLink)时避免dirty checking(试图“刷新”)。
总结:减少了因为要同步更新数据到数据库对系统性能的消耗,所以会提高查询性能。 -
将maven项目打包ssm-crud.war,然后放在tomcat/webapps目录下
启动服务器(tomcat/bin)startup.bat,war会被自动部署成一个文件,这时候可以直接在http://localhost:8080 下访问这个项目,也就是在实际服务器中运行。 -
项目中关于新增、修改、引入数据校验(前端后端)、删除(单个批量)等操作。
报错
- Using platform encoding (UTF-8 actually) to copy filtered resources, i.e. build is platform dependent!
【解决方案】在pom文件中添加
<properties>
<!--编译编码-->
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
-
Error:(3, 17) java: 程序包org.junit不存在【明明在pom文件中存在,且本地仓库里也有,但是还是报错】
【解决方案】在Setting中找到Maven,在下面的runner内,把 Delegate IDE build/run action to Maven打勾 -
”http://mybatis.org/dtd/mybatis-3-mapper.dtd“ 爆红
【解决方案】直接对爆红部分alt+enter,然后fetch external resource去添加这个资源,或者在setting中找到Schemas and DTDs,去手动添加或者去忽略爆红。 -
java.lang.IllegalStateException: Failed to load ApplicationContext
【解决方案】属于spring配置文件加载过程中的错误,找到报错里的caused by,根据后面的内容去找到错误的地方进行修改,我这次是因为引入tx名称空间错误,修改之后好了 -
SQLyog只能搜索出1000条记录,再添加也只是1000条,但是添加显示success
【解决方案】将SQLyog打开表的界面,限制行给取消勾选就行了,之前添加的都在 -
java.lang.AbstractMethodError: Method com/mchange/v2/c3p0/impl/NewProxyResultSet.isClosed()Z is abstract
【解决方案】更新c3p0包版本
总结
该项目大多是前端业务,主要用的技术是jsp和ajax,将近三天跟着视频做了一遍(一方面自己学习效率很低,一方面一些前端的知识比较杂乱,写的很慢)。
MyBatis Generator
mvnrepository
Bootstrap
Mybatis-PageHelper