在学习完课程jsp后给自己做了个总结。做了一个简单的后台管理,实现了一些简单的业务逻辑CRUD。

 

其中不乏涉及到javaweb中的知识,在做这个小系统的时候,我是还没有接触css跟javaScrpit,就连el表达式也是网上看的,但是并不影响只有jsp基础的我,对于知识面只到jsp的我来说,这个项目涉及到的知识并没有超纲,只是说稍微加入了一些额外的知识像jquery,jdbctemplate,分页算法,动态sql语句查询,因为听说这一点知识后面也是要学的,到时候稍加修改,还可以用来变成学校的课程设计,还让自己先提前学习一点,毕竟在java这条长征的路上,多走一点算一点。

把前端三大件(html,css,javaScript)跟后台jbc的使用结合起来,从数据库到前端页面,虽然涉及的功能不多,但是却可以把前后的知识都串联起来,最后了解什么是MVC模式。

难点:session和request的使用,动态sql语句,分页算法,jdbc连接数据库

用到的jsp知识:

  1. MVC模式:前端三大件(V),servlet(C),bean(M)
  2. tomcate的配置
  3. 原始的jdbc(utils)
  4. tag标签
  5. sql语句查询(jdbctemplate)
  6. 4个内置对象域(page,request,session,application)
  7. 预处理
  8. 连接池

涉及到的javaweb的知识:

  1. jquery(就是下载了一个包,哈哈)
  2. jdbctemplate(简化的sql语句)
  3. jstl标签(临时学习的,因为不管后学前端框架还是后端框架都会用到,就现场学习了,哈哈哈啊)
  4. el表达式(临时学习的,)

 

涉及到的算法和功能问题:

  1. 分页算法
  2. 验证码的时间戳
  3. sql万能密码注入问题,动态sql解决(prepartedStatement)

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAVlhfX19UYXVydXMtenp6eHk=,size_20,color_FFFFFF,t_70,g_se,x_16

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAVlhfX19UYXVydXMtenp6eHk=,size_20,color_FFFFFF,t_70,g_se,x_16

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAVlhfX19UYXVydXMtenp6eHk=,size_20,color_FFFFFF,t_70,g_se,x_16

 watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAVlhfX19UYXVydXMtenp6eHk=,size_20,color_FFFFFF,t_70,g_se,x_16

 

 

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>&times;</span></button>
		   <strong>登录失败!</strong>
		</div>
  	</div>
  </body>
</html>

 

 

Logo

基于 Vue 的企业级 UI 组件库和中后台系统解决方案,为数万开发者服务。

更多推荐