首页 > 其他分享 >day05-功能实现04

day05-功能实现04

时间:2022-12-19 22:44:33浏览次数:50  
标签:功能 return 04 int day05 public Furn id furn

家居网购项目实现04

以下皆为部分代码,详见 https://github.com/liyuelian/furniture_mall.git

10.功能09-后台管理 删除家居

10.1需求分析/图解

需求如下:

  1. 管理员进入到家居管理页面
  2. 点击删除家居连接,弹出确认窗口,确认删除,取消放弃
image-20221219164920325

10.2思路分析

10.3代码实现

10.3.1dao层

FurnDAO接口

/**
* 通过传入的id,删除furn表中对应的记录
*
* @param id id
* @return 返回受影响的行数
*/
public int deleteFurnById(int id);

FurnDAOImpl

@Override
public int deleteFurnById(int id) {
    String sql = "DELETE FROM `furn` WHERE `id`=?;";
    return update(sql, id);
}

10.3.2service层

FurnService接口

/**
 * 根据id删除对应的家居信息
 *
 * @param id id
 * @return 返回修改表的行数
 */
public int deleteFurnById(int id);

FurnServiceImpl

@Override
public int deleteFurnById(int id) {
    return furnDAO.deleteFurnById(id);
}

测试类

@Test
public void deleteFurnById() {
    if (furnService.deleteFurnById(24) != 0) {
        System.out.println("删除成功");
    } else {
        System.out.println("删除失败");
    }
}
image-20221219181225540

10.3.3web层

FurnServlet

/**
 * 处理删除家居的请求
 *
 * @param req
 * @param resp
 * @throws ServletException
 * @throws IOException
 */
protected void delete(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    //获取请求删除的家居id
    String id = req.getParameter("id");

    //防止接收的id不是一个数字型的字符串
    furnService.deleteFurnById(DataUtils.parseInt(id, 0));

    //重定向到家居列表页-该地址由浏览器解析
    resp.sendRedirect(req.getContextPath() + "/manage/furnServlet?action=list");

}

10.3.4前端页面校验

furn_manage.jsp添加校验

<%--引入jquery--%>
<script type="text/javascript" src="script/jquery-3.6.0.min.js"></script>
<script type="text/javascript">
    $(function () {
        //获取删除id,绑定事件
        $("a.deleteFurn").click(function () {
            //获取要删除的家居的名字
            var furnName = $(this).parent().parent().find("td:eq(1)").text();
            //confirm弹出的窗口,点击确定返回true,点击取消返回false
            return confirm("确认要删除"+furnName+"吗?");
        })
    })
</script>

10.4完成测试

点击删除

image-20221219184622113

删除成功

image-20221219184635704

11.功能10-后台管理 修改家居

11.1需求分析/图解

image-20221219185628206 image-20221219185715835
  1. 管理员进入到家居管理页面furn_manage.jsp,点击修改按钮,跳转到furn_update.jsp
  2. 在furn_update.jsp先回显该家居信息
  3. 在框中填写新的信息,点击修改家居按钮
  4. 修改成功后,回到展示页面,重新刷新显示家居列表

11.2思路分析

11.3代码实现

11.3.1dao层

FurnDAO接口

/**
 * 通过传入的id,返回furn表中对应的furn对象
 * @param id id
 * @return 返回furn表中对应的furn对象
 */
public Furn queryFurnById(int id);

/**
 * 通过传入的furn对象,修改furn表对应的记录的字段值
 * @param furn 传入的furn对象
 * @return 返回受影响的行数
 */
public int updateFurn(Furn furn);

FurnDAOImpl

@Override
public Furn queryFurnById(int id) {
    String sql = "SELECT `id` , `name` , `maker` , `price` , `sales` , `stock` , `img_path` AS imgPath " +
            "FROM `furn` WHERE id=?";
    return querySingle(sql, Furn.class, id);
}

@Override
public int updateFurn(Furn furn) {
    String sql = "UPDATE `furn` " +
            "SET `name`=?, `maker`=?,`price`=?,`sales`=?,`stock`=?,`img_path`=? " +
            "WHERE `id`=?";
    return update(sql, furn.getName(), furn.getMaker(), furn.getPrice(),
            furn.getSales(), furn.getStock(), furn.getImgPath(), furn.getId());
}

FurnDAOImplTest

@Test
public void queryFurnById() {
    Furn furn = furnDAO.queryFurnById(1);
    System.out.println(furn);
}

@Test
public void updateFurn() {
    Furn furn = new Furn(39,"king","皇家家居",new BigDecimal(999),
            88,99,"assets/images/product-image/default.jpg");
    int i = furnDAO.updateFurn(furn);
    System.out.println("i=" + i);
}

11.3.2service层

FurnService

/**
 * 根据id返回家居信息
 *
 * @param id id
 * @return 返回furn表中对应的furn对象
 */
public Furn queryFurnById(int id);

/**
 * 将传入的furn对象,根据id更新到furn表对应的字段
 *
 * @param furn 传入的furn对象
 * @return 返回受影响的行数
 */
public int updateFurn(Furn furn);

FurnServiceImpl

@Override
public Furn queryFurnById(int id) {
    return furnDAO.queryFurnById(id);
}

@Override
public int updateFurn(Furn furn) {
    return furnDAO.updateFurn(furn);
}

FurnServiceImplTest

@Test
public void queryFurnById() {
    Furn furn = furnService.queryFurnById(1);
    System.out.println(furn);
}

