(1)页面中下拉框动态显示的原理是什么?
当我们点击添加员工时,不是先跳转到添加员工的界面,而是先跳转到一个servlet,先查询所有的部门信息和员工上级信息,携带这些信息请求转发到添加员工的界面,将查询到的信息填入到下拉选框中
(1)简述查询所有员工的逻辑和页面的跳转?
当点击查询所有员工时,首先到servlet内查找处理的方法,在该方法中调用了业务层查询员工信息的方法,业务层又调用了数据库访问层的查询所有员工信息的方法,将结果返回到servlet中,servlet将查询到的信息存储进request对象中,请求转发跳转到empList.jsp界面中
(2)查询所有信息要从empployee,dept,position查询,利用了多表连接和自连接,请问如何编写这个sql?
select e.empid,e.realname,e.sex,e.emptype,e.hiredate,e.onduty,e.qq,e.phone,e.deptno,d.deptname,e.posid,p.pname,mgr.empid,mgr.realname
from employee e
join dept d
on e.deptno=d.deptno
join position p
on e.posid=p.posid
join employee mgr
on e.mgrid=mgr.empid
(1)如何使用taglib指令导入jstl标签库?
先引入标签库:<%@taglib prefix=“c” uri=“http://java.sun.com/jsp/jstl/core” %>
再使用使用标签
(2)简述查询所有员工前台界面的编写?
在显示查询到的员工的信息的表格中,使用循环遍历流转到前台的list集合,将数据打印输出到浏览器上
(1)描述一种应用多条件查询的业务场景?
根据条件进行查询,如果满足条件则根据条件查询,如果所有条件为空或为空字符串则表示查询全部信息,否则有哪些条件满则要求就查询符合条件的信息
(2)如何完成查询条件的记忆功能?
当点击查询后,请求servlet,servlet获取请求信息后,将信息存储至request对象中,然后再在empList.jsp页面中使用EL表达式取出来。
(1)简述整个查询逻辑。
EmpServlet:
public void findEmp(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException{
//获取请求信息
String empid = req.getParameter("empid");
int deptno = Integer.parseInt(req.getParameter("deptno"));
int onduty = Integer.parseInt(req.getParameter("onduty"));
String shiredate = req.getParameter("hiredate");
DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
Date hiredate = null;
if(shiredate!=null && "".equals(shiredate)){
try {
hiredate = df.parse(shiredate);
} catch (ParseException e) {
e.printStackTrace();
}
}
//处理请求信息
EmpService es = new EmpServiceImpl();
List list = es.findEmp(empid,deptno,onduty,hiredate);
// 获取所有部门信息
DeptService ds = new DeptServiceImpl();
List deptList = ds.findAll();
req.setAttribute("deptList", deptList);
// 响应处理结果
req.setAttribute("empid", empid);
req.setAttribute("deptno", deptno);
req.setAttribute("onduty", onduty);
req.setAttribute("shiredate", shiredate);
req.setAttribute("list", list);
req.getRequestDispatcher("/system/empList.jsp").forward(req, resp);
}
EmpService:
List findEmp(String empid, int deptno, int onduty, Date hiredate);
EmpServiceImpl:
public List findEmp(String empid, int deptno, int onduty,
Date hiredate) {
return ed.findEmp(empid, deptno,onduty,hiredate);
}
EmpDao:
List findEmp(String empid, int deptno, int onduty, Date hiredate);
EmpDaoImpl:
public List findEmp(String empid2, int deptno2, int onduty2,
Date hiredate2) {
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
List list = null;
try {
conn = DBUtil.getConnection();
StringBuffer sql = new StringBuffer("select e.empid,e.realname,e.sex,e.emptype,e.hiredate,e.onduty,e.qq,e.phone,"
+" e.deptno,d.deptname,e.posid,p.pname,mgr.empid,mgr.realname"
+" from employee e"
+" join dept d"
+" on e.deptno=d.deptno"
+" join position p"
+" on e.posid=p.posid"
+" join employee mgr"
+" on e.mgrid=mgr.empid"
+" where 1=1");
if(empid2!=null && !"".equals(empid2)){
sql.append(" and e.empid like '%"+empid2+"%'");
}
if(deptno2!=0){
sql.append(" and e.deptno="+deptno2);
}
sql.append(" and e.onduty="+onduty2);
DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
if(hiredate2!=null){
String hiredate = df.format(hiredate2);
sql.append(" and to_char(e.hiredate,'yyyy-mm-dd')>="+hiredate);
}
ps = conn.prepareStatement(sql.toString());
list = new ArrayList<>();
rs = ps.executeQuery();
while(rs.next()){
Employee emp = new Employee();
emp.setEmpid(rs.getString("empid"));
emp.setRealname(rs.getString("realname"));
emp.setSex(rs.getString("sex"));
emp.setEmptype(rs.getInt("emptype"));
emp.setHiredate(rs.getDate("hiredate"));
emp.setOnduty(rs.getInt("onduty"));
emp.setQq(rs.getString("qq"));
emp.setPhone(rs.getString("phone"));
int deptno = rs.getInt("deptno");
String deptname = rs.getString("deptname");
Dept dept = new Dept();
dept.setDeptno(deptno);
dept.setDeptname(deptname);
emp.setDept(dept);
int posid = rs.getInt("posid");
String pname = rs.getString("pname");
Position position = new Position();
position.setPosid(posid);
position.setPname(pname);
emp.setPosition(position);
String empid = rs.getString(13);
String realname = rs.getString(14);
Employee mgr = new Employee();
mgr.setEmpid(empid);
mgr.setRealname(realname);
emp.setMgr(mgr);
list.add(emp);
}
} catch (Exception e) {
e.printStackTrace();
}
return list;
}
(2)如何完成后台的查询条件的sql的拼接。
StringBuffer sql = new StringBuffer("select e.empid,e.realname,e.sex,e.emptype,e.hiredate,e.onduty,e.qq,e.phone,"
+" e.deptno,d.deptname,e.posid,p.pname,mgr.empid,mgr.realname"
+" from employee e"
+" join dept d"
+" on e.deptno=d.deptno"
+" join position p"
+" on e.posid=p.posid"
+" join employee mgr"
+" on e.mgrid=mgr.empid"
+" where 1=1");
if(empid2!=null && !"".equals(empid2)){
sql.append(" and e.empid like '%"+empid2+"%'");
}
if(deptno2!=0){
sql.append(" and e.deptno="+deptno2);
}
sql.append(" and e.onduty="+onduty2);
DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
if(hiredate2!=null){
String hiredate = df.format(hiredate2);
sql.append(" and to_char(e.hiredate,'yyyy-mm-dd')>="+hiredate);
}
(1)简述删除员工的逻辑
在jsp页面中,点击删除,触发单击事件,弹出确认弹框,确认后向相应servlet发送请求,在发送请求的同时携带empid,empid通过el表达式获取。Servlet调用相应service,service调用dao层进行数据库操作。之后再将数据原路返回到servlet,使用重定向请求查询所有员工信息
(2)在删除员工成功后,页面跳转后条件页面上会带出来刚才删过的员工的编号,这个问题就是一个代码bug,那么这个问题怎么解决呢?
使用重定向进行页面跳转
(1)简述更新操作的逻辑?
点击修改,发送请求(附带empid),根据empid查询该员工信息,并显示在修改页面,在servlet中获取修改页面的数据,封装成对象作为参数传给相应service,再传给dao进行处理。之后将结果返回,成功则发送请求查询所有,否则跳转到修改页面
(1)如何将员工数据回显到empUpdate.jsp页面
根据empid查询出某个员工的信息,将信息存进request中,在请求转发流转到empUpdate.jsp中,在页面中使用el和jstl读取数据并显示
基本信息
(1)在整个更新操作中,需要注意的事项是什么?
更新操作要注意总共分为两部分,首先查询出要修改的员工的信息,之后再修改该员工的信息
(2)到这里为止,我们已经完成了员工的增删改查操作,我们是否可以总结一下,写代码从前端到后端的流程呢?(再次理解MVC)
前端界面(视图层)调用相应servlet(控制层),servlet调用service(业务层),service调用dao层进行数据操作。从数据库查询出数据后,再原路返回,返回到servlet后,请求转发或者重定向到其他servlet或者相应页面
(1)简述登陆功能的逻辑和页面的跳转。
用户输入用户名和密码,servlet将页面用户输入的数据获取,并作为参数传给service,service调用dao层,dao层将根据参数用户名和密码查询数据库中是否有符合条件的数据,有则通过可以登录,进入主页面,否则登陆失败,返回登录界面
(2)登陆成功进入到系统之后,页面上如何显示当前用户呢?
登陆成功时,将该用户的信息存进session中,页面上使用el表达式获取session中该员工信息,获取需要的数据,显示在正确的位置上
(1)如何完成用户退出功能?
将session销毁后重定向到登录界面
(2)登陆系统后,不同的用户看到的菜单是不一样的,这个功能如何完成的呢?
在jsp页面中使用jstl表达式,通过emptype判断身份,从而显示不同页面
(3)登陆系统后,不同的用户看到的菜单是不一样的,思考是否有更好的技术能帮助我们完成这个事呢?可以自行查询资料。
(1)平时经常遇到验证码功能,请问验证码的作用是什么?
是一种区分用户是计算机还是人的公共全自动程序。可以防止:恶意破解密码、刷票、论坛灌水,有效防止某个黑客对某一个特定注册用户用特定程序暴力破解方式进行不断的登陆尝试,实际上用验证码是现在很多网站通行的方式,我们利用比较简易的方式实现了这个功能
(2)如何完成验证码功能,简述整个逻辑?
在randoServlet中将验证码图像生产并存进session中,在登录的servlet中,将session中的验证码获取,同时也获取页面中用户输入的验证码,将二者进行对比,一致则通过,进行剩余代码,否则直接返回到登录界面。在jsp页面中,点击验证码,触发单击事件,根据时间不同,产生新的验证码