jsp简易万能后台管理系统(一包辣条钱)
jsp万能后台管理系统,实现了知识的串联,可以作为任意简单系统后台的增删该查。
·
在学习完课程jsp后给自己做了个总结。做了一个简单的后台管理,实现了一些简单的业务逻辑CRUD。
其中不乏涉及到javaweb中的知识,在做这个小系统的时候,我是还没有接触css跟javaScrpit,就连el表达式也是网上看的,但是并不影响只有jsp基础的我,对于知识面只到jsp的我来说,这个项目涉及到的知识并没有超纲,只是说稍微加入了一些额外的知识像jquery,jdbctemplate,分页算法,动态sql语句查询,因为听说这一点知识后面也是要学的,到时候稍加修改,还可以用来变成学校的课程设计,还让自己先提前学习一点,毕竟在java这条长征的路上,多走一点算一点。
把前端三大件(html,css,javaScript)跟后台jbc的使用结合起来,从数据库到前端页面,虽然涉及的功能不多,但是却可以把前后的知识都串联起来,最后了解什么是MVC模式。
难点:session和request的使用,动态sql语句,分页算法,jdbc连接数据库
用到的jsp知识:
- MVC模式:前端三大件(V),servlet(C),bean(M)
- tomcate的配置
- 原始的jdbc(utils)
- tag标签
- sql语句查询(jdbctemplate)
- 4个内置对象域(page,request,session,application)
- 预处理
- 连接池
涉及到的javaweb的知识:
- jquery(就是下载了一个包,哈哈)
- jdbctemplate(简化的sql语句)
- jstl标签(临时学习的,因为不管后学前端框架还是后端框架都会用到,就现场学习了,哈哈哈啊)
- el表达式(临时学习的,)
涉及到的算法和功能问题:
- 分页算法
- 验证码的时间戳
- sql万能密码注入问题,动态sql解决(prepartedStatement)
package cn.itcast.dao.impl;
import cn.itcast.dao.UserDao;
import cn.itcast.domain.User;
import cn.itcast.util.JDBCUtils;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;
public class UserDaoImpl implements UserDao {
//连接池放入JdbcTemplate()中
private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
@Override
public List<User> findAll() {
//使用jdbc操作数据库
//1.定义sql
String sql = "select * from user";
//可参考jdbctemplate详解
//new BeanPropertyRowMapper<User>(User.class) 将结果集封装,存储到bean中,并返回一个list集合
List<User> users = template.query(sql, new BeanPropertyRowMapper<User>(User.class));
return users;
}
@Override
// public User findUserByUsernameAndPassword(String username,String password)
public User findUserByUsernameAndPassword(User user){
try {
String sql = "select * from user where username =? and password=?";
User user1= template.queryForObject(sql, new BeanPropertyRowMapper<User>(User.class),user.getUsername(),user.getPassword());
return user1;
}catch(Exception e){
e.printStackTrace();
return null;
}
}
@Override
public void add(User user) {
//1.定义sql
String sql ="insert into user values(null,?,?,?,?,?,?,null,null)";
//执行sql
template.update(sql,user.getName(),user.getGender(),user.getAge(),user.getAddress(),user.getQq(),user.getEmail());
}
@Override
public void delete(int id) {
//1定义sql
String sql = "delete from user where id = ?";
//2执行sql
template.update(sql,id);
}
@Override
public User findById(int id) {
String sql = "select * from user where id=?";
return template.queryForObject(sql,new BeanPropertyRowMapper<User>(User.class),id);
}
@Override
public void update(User user) {
String sql= "update user set name = ?,gender = ?,age= ?,address =?,qq=?,email = ? where id= ?";
template.update(sql,user.getName(),user.getGender(),user.getAge(),user.getAddress(),user.getQq(),user.getEmail(),user.getId());
}
登录页
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="utf-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=edge"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>管理员登录</title>
<!-- 1. 导入CSS的全局样式 -->
<link href="css/bootstrap.min.css" rel="stylesheet">
<!-- 2. jQuery导入,建议使用1.9以上的版本 -->
<script src="js/jquery-2.1.0.min.js"></script>
<!-- 3. 导入bootstrap的js文件 -->
<script src="js/bootstrap.min.js"></script>
<script type="text/javascript">
</script>
</head>
<body>
<div class="container" style="width: 400px;">
<h3 style="text-align: center;">管理员登录</h3>
<form action="login" method="post">
<div class="form-group">
<label for="user">用户名:</label>
<input type="text" name="user" class="form-control" id="user" placeholder="请输入用户名"/>
</div>
<div class="form-group">
<label for="password">密码:</label>
<input type="password" name="password" class="form-control" id="password" placeholder="请输入密码"/>
</div>
<div class="form-inline">
<label for="vcode">验证码:</label>
<input type="text" name="verifycode" class="form-control" id="verifycode" placeholder="请输入验证码" style="width: 120px;"/>
<a href="javascript:refreshCode()"><img src="vcode" title="看不清点击刷新" id="vcode"/></a>
</div>
<hr/>
<div class="form-group" style="text-align: center;">
<input class="btn btn btn-primary" type="submit" value="登录">
</div>
</form>
<!-- 出错显示的信息框 -->
<div class="alert alert-warning alert-dismissible" role="alert">
<button type="button" class="close" data-dismiss="alert" >
<span>×</span></button>
<strong>登录失败!</strong>
</div>
</div>
</body>
</html>
更多推荐
已为社区贡献1条内容
所有评论(0)