@Test
public void updateFurn() {
    int i = furnService.updateFurn(new Furn(38, "queen", "皇家家居", new BigDecimal(888),
            99, 21, "assets/images/product-image/default.jpg"));
    System.out.println("i=" + i);
}

11.3.3web层

FurnServlet

/**
 * 处理显示单个家居信息的请求
 *
 * @param req
 * @param resp
 * @throws ServletException
 * @throws IOException
 */
protected void showFurn(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    //获取请求显示的家居id
    String id = req.getParameter("id");
    //在数据库中查询,得到furn对象
    Furn furn = furnService.queryFurnById(DataUtils.parseInt(id, 0));
    //将furn放入到request域中
    req.setAttribute("furn", furn);
    //请求转发到furn_update.jsp中,在该页中显示furn信息
    //这里使用请求转发是因为如果使用重定向,当刷新页面之后就没有了request域中的信息
    req.getRequestDispatcher("/views/manage/furn_update.jsp")
            .forward(req, resp);
}

/**
 * 处理修改家居的请求
 *
 * @param req
 * @param resp
 * @throws ServletException
 * @throws IOException
 */
protected void update(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    //自动填充Javabean
    Furn furn = DataUtils.copyParamToBean(req.getParameterMap(), new Furn());
    //调用updateFurn,更改数据
    furnService.updateFurn(furn);
    //修改成功后重定向,显示列表家居
    resp.sendRedirect(req.getContextPath() + "/manage/furnServlet?action=list");
}

相应的前端接口也需要修改,这里忽略

utils包工具类DataUtils:

package com.li.furns.utils;

import org.apache.commons.beanutils.BeanUtils;

import java.util.Map;

/**
 * @author 李
 * @version 1.0
 */
public class DataUtils {
    public static <T> T copyParamToBean(Map value, T bean) {
        try {
            //将req.getParameterMap()的数据自动封装到furn对象中
            //底层使用反射将数据封装,前提是,表单提交的数据字段名称必须和Javabean的属性名一致
            BeanUtils.populate(bean, value);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return bean;
    }

    //将字符串转成数字,否则返回默认值
    public static int parseInt(String str, int defaultVal) {
        try {
            return Integer.parseInt(str);
        } catch (NumberFormatException e) {
            System.out.println(str + " 格式不正确");
        }
        return defaultVal;
    }
}

11.4完成测试

点击修改按钮

image-20221219222230724

跳转到修改页面,显示数据成功

image-20221219222355131

插入新数据,点击修改按钮

image-20221219222513008

页面跳转显示成功

image-20221219222546179

数据库显示修改成功

image-20221219223747807

标签:功能,return,04,int,day05,public,Furn,id,furn
From: https://www.cnblogs.com/liyuelian/p/16993280.html

相关文章

  • [ARC044B] 最短路問題
    [ARC044B]最短路問題难度:\(1744\)标签:最短路,记数\(\mathtt{blog}\)有一个\(n\)个点的无向图,\(1\)点为起点,现在告诉你\(1\simn\)点到\(1\)点的最短距离,每条边......
  • [深度学习] ubuntu18.04配置深度学习环境笔记
    最近装过很多ubuntu18.04系统的nvidia驱动,cuda10.2,cudnn7.6.5,发现每次都会出现一些小问题。总结了具体步骤,做个记录。主要分为三个步骤:驱动安装,cuda安装,cudnn安装。本文主......
  • Ubuntu18.04上手配置入门指南
    ​​写在前面​​​​Linux系统基本介绍​​​​键盘差异&常用快捷键​​​​常用终端命令​​​​系统配置篇​​​​软件安装篇​​​​IDE&Editors​​​​Browser​​​......
  • 040_JMM学习方法
    目录提出问题解决问题百度百科官方文档/博客/视频该如何学习理解查询面试题答案提出问题解决问题百度百科官方文档/博客/视频该如何学习理解查询面试题......
  • asp.net c#开发 微信派发现金红包/H5网页抢红包功能
    临近节日,公司里为了给广大老客户赠福利,以及来一波拉新活动:搞了一个营销活动,大概活动规则如下:1、老客户通过网页抢红包,中奖会派发微信支付的红包;2、新客户只要关注后就可以中......
  • 004 关键字record
    以下这行代码可以写在一个单独的文件Point.java内,也可以写在某个函数内。 1recordPoint(intx,inty){} 它等价于如下代码:1classPoint{2privatefin......
  • 基于I.MX6UL平台的ADS1256驱动开发五.实现功能
    在前面我们已经完成了基本的寄存器读写操作,下面我们就可以根据数据手册来完成基础AD功能的实现。初始化初始化的过程基本上是从AD板供应商提供的Demo移植的。1voidA......
  • 应用笔记 | TSMaster快速入门篇(3)-Trace窗口功能分析图解
    概述Trace窗口是做总线分析时最常用的窗口,主要用于记录总线测量时的各种活动。一、设置显示刷新率为了降低软件CPU占用率,Trace窗口提供了几种显示刷新率让用户选择。如下......
  • 刷题笔记——1043.[编程入门]三个数字的排序
    题目1043.[编程入门]三个数字的排序代码whileTrue: try: li=list(map(int,input().strip().split())) li.sort() foriinli: print(i,end='') except......
  • C# dataGridView常用功能
     1.鼠标选中一行删除此行: foreach(DataGridViewRowrindGView_countList.SelectedRows)       {        if(!r.IsNewRow)   ......