day70_淘淘商城项目_03_商品类目选择 + 图片上传 + 图片服务器FastDFS + 富文本编辑器KindEditor + 新增商品_匠心笔记

本文主要是介绍day70_淘淘商城项目_03_商品类目选择 + 图片上传 + 图片服务器FastDFS + 富文本编辑器KindEditor + 新增商品_匠心笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

淘淘商城项目_03

    • 1、商品类目选择
      • 1.1、功能分析
        • 1.1.1、数据库表结构设计
        • 1.1.2、前端页面分析
      • 1.2、服务层工程开发
        • 1.2.1、Dao层
        • 1.2.2、Service层
        • 1.2.3、发布服务
      • 1.3、表现层功能开发
        • 1.3.1、引用服务
        • 1.3.2、Controller
    • 2、新增商品数据库分析
      • 2.1、商品表分析
      • 2.2、商品描述表分析
    • 3、图片上传分析
    • 4、图片服务器
      • 4.1、什么是FastDFS
      • 4.2、FastDFS架构
      • 4.3、文件上传的流程
      • 4.4、文件下载
      • 4.5、最简单的FastDFS架构
    • 5、图片服务器安装方法
    • 6、图片服务器使用
      • 6.1、FastDFS的Java客户端
      • 6.2、使用DastDFS的Java客户端上传图片
        • 6.2.1、上传步骤
        • 6.2.2、测试代码
      • 6.3、使用工具类上传图片
    • 7、实现图片上传功能
      • 7.1、功能分析
        • 7.1.1、前端页面实现
        • 7.1.2、请求分析
        • 7.1.3、加入文件上传的jar包
        • 7.1.4、配置(多媒体)文件上传解析器
      • 7.2、Controller开发
      • 7.3、解决火狐浏览器兼容性的问题
    • 8、富文本编辑器的使用方法
      • 8.1、富文本编辑器介绍
      • 8.2、使用方法
    • 9、新增商品功能实现
      • 9.1、功能分析
      • 9.2、服务层功能开发
        • 9.2.1、Dao层
        • 9.2.2、Service层
        • 9.2.3、发布服务
      • 9.3、表现层功能开发
        • 9.3.1、引用服务
        • 9.3.2、Controller
      • 9.4、作业

  • 课程计划
    • 第三天:
  • 1、商品类目选择
  • 2、图片上传
    • a) 图片服务器FastDFS
    • b) 图片上传功能实现
  • 3、富文本编辑器的使用KindEditor
  • 4、商品添加功能完成

1、商品类目选择

1.1、功能分析

1.1.1、数据库表结构设计


parent_id 表示节点的父节点。
上表的设计可以展示为树形结构展开类目。

1.1.2、前端页面分析

在taotao-manager-web项目中的jsp下的item-add.jsp中:

我们在该文件中使用 【Ctrl + F】 进行搜索,没有找到事件绑定的样式class(selectItemCat),那我们在Eclipse使用【文件搜索】功能,步骤:Search --> File…,如下:

我们找到了class绑定事件元素处理的js文件common.js,如下:

我们发现:在item-add.jsp中我们并没有引用common.js,但由于在首页index.jsp中我们已经引入了,所以item-add.jsp作为首页index.jsp一个片段,所以在item-add.jsp中我们同样可以使用common.js。
展示商品分类列表,使用EasyUI的tree控件展示。如下:

详解如下:

初始化tree请求的url:/item/cat/list
参数:id  父节点的id值。
初始化tree时只需要把第一级节点展示,子节点异步加载展示。返回值:json格式数据[{    "id": 1,    "text": "Node 1",    "state": "closed"
},{    "id": 2,    "text": "Node 2",    "state": "closed"   
}] 
state:如果节点下有子节点则state的值为"closed",如果节点下没有子节点则state的值为"open"。

所以我们需要创建一个pojo来描述tree的节点信息,包含三个属性id、text、state。
放到taotao-common工程中。由于是服务端响应回来的pojo数据,所以需要实现序列化接口。
EasyUITreeNode.java

package com.taotao.common.pojo;import java.io.Serializable;/*** 类目查询时的返回的数据类* @author	chenmingjun* @date	2018年11月12日下午5:01:23* @version 1.0*/
public class EasyUITreeNode implements Serializable {private static final long serialVersionUID = 1L;private Long id;private String text;private String state;public Long getId() {return id;}public void setId(Long id) {this.id = id;}public String getText() {return text;}public void setText(String text) {this.text = text;}public String getState() {return state;}public void setState(String state) {this.state = state;}@Overridepublic String toString() {return "EasyUITreeNode [id=" + id + ", text=" + text + ", state=" + state + "]";}
}

查询的表:
  tb_item_cat
查询的列:
  id、name、is_parent
查询条件:
  parentId

1.2、服务层工程开发

1.2.1、Dao层

  Dao层只需要查询商品分类表tb_item_cat即可,属于单表查询,单表查询我们没有必要自己写Mapper了,使用Mybatis逆向工程生成的Mapper即可。

1.2.2、Service层

参数:
  Long parentId
业务逻辑:
  1、根据parentId查询节点列表。
  2、转换成EasyUITreeNode列表。
  3、返回。
返回值:
  List<EasyUITreeNode>

先写接口,在taotao-manager-interface工程中:

package com.taotao.service;import java.util.List;import com.taotao.common.pojo.EasyUITreeNode;/*** 商品类目管理接口* @author	chenmingjun* @date	2018年11月12日下午8:15:24* @version 1.0*/
public interface ItemCatService {/*** 根据商品类目的父节点id,查询该节点的子类目列表* @param parentId* @return*/List<EasyUITreeNode> getItemCatList(Long parentId);
}

再写实现类,在taotao-manager-service工程中:

/*** 商品类目管理Service* @author	chenmingjun* @date	2018年11月12日下午8:15:58* @version 1.0*/
@Service
public class ItemCatServiceImpl implements ItemCatService {@Autowiredprivate TbItemCatMapper itemCatMapper;@Overridepublic List<EasyUITreeNode> getItemCatList(Long parentId) {TbItemCatExample example = new TbItemCatExample();// 设置查询条件Criteria criteria = example.createCriteria();criteria.andParentIdEqualTo(parentId);List<TbItemCat> list = itemCatMapper.selectByExample(example);// 将list转换成EasyUITreeNode列表List<EasyUITreeNode> resultList = new ArrayList<>();for (TbItemCat tbItemCat : list) {EasyUITreeNode node = new EasyUITreeNode();node.setId(tbItemCat.getId());node.setText(tbItemCat.getName());// 如果节点下有子节点则state的值为"closed",如果节点下没有子节点则state的值为"open"node.setState(tbItemCat.getIsParent() ? "closed" : "open");// 将节点添加到list集合(列表)resultList.add(node);}return resultList;}
}
1.2.3、发布服务

在taotao-manager-service中的applicationContext-service.xml中发布服务:

1.3、表现层功能开发

1.3.1、引用服务

在taotao-manager-web中的springmvc.xml中引用服务:

这篇关于day70_淘淘商城项目_03_商品类目选择 + 图片上传 + 图片服务器FastDFS + 富文本编辑器KindEditor + 新增商品_匠心笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1100830

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2