CategoryServlet.java
~~~
package zyw.web;
import org.apache.commons.beanutils.BeanUtils;
import zyw.bean.Category;
import zyw.service.CategoryService;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.sql.SQLException;
import java.util.Date;
import java.util.Map;
@WebServlet(name = "CategoryServlet",urlPatterns = "/category")
public class CategoryServlet extends BaseServlet {
public void addCategory(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//获取参数 通过BeanUtils封装实体类
try {
Map<String, String[]> parameterMap = request.getParameterMap();
Category category = new Category();
category.setCreatetime(new Date());
BeanUtils.populate(category,parameterMap);
CategoryService categoryService=new CategoryService();
boolean b = categoryService.addCategory(category);
if (b){
//添加成功
response.setStatus(201);
request.getRequestDispatcher("/category-add.jsp").forward(request,response);
}else {
// 添加失败
response.setStatus(600);
request.getRequestDispatcher("/category-add.jsp").forward(request,response);
}
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}catch (SQLException e) {
e.printStackTrace();
}
}
}
~~~
CategoryService.java
~~~
package zyw.service;
import zyw.bean.Category;
import zyw.dao.CategoryDao;
import java.sql.SQLException;
public class CategoryService {
//添加
public boolean addCategory(Category category) throws SQLException {
CategoryDao dao = new CategoryDao();
boolean addCategory = dao.addCategory(category);
return addCategory;
}
}
~~~
CategoryDao.java
~~~
package zyw.dao;
import com.mchange.v2.c3p0.ComboPooledDataSource;
import org.apache.commons.dbutils.QueryRunner;
import zyw.bean.Category;
import java.sql.SQLException;
public class CategoryDao {
public boolean addCategory(Category category) throws SQLException {
ComboPooledDataSource dataSource=new ComboPooledDataSource();
QueryRunner queryRunner=new QueryRunner(dataSource);
String sql="insert into category values(null,?,?,?,?)";
int row = queryRunner.update(sql, category.getC_name(), category.getPlace(), category.getCreatetime(), category.getType());
if (row>0){
return true;
}else {
return false;
}
}
}
~~~
category-add.jsp中重要部分
![](https://box.kancloud.cn/d893f091495a16a598c729e024a10d33_587x110.png)
~~~
<%
System.out.println(response.getStatus() + "--------------status");
if (response.getStatus() == 201) {
out.write("<script type=\"text/javascript\">\n" +
" window.onload=function(){\n" +
" showdiv();\n" +
" }</script>");
} else if (response.getStatus() == 200) {
} else {
out.write("<script type=\"text/javascript\">\n" +
" window.onload=function(){\n" +
" hidediv();\n" +
" }</script>");
}
%>
<script>
function showdiv() {
document.getElementById('sucess-info').style.display = 'block';//show的display属性设置为block(显示)
document.getElementById('fail-info').style.display = 'none';//show的display属性设置为block(显示)
}
function hidediv() {
document.getElementById('fail-info').style.display = 'block';
document.getElementById('sucess-info').style.display = 'none';//show的display属性设置为none(隐藏)
}
</script>
~~~
结果
![](https://box.kancloud.cn/a976e9d0e6ee7c5b7fe82047d244b558_1330x457.png)
- 学习心得
- 将jar包加入项目中
- Servlet
- 编写第一个Servlet
- 使用Servlet3.0创建Servlet
- HttpServletRequest简介-获取请求行和请求头
- HttpServletResponse获取请求参数
- response对象发送响应行和响应头
- HttpServletResponse发送请求体
- 【实例】验证码
- Servlet的生命周期
- ServletConfig对象
- ServletContext-获取项目初始化参数
- ServletContext对象-在多个Servlet之间共享参数
- 请求转发
- 【实例】登录错误时显示错误界面
- 重定向介绍
- 网页的自动刷新
- Servlet线程安全
- 案例 文件下载
- Cookie与Session会话技术
- 会话技术概述
- Cookie的会话流程
- 获取Cookie
- 【案例 】记录网站上一次访问时间
- Session的会话流程
- 使用Session域对象存取数据
- Session的生命周期和持久化
- 【实例】购物车的简单使用
- JSP技术
- JSP指令
- JSP隐式对象
- JSP标签
- JSTL标签库
- EL表达式
- EL的内置对象和执行表达式
- JSTL简介
- JSTL-if标签
- JSTL-forEach标签
- 【案例】实现商品列表展示
- MySQL数据库
- SQL语句
- 命名规则与数据类型
- SQL-增删改查
- 设计数据库
- JDBC的应用
- JDBC连接数据库
- 查询
- 插入.删除.修改
- Junit单元测试
- 预防SQL注入
- JDBCutils工具类
- 监听器Listener
- ServletContextListener
- HttpSessionListener和ServletRequestListener
- 域对象属性监听器
- 对象感知监听器
- 【案例】商品促销活动推广
- 过滤器Filter
- 创建一个过滤器
- Filter生命周期和配置
- 【案例】解决中文输出乱码问题
- XML入门
- XML元素和解析方式
- XML约束
- 实战-生鲜后台管理系统
- MVC和三层架构
- 项目需求和项目搭建
- 数据库设计
- 注册功能
- 登录功能
- 记住密码
- BeanUtils的使用
- Servlet的抽取(上)
- Servlet的抽取(下)
- 增加生鲜种类
- 查询生鲜列表
- 分页功能
- 修改生鲜信息
- 删除生鲜功能
- 权限控制Filter