以下要讲的案例来自于《Spring 3.X 企业应用开发实战》这本书。

针对我一周的摸索,现在总结几个易错点,当然,这是在我自己犯过错误的前提下总结出来的,如果有说的不到位的地方,欢迎大家指出。所使用的代码均出自《Spring 3.X 企业应用开发实战》chapter2,代码什么的都不重要,差别不大,主要是配置容易出问题。

1.UserDao的代码

package com.baobaotao.dao;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowCallbackHandler;
import org.springframework.stereotype.Repository;
import com.baobaotao.domain.User; import java.sql.ResultSet;
import java.sql.SQLException; /**
* Created by RACHEL on 2017/10/11.
*/
@Repository
public class UserDao { @Autowired//自动注入JdbcTemplate的Bean
private JdbcTemplate jdbcTemplate; public User findUserByUserName(final String userName) {
//根据用户名查询用户的SQL语句
String sqlStr = "SELECT user_id,user_name,credits from t_user where user_name=?";
final User user = new User();
jdbcTemplate.query(sqlStr,new Object[]{userName},
new RowCallbackHandler() {
public void processRow(ResultSet resultSet) throws SQLException {
user.setUserID(resultSet.getInt("user_id"));
user.setUserName(userName);
user.setCredits(resultSet.getInt("credits"));
}
});
return user;
} public int getMatchCount(String userName, String password) {
String sqlStr = "select count(*) from t_user where user_name=? and password=?";
Object args[] = new Object[]{userName, password};
return jdbcTemplate.queryForObject(sqlStr, new Object[] {userName, password},int.class);
} public void updateLoginInfo(User user) {
String sqlStr = "update t_user set last_visit=?,last_ip=?,credits=? where user_id=?";
Object args[] = new Object[]{user.getLastVisit(), user.getLastIP(), user.getCredits(), user.getUserID()};
jdbcTemplate.update(sqlStr, args);
}
}

注意被标记的那段代码,是不是与书上有些许不同。书上用的是queryForInt(……)方法,而我换成了queryForObject方法,这是因为:spring 3.2.2版本之后,jdbctemplate中的queryForInt已经被取消了,  现在,全部用queryForObject了(包括queryForLong),queryForObject能代替queryForInt方法。关于这个问题,推荐一篇博客:http://jackyrong.iteye.com/blog/2086255

既然说到了方法queryForObject,那么接下来简单说说此方法的几点注意事项:

 public int getMatchCount(String userName, String password) {
String sqlStr = "select count(*) from t_user where user_name=? and password=?";
Object args[] = new Object[]{userName, password};
return jdbcTemplate.queryForObject(sqlStr, new Object[] {userName, password},integer.class); //注意,这段代码与书上不同,若用书上那段代码肯定会报错
}

queryForObject方法的写法:queryForObject(String sql, Object[] args, Class<T> requiredType){}

(1)JdbcTemple.queryForObject 返回都是单行单列一个数据,也就是说只能返回一条记录

(2)queryForObject()方法中,第三个参数是用来写返回值的类型的,如果需要返回的是int类型,就写Integer.class,需要返回long类型就写long.class.

2.UserServiceTest

