栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

品优购(IDEA版)-第一天

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

品优购(IDEA版)-第一天

品优购(IDEA版)-第一天

品优购IDEA版应该是2019年的新项目。目前只有视频。资料其他都还是旧的。

1.学习目标

1:了解电商行业特点以及理解电商的模式
2:了解整体品优购的架构特点
3:能够运用 Dubbo+SSM 搭建分布式应用
4:搭建工程框架,完成品牌列表后端代码

2. 电商概述 3. 品优购需求分析与设计 3.1. 品优购简介

品优购商城主要分为网站前台、网站后台、商家后台三类系统。

3.1.1. 网站前台

主要包括网站首页、商家首页、商品详情、搜索、会员中心、订单与支付相关页面、秒杀频道等。

3.1.2. 网站后台

运营该电商平台的运营人员的管理后台。 主要包括商家审核、品牌管理、规格管理、模板管理、商品分类管理、商品审核、广告类型管理、广告管理、订单查询、商家结算等。

3.1.3. 商家管理后台

加入了该电商平台的商家进行管理的后台,主要功能是对商品的管理以及订单查询统计、资金结算等功能。

3.2. 系统架构 3.2.1. SOA 架构


3.2.2. 品优购架构分析

3.3. 数据库表结构


3.4. 项目框架

品优购采用当前流行的前后端分离架构。后端框架采用 Spring + Spring MVC +
Mybatis +Dubbo。前端采用 angularJS + Bootstrap。

4. 分布式服务框架 Dubbo 4.1. DUBBO 简介

DUBBO 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服 务调用方案,是阿里巴巴
SOA(Service-Oriented Architecture,SOA,面向服务架构) 服务化治理方案的核心框架,每天为
2,000+个服务提供 3,000,000,000+次访问量
支持,并被广泛应用于阿里巴巴集团的各成员站点。官网地址:http://dubbo.io/

4.1.1 DUBBO 架构


节点角色说明:

英文名 节点角色说明
Provider 暴露服务的服务提供方。
Consumer 调用远程服务的服务消费方。
Registry 服务注册与发现的注册中心。
Monitor 统计服务的调用次调和调用时间的监控中心。
Container 服务运行容器。

调用关系说明:

  1. 服务容器负责启动,加载,运行服务提供者。
  2. 服务提供者在启动时,向注册中心注册自己提供的服务。
  3. 服务消费者在启动时,向注册中心订阅自己所需的服务。
  4. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长
    连接推送变更数据给消费者。
  5. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行
    调用,如果调用失败,再选另一台调用。
  6. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一
    次统计数据到监控中心。

【软负载均衡】软件负载均衡则是通过在服务器上安装的特定的负载均衡软件或是自带负载均衡模块完成对请求的分配派发。如:轮询法、随机法、源地址哈希 法、最小连接数法等。在消费方中声明服务的时候可以指定负载均衡的策略, dubbo 在返回的服务地址列表中使用负载均衡策略选择一个服务地址;默认是使 用随机法。

4.2. 注册中心 zookeeper 4.2.1. zookeeper 简介

官方推荐使用 zookeeper 注册中心。注册中心负责服务地址的注册与查找,相当于目录服务,服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求,压力较小。

zookeeper 是 Apacahe Hadoop 的子项目,是一个树型的目录服务,支持变更推送,适合作为 Dubbo 服务的注册中心,工业强度较高,可用于生产环境。

zooKeeper 用来做 dubbo 的注册中心,也即哪一个服务由哪一台机器来提供
必需让调用者知道,简单来说就是 ip 地址和服务名称的对应关系。

4.2.2. 准备 Linux 环境

导入的虚拟机必须设置 ip 为 192.168.25.168 才可以使用 FastDFS(后面的课程会
用);如果虚拟机不是 25 网段,需要手动设置网段,设置方式如下图:

因为除了只有视频是新的,软件资源其实都还是旧的,所以其实是需要使用25网段


4.2.3. VMWare 中打开虚拟机

找到下发的虚拟机文件夹“pinyougou”;导入 VMWare 内,步骤如下:

如果出现弹出框;那么选择 我已移动该虚拟机

4.2.4. 启动虚拟机


上述安装的 CentOS7 64 位系统;
帐号:root,密码:itcast

【注意】如果启动后无法在 windows 中使用工具连接(systemctl start
network.service 命令可以查看状态);那么可以在 centos 中重启网络;输入如下
命令:
systemctl stop NetworkManager
systemctl restart network.service

进入桌面后,右击进入terminal输入ifconfig,查看ip

