java-project3
java-project3 copied to clipboard
SSM在线考试系统
java-project3
用到的技术:
spring+springmvc+mybatis+jquery
数据库:
mysql
分页:
pagehelper
简单的介绍:
这是一个在线考试系统,老师能登录后台进行相关操作,学生进行考试,页面做的不是特别好看,主要是熟悉crud的一些操作和框架的整合.
遇到的一些问题:
1.在配置好ssm环境后启动报错:org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactoryBean' defined in class path resource [spring/spring.xml]: Invocation of init method failed; nested exception is org.springframework.core.NestedIOException: Failed to parse config resource: class path resource [spring/mybatis-config.xml]; nested exception is org.apache.ibatis.builder.BuilderException: Error parsing SQL Mapper Configuration. Cause: org.apache.ibatis.builder.BuilderException: The setting is not known. Make sure you spelled it correctly (case sensitive).
答:原因是因为mybatis-config中有setting写错了,我多写了一个<setting name="",value=""></setting>
(不知道什么时候手抽了)
2.StudentDaoImpl单元测试时,student这个bean在xml中配置了但在单元测试时一直为空:
答:https://stackoverflow.com/questions/50626457/i-defined-a-bean-in-spring-xml-and-i-want-to-use-the-bean-in-the-java-code-by-us
3.判断单选框是否被选中以及获得其中的值:
答:http://www.jb51.net/article/64141.htm
4.mybatis报错:org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.type.TypeException: Could not set parameters for mapping: ParameterMapping{property='subjectTitle', mode=IN, javaType=class java.lang.Object, jdbcType=null, numericScale=null, resultMapId='null', jdbcTypeName='null', expression='null'}. Cause: org.apache.ibatis.type.TypeException: Error setting non null for parameter #1 with JdbcType null . Try setting a different JdbcType for this parameter or a different configuration property. Cause: org.apache.ibatis.type.TypeException: Error setting non null for parameter #1 with JdbcType null . Try setting a different JdbcType for this parameter or a different configuration property. Cause: java.sql.SQLException: Parameter index out of range (1 > number of parameters, which is 0).
答:报错是说参数有错误,我的select语句是这么写的<select>select * from tb_subject where subjectTitle like '%#{subjectTitle}%'</select>
,但是这么写在mybatis中是不对的,http://w6513017.iteye.com/blog/1512761
5.从数据库中随机的查数据:
http://www.jb51.net/article/42229.htm
6.试卷页面我本来是想分页做的,但是我查询的时候就是用的limit,它分页时也是用的limit,就变成了select * from tb_subject limit 20 limt 10
这样就报错了,不知道怎么办
能够改进的地方:
1.学生注册时忘记做验证了,你不填也能够注册进去。(最后检验的时候才发现,那为什么不改呢???因为我懒,嘤嘤嘤)
2.所有的验证都只是前端验证,其实应该要前后端都要验证,最少也要后端验证。(那为什么不进行后端验证呢???...嘤嘤嘤)
3.拓展性不够好,很多地方都写死了,就比如老师不能修改考试时间
4.没有过滤特殊字符,没有限制输入的格式长度.
能够改进的地方太多了,就不一一列举了...
做的比较好的地方:
1.架构分成了四层:①表现层②业务逻辑层③持久层④数据库层,写代码时思路就比较清晰.
2.修改试题 增加试题 删除试题 都是用的同一个success.jsp通过<c:choose><c:when></c:when></c:choose>
实现.
3.这次不像java-project2那样自己写的分页,而是用的刘增辉大神写的pagehelper,真的简单多了.
项目截图
0.项目目录
data:image/s3,"s3://crabby-images/f1f68/f1f6883719ee517eba77038cc84754265b6a90ee" alt=""
1.首页
data:image/s3,"s3://crabby-images/a522e/a522e4d81b762445ea451e609d9e6ce8df45366b" alt=""
2.注册页面
data:image/s3,"s3://crabby-images/a860e/a860e3d18e7e640944e98fd59e89b1028c5adfa2" alt=""
data:image/s3,"s3://crabby-images/3c366/3c3662c7be8eeb4d549cf0b57328136e0ce00f5d" alt=""
3.管理员登录
data:image/s3,"s3://crabby-images/6ed70/6ed706387d9c959c205504f2116c7b59b5668f4f" alt=""
4.管理员登录首页
data:image/s3,"s3://crabby-images/fa9a3/fa9a313fba27c0dfdd7ba717d794b3fe7c71bb87" alt=""
5.导入试题
data:image/s3,"s3://crabby-images/f78da/f78da0a6244d23f9b311aab2dd31534e60761e5c" alt=""
data:image/s3,"s3://crabby-images/f331a/f331abb30d36c75a9ff9d4946b04bf84f3d8a344" alt=""
6.管理试题
data:image/s3,"s3://crabby-images/f59a6/f59a685b8e1967fd73ab06efb0935e49b8a9cf13" alt=""
data:image/s3,"s3://crabby-images/eff2e/eff2e8af867e38101dd1c9f4a0543f49533e5132" alt=""
data:image/s3,"s3://crabby-images/50557/505571da7f95e20c6cb0c840fc7e74daff3ffca2" alt=""
data:image/s3,"s3://crabby-images/47b8b/47b8be9aa25120018b37c798a0e54aa7bb802572" alt=""
7.查看试题
data:image/s3,"s3://crabby-images/bd16e/bd16e2ff06f79d3bc45f9bf91b5e73ef54cd897f" alt=""
8.查看试题
data:image/s3,"s3://crabby-images/6375a/6375a323faa4987a06c75cae801cbd6b3dc0a8cd" alt=""
data:image/s3,"s3://crabby-images/be86f/be86fd9e12490986e94c3e2a844c028db86170e4" alt=""
9.管理学生
data:image/s3,"s3://crabby-images/bc2ac/bc2ac92563ebbdf7852f4a842e45518bd7d44d50" alt=""
data:image/s3,"s3://crabby-images/6debb/6debbb96feca9a674a609f05d3df58e2fdbd211f" alt=""
data:image/s3,"s3://crabby-images/d2662/d266232fb56ce4b087bdb48e3cdfcf7a0e0c76ff" alt=""
data:image/s3,"s3://crabby-images/5dcc6/5dcc605b81675d7b82cd58f9ec4ead1132d30806" alt=""
10.学生登录
data:image/s3,"s3://crabby-images/ea59a/ea59a96652d9b4c44b425fd52e3b1198cafcfe32" alt=""
11.学生首页
data:image/s3,"s3://crabby-images/c79a4/c79a41041a63306c94bc9a91582100b9e2553dca" alt=""
12.学生考试界面
data:image/s3,"s3://crabby-images/63f36/63f3603ea1f61f9d96c54827e86e95f4faf431ad" alt=""
13.自动得出分数界面
data:image/s3,"s3://crabby-images/3a596/3a59696247557239aade1914fc9f4efa88e2fd9c" alt=""
data:image/s3,"s3://crabby-images/53cbe/53cbed135c6b2466548e7e16d377bf6d5b743ca4" alt=""
data:image/s3,"s3://crabby-images/d84aa/d84aa7b134dded0cf9fb8e8c29ba29163461ebe2" alt=""