package com.baobaotao.service;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import com.baobaotao.domain.User;
import com.baobaotao.services.UserService; import static org.junit.Assert.assertTrue;
/**
* Created by RACHEL on 2017/10/11.
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"/applicationContext.xml"})//assign spring profile
public class UserServiceTest {
@Autowired
private UserService userService;
@Test
//mark the manner of test
public void hasMatchUser() throws Exception {
boolean b1 = userService.hasMatchUser("aa","123"); //注意,这段测试代码不要照着书写,应该对应改成你在数据库中的用户名和密码;
boolean b2 = userService.hasMatchUser("aa","1223"); 换句话说,这里设置的用户名和密码必须与你在数据库中设置的一样,否则会找不到页面
assertTrue(b1);
assertTrue(!b2);
} @Test
public void findUserByUserName() throws Exception {
User user = userService.findUserByUserName("aa"); //用户名必须与数据库设置的用户名匹配 } }

3.web.xml文件

<servlet>
<servlet-name>demo7</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<load-on-startup>3</load-on-startup>
</servlet> <servlet-mapping>
<servlet-name>demo7</servlet-name>
<url-pattern>*.html</url-pattern>
</servlet-mapping>
</web-app>

注意,<servlet-name>……</servlet-name>中,必须是你的工程名,不要写错成baobaotao。我当时就是因为这个原因,一直报错,404找不到页面,倒腾了一天。But,如果大家将工程名和main下面的文件名都设置成baobaotao,也就没这么多事了。。

4.servlet.xml文件

<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver"
p:viewClass="org.springframework.web.servlet.view.JstlView"
p:prefix="/WEB-INF/"
p:suffix=".jsp" /> </beans>

如果你没有在WEB-INF下面建jsp文件夹,而是直接把main.jsp和login.jsp直接放到WEB-INF下, p:prefix="/WEB-INF/jsp"。这段代码表示的是你.jsp文件的存储路径,所以必须与自己对应的路径一直,否则会因为找不到路径报404错。


最后,给大家推荐一篇不错的博文,当时学习时,对我的帮助还是挺大的,以此共勉:http://www.cnblogs.com/yangyquin/p/5289604.html

使用Spring框架实现用户登录实例的更多相关文章

  1. 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(五)——实现注册功能

    使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化 使用 Flask 框架写用 ...

  2. 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(四)——对 run.py 的调整

    使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化 使用 Flask 框架写用 ...

  3. Django:用户登录实例

    Django:用户登录实例 一.源代码 1,login.html代码(登录界面): <!DOCTYPE html> <html lang="zh-CN"> ...

  4. 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用

    使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化 使用 Flask 框架写用 ...

  5. 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化

    使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化 使用 Flask 框架写用 ...

  6. 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(三)——使用Flask-Login库实现登录功能

    使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化 使用 Flask 框架写用 ...

  7. 最新 Eclipse IDE下的Spring框架配置及简单实例

    前段时间开始着手学习Spring框架,又是买书又是看视频找教程的,可是鲜有介绍如何配置Spring+Eclipse的方法,现在将我的成功经验分享给大家. 本文的一些源代码来源于码农教程:http:// ...

  8. vue新手入门之使用vue框架搭建用户登录注册案例,手动搭建webpack+Vue项目(附源码,图文详解,亲测有效)

    前言 本篇随笔主要写了手动搭建一个webpack+Vue项目,掌握相关loader的安装与使用,包括css-loader.style-loader.vue-loader.url-loader.sass ...

  9. 基于Servlet的MVC模式用户登录实例

    关于MVC模式的简单解释 M Model,模型层,例如登录实例中,用于处理登录操作的类: V View,视图层,用于展示以及与用户交互.使用html.js.css.jsp.jQuery等前端技术实现: ...

随机推荐

  1. 利用ASCII码生成指定规则的字符串

    /** * 上送终端编号的后两位生成规则 总共可以生成 (36*36-1)1295个编号 * 01...09 0A...0Z * 10...19 1A...1Z * ............... * ...

  2. 短视频图像处理 OpenGL ES 实践

    2017年,短视频正以其丰富的内容表现力和时间碎片化的特点,快速崛起,而短视频最具可玩性之处就在支持人脸识别的动态贴图和各种不同效果的美颜.滤镜等.那短视频动态贴纸.滤镜.美颜等功能究竟是如何实现的呢 ...

  3. uvalive 3708 Graveyard

    https://vjudge.net/problem/UVALive-3708 题意: 一个长度为10000的圆环上放着n个雕塑,每个雕塑之间的距离均相等,即这个圆环被n个点均分.现在需要加入m个雕塑 ...

  4. css样式引入优先级?

    css中的优先级讲的有 1.选择器的优先级. 2.样式引入的优先级. 今天要研究的是样式引入的优先级.网上又很多答案都是如下的,但是真的是这样的吗,让我们来探一探究竟是如何. 四种样式的优先级别是:行 ...

  5. C语言bitmap的使用技巧

    bitmap是一种以位的状态来表示某种特性的状态的一种操作方式,类似嵌入式中的寄存器操作,在表示某种特性enable/disable的时候很适用且占用的内存空间也很小 比如:做过交换机或者企业网管,路 ...

  6. Spring常用注解介绍【经典总结】

    Spring的一个核心功能是IOC,就是将Bean初始化加载到容器中,Bean是如何加载到容器的,可以使用Spring注解方式或者Spring XML配置方式. Spring注解方式减少了配置文件内容 ...

  7. Digital Square 搜索

    Digital Square Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Subm ...

  8. Island Perimeter

    You are given a map in form of a two-dimensional integer grid where 1 represents land and 0 represen ...

  9. [js高手之路] html5 canvas动画教程 - 匀速运动

    匀速运动:指的是物体在一条直线上运动,并且物体在任何相等时间间隔内通过的位移都是相等的.其实就是匀速直线运动,它的特点是加速度为0,从定义可知,在任何相等的时间间隔内,速度大小和方向是相同的. < ...

  10. 1-git初体验

    1 准备工作: windows系统下,安装好msysgit  -安装好后,在开始菜单找到Git  > Git bash 2 当前电脑配置用户名 邮箱 $ git config --global ...