ifconfig

4.2.5. Linux 中安装 zookeeper

将zookeeper-3.4.6.tar.gz上传到服务器的/root/目录下

解压

tar -zxvf zookeeper-3.4.6.tar.gz

进入zookeeper-3.4.6目录。创建data文件夹

进入conf(配置)文件夹,重命名zoo_sample.cfg为zoo.cfg。修改zoo.cfg文件。


进入bin文件夹,启动zookeeper

4.3. 监控中心 Monitor

在开发时,需要知道注册中心都注册了哪些服务,以便我们开发和测试。可以通过部署一个监控中心来实现。其实监控中心就是一个 web 应用,部署到tomcat 即可。


上传tomcat与dubbo-admin到服务器



5. IDEA 开发环境设置 5.1. 创建 IDEA 工程


或者

6. 品优购-框架搭建 6.1. 工程结构说明

开发完成后的工程结构如下:

模块名 工程说明
pinyougou-parent 聚合父工程
pinyougou-pojo 通用实体类
pinyougou-dao 通用实体类
pinyougou-xxx 业务服务层工程
pinyougou-xxx-interface 业务服务层接口
pinyougou-xxx-service 业务服务层实现(web 工程)
pinyougou-xxx-web 展现(控制)层工程(web 工程)
6.2. 创建数据库表

在导入的虚拟机里面已经有使用 mysql 5.7 的数据库名称为:pinyougoudb,
mysql5.7 的用户名和密码都为:root。
另外;也可以自行创建数据库,将“资料/database/pinyougoudb.sql”导入。

6.3. 创建工程&添加依赖 6.3.1. pinyougou

品优购聚合父工程;包括后续开发的所有品优购聚合子工程。主要功能是进行依赖、插件统一管理。

6.3.1.1. 创建


6.3.1.2. 依赖

后续的文中出现依赖表示修改当前项目的 pom.xml 文件



    4.0.0

    com.pinyougou
    pinyougou
    pom
    1.0-SNAPSHOT

    
    
 4.12
 4.3.10.RELEASE
 4.2.3.RELEASE
 3.4.5
 1.3.1
 5.1.32
 1.1.5
 5.1.2
 3.5.0
 2.6.0
 1.7.12
 1.0
 1.2.44
 3.4.9
 0.1
 2.9.0
 1.8.9.RELEASE
 2.5
 1.3.1
 1.25
 2.3.23
 5.14.3
 3.4.1
 1.5.5.RELEASE
 4.5.3
 0.0.3
 4.4.8
 3.12.1.GA
 1.11
 1.6.1
 2.0.2
 2.3.2
    

    
 
     
  junit
  junit
  ${junit.version}
     

     
     
  org.springframework
  spring-beans
  ${spring.version}
     
     
  org.springframework
  spring-context
  ${spring.version}
     
     
  org.springframework
  spring-web
  ${spring.version}
     
     
  org.springframework
  spring-aspects
  ${spring.version}
     
     
  org.springframework
  spring-jdbc
  ${spring.version}
     
     
  org.springframework
  spring-webmvc
  ${spring.version}
     
     
  org.springframework
  spring-jms
  ${spring.version}
     
     
  org.springframework
  spring-context-support
  ${spring.version}
     
     
  org.springframework
  spring-test
  ${spring.version}
     

     
     
  org.mybatis
  mybatis
  ${mybatis.version}
     
     
  org.mybatis
  mybatis-spring
  ${mybatis.spring.version}
     

     
     
  org.slf4j
  slf4j-log4j12
  ${slf4j.version}
     

     
     
  com.alibaba
  dubbo
  ${dubbo.version}
     
     
  org.apache.zookeeper
  zookeeper
  ${zookeeper.version}
     
     
  com.github.sgroschupf
  zkclient
  ${zkclient.version}
     

     
     
  com.alibaba
  fastjson
  ${fastjson.version}
     

     
  javax.servlet
  servlet-api
  ${servlet.api.version}
  provided
     

     
     
  com.github.pagehelper
  pagehelper
  ${pagehelper.version}
     

     
     
  tk.mybatis
  mapper
  ${mapper.version}
     

     
     
  mysql
  mysql-connector-java
  ${mysql.version}
     
     
     
  com.alibaba
  druid
  ${druid.version}
     

     
     
  javax.persistence
  persistence-api
  ${javax.persistence.version}
     

     
     
  redis.clients
  jedis
  ${jedis.version}
     
     
  org.springframework.data
  spring-data-redis
  ${spring.data.redis.version}
     

     
     
  commons-fileupload
  commons-fileupload
  ${commons.fileupload.version}
     

     
     
  fastdfs_client
  fastdfs_client
  ${fastdfs.client.version}
     

     
     
  org.freemarker
  freemarker
  ${freemarker.version}
     

     
     
  org.apache.activemq
  activemq-client
  ${activemq.version}
     
     
     
  org.springframework.security
  spring-security-web
  ${spring.security.version}
     
     
  org.springframework.security
  spring-security-config
  ${spring.security.version}
     

     
     
  org.springframework.security
  spring-security-cas
  ${spring.security.version}
     
     
  org.jasig.cas.client
  cas-client-core
  ${cas.client.core.version}
  
  
      
   org.slf4j
   log4j-over-slf4j
      
  
     

     
     
  org.springframework.data
  spring-data-solr
  ${spring.data.solr.version}
     

     
  org.apache.httpcomponents
  httpclient
  ${httpclient.version}
     

     
     
  com.github.wxpay
  wxpay-sdk
  ${wxpay.sdk.version}
     

     
     
  com.github.penggle
  kaptcha
  ${kaptcha.version}
  
      
   javax.servlet
   javax.servlet-api
      
  
     

     
     
  commons-codec
  commons-codec
  ${commons.codec.version}
     

     
  javassist
  javassist
  ${javassist.version}
     

     
  dom4j
  dom4j
  ${dom4j.version}
     

     
  xml-apis
  xml-apis
  ${xml.apis.version}
     
 
    

    
 
     
     
  org.apache.maven.plugins
  maven-compiler-plugin
  3.6.0
  
      1.8
      1.8
      UTF-8
  
     
 

 
     
  
  
      org.apache.tomcat.maven
      tomcat7-maven-plugin
      2.2
  
     
 
    

