控制层:
文件上传需要import org.apache.commons.fileuploadjar包
代码语言:javascript复制package com.product.dbutil.product.action;
import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
import com.product.dbutil.product.dao.ProductDao;
import com.product.dbutil.product.service.ProductService;
import com.product.dbutil.product.util.DividePage;
import com.product.dbutil.product.util.UUIDTools;
public class ProductAction extends HttpServlet {
private ProductService service;
/**
* Constructor of the object.
*/
public ProductAction() {
super();
}
/**
* Destruction of the servlet. <br>
*/
public void destroy() {
super.destroy(); // Just puts "destroy" string in log
// Put your code here
}
/**
* The doGet method of the servlet. <br>
*
* This method is called when a form has its tag value method equals to get.
*
* @param request
* the request send by the client to the server
* @param response
* the response send by the server to the client
* @throws ServletException
* if an error occurred
* @throws IOException
* if an error occurred
*/
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doPost(request, response);
}
/**
* The doPost method of the servlet. <br>
*
* This method is called when a form has its tag value method equals to
* post.
*
* @param request
* the request send by the client to the server
* @param response
* the response send by the server to the client
* @throws ServletException
* if an error occurred
* @throws IOException
* if an error occurred
*/
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
PrintWriter out = response.getWriter();
String action_flag = request.getParameter("action_flag");
if (action_flag.equals("add")) {
addProduct(request, response);
} else if (action_flag.equals("list")) {
listProduct(request, response);
} else if (action_flag.equals("del")) {
delProduct(request, response);
}else if(action_flag.equals("view")){
viewProduct(request, response);
}
out.flush();
out.close();
}
private void viewProduct(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
String proid = request.getParameter("proid");
Map<String,Object> map = service.viewProduct(proid);
request.setAttribute("map", map);
request.getRequestDispatcher("/product/2_1_5xs.jsp").forward(request, response);
}
private void delProduct(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
String path = request.getContextPath();
// 获得选中的复选框的值
String[] ids = request.getParameterValues("ids");
boolean flag = service.delProduct(ids);
if (flag) {
response.sendRedirect(path
"/servlet/ProductAction?action_flag=list");
}
}
private void listProduct(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
// String path = request.getContextPath();
// 接收用户的查询名字
String proname = request.getParameter("proname");
int recordCount = service.getItemCount();// 获得记录的总条数
int currentPage = 1;// 当前页是第一页
String pageNum = request.getParameter("pageNum");
if (pageNum != null) {
currentPage = Integer.parseInt(pageNum);
}
DividePage pUtil = new DividePage(5, recordCount, currentPage);
int start = pUtil.getFromIndex();
int end = pUtil.getToIndex();
// 已经进行分页之后的数据集合
List<Map<String, Object>> list = service.listProduct(proname, start,
end);
request.setAttribute("pUtil", pUtil);
request.setAttribute("listproduct", list);
request.setAttribute("proname", proname);
request.getRequestDispatcher("/product/2_1_5.jsp").forward(request,
response);
}
private void addProduct(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
// 表单含有文件要提交
String path = request.getContextPath();
DiskFileItemFactory diskFileItemFactory = new DiskFileItemFactory();
// 构建一个文件上传类
ServletFileUpload servletFileUpload = new ServletFileUpload(
diskFileItemFactory);
servletFileUpload.setFileSizeMax(3 * 1024 * 1024);
servletFileUpload.setSizeMax(6 * 1024 * 1024);// 上传文件总大小
List<FileItem> list = null;
List<Object> params = new ArrayList<Object>();
params.add(UUIDTools.getUUID());
try {
// 解析request的请求
list = servletFileUpload.parseRequest(request);
// 取出所有表单的值:判断非文本字段和文本字段
for (FileItem fileItem : list) {
if (fileItem.isFormField()) {
if (fileItem.getFieldName().equals("proname")) {
params.add(fileItem.getString("utf-8"));
}
if (fileItem.getFieldName().equals("proprice")) {
params.add(fileItem.getString("utf-8"));
}
if (fileItem.getFieldName().equals("proaddress")) {
params.add(fileItem.getString("utf-8"));
}
} else {
try {
String image = fileItem.getName();
params.add(image);
String upload_path = request.getRealPath("/upload");
System.out.println("--->>" upload_path);
//
File real_path = new File(upload_path "/" image);
fileItem.write(real_path);
boolean flag = service.addProduct(params);
if (flag) {
response
.sendRedirect(path
"/servlet/ProductAction?action_flag=list");
}
// 把数据插入到数据库中
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
} catch (FileUploadException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
/**
* Initialization of the servlet. <br>
*
* @throws ServletException
* if an error occurs
*/
public void init() throws ServletException {
// Put your code here
service = new ProductDao();
}
}
服务层:
代码语言:javascript复制package com.product.dbutil.product.service;
import java.util.List;
import java.util.Map;
public interface ProductService {
public boolean addProduct(List<Object> params);
public boolean delProduct(String[] ids);
// 提取所有产品的信息
public List<Map<String, Object>> listProduct(String proname,int start,int end);
public int getItemCount();
public Map<String,Object> viewProduct(String proid);
}
数据访问层:
代码语言:javascript复制package com.product.dbutil.product.dao;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.concurrent.CountDownLatch;
import com.product.dbutil.jdbc.JdbcUtils;
import com.product.dbutil.product.service.ProductService;
public class ProductDao implements ProductService {
private JdbcUtils jdbcUtils;
public ProductDao() {
// TODO Auto-generated constructor stub
jdbcUtils = new JdbcUtils();
}
public boolean addProduct(List<Object> params) {
// TODO Auto-generated method stub
boolean flag = false;
try {
String sql = "insert into product(proid,proname,proprice,proaddress,proimage) values(?,?,?,?,?)";
jdbcUtils.getConnection();
flag = jdbcUtils.updateByPreparedStatement(sql, params);
} catch (Exception e) {
// TODO: handle exception
} finally {
jdbcUtils.releaseConn();
}
return flag;
}
/*
* (non-Javadoc) 提取产品的信息
*
* @see com.product.dbutil.product.service.ProductService#listProduct()
*/
public List<Map<String, Object>> listProduct(String proname, int start,
int end) {
// TODO Auto-generated method stub
List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
String sql = "select * from product where (1=1) ";
// limit ?,?
StringBuffer buffer = new StringBuffer(sql);
List<Object> params = new ArrayList<Object>();
if (proname != null) {
buffer.append(" and proname like ? ");
params.add("%" proname "%");
}
buffer.append("limit ?,? ");
params.add(start);
params.add(end);
try {
jdbcUtils.getConnection();
list = jdbcUtils.findMoreResult(buffer.toString(), params);
} catch (Exception e) {
// TODO: handle exception
} finally {
jdbcUtils.releaseConn();
}
return list;
}
public int getItemCount() {
int result = 0;
Map<String, Object> map = null;
String sql = " select count(*) mycount from product ";
try {
jdbcUtils.getConnection();
map = jdbcUtils.findSimpleResult(sql, null);
result = Integer.parseInt(map.get("mycount").toString());
} catch (Exception e) {
// TODO: handle exception
} finally {
jdbcUtils.releaseConn();
}
// TODO Auto-generated method stub
return result;
}
public boolean delProduct(String[] ids) {
// TODO Auto-generated method stub
boolean flag = false;
try {
jdbcUtils.getConnection();
String[] sql = new String[ids.length];
if (ids != null) {
for (int i = 0; i < ids.length; i ) {
sql[i] = "delete from product where proid='" ids[i] "'";
}
}
flag = jdbcUtils.deleteByBatch(sql);
} catch (Exception e) {
// TODO: handle exception
} finally {
jdbcUtils.releaseConn();
}
return flag;
}
public Map<String, Object> viewProduct(String proid) {
// TODO Auto-generated method stub
Map<String, Object> map = null;
try {
String sql = "select * from product where proid = ? ";
List<Object> params = new ArrayList<Object>();
params.add(proid);
jdbcUtils.getConnection();
map = jdbcUtils.findSimpleResult(sql, params);
} catch (Exception e) {
// TODO: handle exception
} finally {
jdbcUtils.releaseConn();
}
return map;
}
}
分页查找工具类:
代码语言:javascript复制package com.product.dbutil.product.util;
public class DividePage {
private int pageSize;// 表示显示的条数
private int recordCount;// 表示记录的总条数
private int currentPage;// 表示当前页
public DividePage(int pageSize, int recordCount, int currentPage) {
// TODO Auto-generated constructor stub
this.pageSize = pageSize;
this.recordCount = recordCount;
setCurrentPage(currentPage);
}
public DividePage(int pageSize, int recordCount) {
// TODO Auto-generated constructor stub
this(pageSize, recordCount, 1);
}
// 获得总页数
public int getPageCount() {
int size = recordCount / pageSize;
int mod = recordCount % pageSize;
if (mod != 0) {
size ;
}
return recordCount == 0 ? 1 : size;
}
public int getFromIndex() {
return (currentPage - 1) * pageSize;
}
public int getToIndex() {
return pageSize;
}
public int getCurrentPage() {
return currentPage;
}
public void setCurrentPage(int currentPage) {
int validPage = currentPage <= 0 ? 1 : currentPage;
validPage = validPage > getPageCount() ? getPageCount() : validPage;
this.currentPage = validPage;
}
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public int getRecordCount() {
return recordCount;
}
public void setRecordCount(int recordCount) {
this.recordCount = recordCount;
}
}
唯一ID工具类:
代码语言:javascript复制package com.product.dbutil.product.util;
import java.util.UUID;
public class UUIDTools {
public UUIDTools() {
// TODO Auto-generated constructor stub
}
public static String getUUID() {
UUID uuid = UUID.randomUUID();
return uuid.toString().replaceAll("-", "").substring(0, 6);
}
}