什么是mvc
Controller(**Servlet)把数据封装成Model发给View显示
Model (Person)用户输入放到Model中传给Controller
View(jsp)只写for循环、颜色控制显示等,不在jsp中写业务逻辑代码
【知识点】
forward和sendRedirect都会导致浏览器收到一个响应,由于http协议规定一个请求只能对应一个响应,所以在进行forward或sendRedirect操作后,立即return,这样可以避免后面的代码再次生成响应从而导致错误
【注意】
setAttribute的使用周期
sendRedirect和forward的选择
【PersonServlet.java】
查询和新增功能
package com.rupeng.web2;
import java.io.IOException;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.LinkedList;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class PersonServlet extends HttpServlet
{
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException
{
this.doGet(req, resp);
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException
{
String action = req.getParameter("action");
if (action.equals("list"))
{
try
{
ResultSet rs = JdbcUtils
.executeQuery("select * from T_Persons2");
// req.setAttribute("rs", rs);
List<Person> list = new LinkedList<Person>();
while (rs.next())
{
int id = rs.getInt("Id");
String name = rs.getString("Name");
int age = rs.getInt("Age");
Person p = new Person();
p.setId(id);
p.setName(name);
p.setAge(age);
list.add(p);
}
JdbcUtils.closeAll(rs);
// /REsultSet等一般不要传给jsp
req.setAttribute("persons", list);// request中的数据有效期是“当前请求”
// jsp中就可以从request总取出"persons"的值
//!!!如果逻辑是服务器处理的,那么"/"一般可以表示“项目的WebRoot根目录”
//如果逻辑是浏览器端处理的。
req.getRequestDispatcher("/PersonList2.jsp").forward(req, resp);
//req.getRequestDispatcher("/PersonList2_2.jsp").forwar