6.3.2. pinyougou-common

通用工具类工程;放置其它工程经常使用的工具类或者组件。

6.3.2.1. 创建

6.3.2.2. 依赖


    
 pinyougou
 com.pinyougou
 1.0-SNAPSHOT
    
    4.0.0

    pinyougou-common



6.3.3. pinyougou-pojo

实体类工程;统一放置品优购的所有数据库实体类或者其它领域模型。

6.3.3.1. 创建

创建 pinyougou 的子模块工程,与 pinyougou-common 的创建方式类似;后面的若是pinyougou 的子模块工程的创建也都如此;不再每一步都截图了。

6.3.3.2. 依赖


    
 pinyougou
 com.pinyougou
 1.0-SNAPSHOT
    
    4.0.0

    pinyougou-pojo

    
 
 
     javax.persistence
     persistence-api
 

 
     org.springframework.data
     spring-data-solr
 
    

6.3.4. pinyougou-dao

数据库通用访问层工程;放置 Mybatis 中对应于数据库操作的所有 Mapper 接口类。

6.3.4.1. 创建

6.3.4.2. 依赖


    
 pinyougou
 com.pinyougou
 1.0-SNAPSHOT
    
    4.0.0

    pinyougou-dao

    
 
     com.pinyougou
     pinyougou-pojo
     1.0-SNAPSHOT
 

 
     org.springframework
     spring-beans
 

 
     org.springframework
     spring-jdbc
 

 
 
     org.mybatis
     mybatis
 
 
     org.mybatis
     mybatis-spring
 

 
 
     com.github.pagehelper
     pagehelper
 

 
 
     tk.mybatis
     mapper
 

 
 
     mysql
     mysql-connector-java
 
 
 
     com.alibaba
     druid
 

 
 
     org.slf4j
     slf4j-log4j12
 
    


6.3.5. pinyougou-sellergoods

商家商品服务工程;该工程主要是对应于商品、商家、品牌、规格、商品分类等
的服务提供,由 pinyougou-sellergoods-interface 和 pinyougou-sellergoods-service构成。

6.3.5.1. 创建


6.3.5.2. 依赖

无需改动。

6.3.6. pinyougou-sellergoods-interface 6.3.6.1. 创建

注意这个工程是 pinyougou-sellergoods 的聚合子工程。

6.3.6.2. 依赖


    
 pinyougou-sellergoods
 com.pinyougou
 1.0-SNAPSHOT
    
    4.0.0

    pinyougou-sellergoods-interface

    
 
     com.pinyougou
     pinyougou-pojo
     1.0-SNAPSHOT
 
    

6.3.7. pinyougou-sellergoods-service 6.3.7.1. 创建

注意这个工程是 pinyougou-sellergoods 的聚合子工程。 安装插件JBLJavaToWeb

