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中重要部分

~~~
<%
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>
~~~
結果

- 學習心得
- 將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