**
代码日记2
用户信息查询
** 继上一个日记之后,管理员登录成功,接下来进行用户信息增删改查的查询功能 前端页面 当管理员登录成功之后跳转到index.jsp页面
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!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 align="center">
<a
href="${pageContext.request.contextPath}/UserListServlet" style="text-decoration:none;font-size:33px">查询所有用户信息
</a>
</div>
</body>
</html>
点击查询所有用户信息,跳转到list.jsp页面,代码如下
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html>
<!-- 网页使用的语言 -->
<html lang="zh-CN">
<head>
<!-- 指定字符集 -->
<meta charset="utf-8">
<!-- 使用Edge最新的浏览器的渲染方式 -->
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<!-- viewport视口:网页可以根据设置的宽度自动进行适配,在浏览器的内部虚拟一个容器,容器的宽度与设备的宽度相同。
width: 默认宽度与设备的宽度相同
initial-scale: 初始的缩放比,为1:1 -->
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
<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>
<style type="text/css">
td, th {
text-align: center;
}
</style>
</head>
<body>
<div class="container">
<h3 style="text-align: center">用户信息列表</h3>
<table border="1" class="table table-bordered table-hover">
<tr class="success">
<th>编号</th>
<th>姓名</th>
<th>性别</th>
<th>年龄</th>
<th>籍贯</th>
<th>QQ</th>
<th>邮箱</th>
<th>操作</th>
</tr>
<c:forEach items="${users}" var="user" varStatus="s">
<tr>
<td>${s.count}</td>
<td>${user.name}</td>
<td>${user.gender}</td>
<td>${user.age}</td>
<td>${user.address}</td>
<td>${user.qq}</td>
<td>${user.email}</td>
<td><a class="btn btn-default btn-sm" href="update.jsp?count=${s.count}">修改</a> <a class="btn btn-default btn-sm" href="${pageContext.request.contextPath}/DeleteUserServlet?count=${s.count}">删除</a></td>
</tr>
</c:forEach>
<tr>
<td colspan="8" align="center"><a class="btn btn-primary" href="adduser.jsp">添加联系人</a></td>
</tr>
</table>
</div>
</body>
</html>
再看后端代码为UserListServlet.java 核心代码如下
//调用Servive层获取数据
UserService service=new UserServiceImpl();
List<User> list=service.findAll();
//转发到特定的页面
//将获取到的list集合存储到request域中
request.setAttribute("users", list);
request.getRequestDispatcher("/list.jsp").forward(request, response);
服务层
package com.zjh.service;
import java.util.List;
import com.zjh.domain.Admin;
import com.zjh.domain.User;
public interface UserService {
//登录方法
public Admin login(Admin admin);
//查询所有用户
public List<User> findAll();
}
服务层接口 核心代码:
@Override public List findAll() {
return dao.findAll();
} 数据层
package com.zjh.dao;
import java.util.List;
import com.zjh.domain.Admin;
import com.zjh.domain.User;
public interface UserDao {
//查询方法
public List<User> findAll();
}
数据层接口 核心代码
package com.zjh.dao.impl;
import java.security.interfaces.RSAKey;
import java.util.List;
import java.util.Map;
import org.apache.commons.beanutils.BeanUtils;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.ParameterMapper;
import org.springframework.jdbc.support.JdbcUtils;
import com.sun.research.ws.wadl.Request;
import com.zjh.dao.UserDao;
import com.zjh.domain.Admin;
import com.zjh.domain.User;
import com.zjh.util.JDBCUtils;
public class UserDaoImpl implements UserDao{
//基于阿里巴巴duri连接池下的连接技术
private JdbcTemplate template=new JdbcTemplate(JDBCUtils.getDataSource());
//管理员登录
@Override
public Admin login(String username,String password) {
try {
String sql="select * from admin where username=? and password=?";
Admin admin=template.queryForObject(sql, new BeanPropertyRowMapper<Admin>(Admin.class),username,password);
return admin;
} catch (Exception e) {
System.out.println("用户名或密码有误");
return null;
}
}
//用户信息查找
@Override
public List<User> findAll() {
String sql="select * from user";
List<User> user=template.query(sql, new BeanPropertyRowMapper<User>(User.class));
return user;
}
}
三层架构原理逻辑要清楚,服务层→业务层→数据层 重点:数据库查询语句 select from table_name,查询的用户是一个集合所以用List,还有连接池技术块
|