6.3.7.3. 依赖


    
 pinyougou-sellergoods
 com.pinyougou
 1.0-SNAPSHOT
    
    4.0.0
    pinyougou-sellergoods-service
    war

    

 
     com.pinyougou
     pinyougou-sellergoods-interface
     1.0-SNAPSHOT
 

 
     com.pinyougou
     pinyougou-dao
     1.0-SNAPSHOT
 

 
     org.springframework
     spring-beans
 
 
     org.springframework
     spring-context
 
 
     org.springframework
     spring-web
 
 
     org.springframework
     spring-aspects
 

 
 
     com.alibaba
     dubbo
 
 
     org.apache.zookeeper
     zookeeper
 
 
     com.github.sgroschupf
     zkclient
 

 
     com.alibaba
     fastjson
 
 
     com.pinyougou
     pinyougou-common
     1.0-SNAPSHOT
 
    

    
 
     
     
  org.apache.tomcat.maven
  tomcat7-maven-plugin
  
      /
      9000
  
     
 
    


6.3.8. pinyougou-manage-web 6.3.8.1. 创建


6.3.8.2. 转换为 web 工程

6.3.8.3. 依赖


    
 pinyougou
 com.pinyougou
 1.0-SNAPSHOT
    
    4.0.0
    pinyougou-manage-web
    war
    
 
     com.pinyougou
     pinyougou-sellergoods-interface
     1.0-SNAPSHOT
 

 
     org.springframework
     spring-webmvc
 

 
     org.slf4j
     slf4j-log4j12
 

 
 
     com.alibaba
     dubbo
 
 
     org.apache.zookeeper
     zookeeper
 
 
     com.github.sgroschupf
     zkclient
 

 
 
     com.alibaba
     fastjson
 

 
     javax.servlet
     servlet-api
     provided
 

    
    
 
     
     
  org.apache.tomcat.maven
  tomcat7-maven-plugin
  
      /
      9100
  
     
 
    


6.4. 整合工程 6.4.1. pinyougou-dao 6.4.1.1. applicationContext-dao.xml

添加
pinyougoupinyougou-daosrcmainresourcesspringapplicationContext-dao.xml
内容如下:




    
    package com.pinyougou.manage.controller;

import java.util.List;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.alibaba.dubbo.config.annotation.Reference;
import com.pinyougou.pojo.TbBrand;
import com.pinyougou.sellergoods.service.BrandService;

@RestController
@RequestMapping("/brand")
public class BrandController {

	@Reference
	private BrandService brandService;
	
	@RequestMapping("/findAll")
	public List findAll(){
		return brandService.queryAll();
	}
	
}
7.4. 安装工程

点击 IDEA 最右边的“Maven Projects”

7.5. 启动 7.5.1. 启动 pinyougou-sellergoods-service

7.5.2. 启动 pinyougou-manage-web

这个启动与 pinyougou-sellergoods-service 的启动配置是一样的;不在赘述图。

7.6. 测试
打开 chrome 浏览器;输入:http://localhost:9100/brand/findAll.do

8. Git 管理代码 9. 常见问题 9.2. Mybatis 中查询语句找不到

org.springframework.web.util.NestedServletException: Request processing failed;
nested exception is java.lang.RuntimeException:
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):
com.pinyougou.mapper.BrandMapper.queryAll
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):
com.pinyougou.mapper.BrandMapper.queryAll

在 IDEA 中检查 resources 文件夹中 com.pinyougou.mapper 是不是已经变成了
一个目录;真正的是三级目录,只是在 IDEA 上看不太出区别。请创建的时候
创建 package 方 式 创 建 则 不 会 出 现 了 ; 不 管 如 何 请 保 证
resources/com/pinyougou/mapper 目录的存在

以上为第一天内容,视频参考Java 品优购互联网商城 项目实战(基于IDEA)新版。因为第一天是没有视频的,是基于这份pdf讲义实现的。然而这份pdf讲义也有很多错误,有的是因为资源是旧的,不兼容,还有的是直接是里面代码的错误导致的bug。以上我博客的内容基本是花了时间排除了错误后的实现。所以有些地方会与讲义不同。

第一天内容我写了思维导图,打开有点慢。
博客内容中,如果我有哪些没有讲清楚或者实现中遇到了哪些问题,请在评论中留言,我看到会尽快回复的,或者其他小伙伴看到也会帮忙解决的。
第一天需要使用的资料hirr,或者不失效的

转载请注明:文章转载自 www.mshxw.com
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号