品優購(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 | 服務運行容器。 |
調用關系說明:
- 服務容器負責啟動,加載,運行服務提供者。
- 服務提供者在啟動時,向注冊中心注冊自己提供的服務。
- 服務消費者在啟動時,向注冊中心訂閱自己所需的服務。
- 注冊中心返回服務提供者地址列表給消費者,如果有變更,注冊中心將基於長
連接推送變更數據給消費者。 - 服務消費者,從提供者地址列表中,基於軟負載均衡算法,選一台提供者進行
調用,如果調用失敗,再選另一台調用。 - 服務消費者和提供者,在內存中累計調用次數和調用時間,定時每分鍾發送一
次統計數據到監控中心。
【軟負載均衡】軟件負載均衡則是通過在服務器上安裝的特定的負載均衡軟件或是自帶負載均衡模塊完成對請求的分配派發。如:輪詢法、隨機法、源地址哈希 法、最小連接數法等。在消費方中聲明服務的時候可以指定負載均衡的策略, 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 文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://maven.apache.org/POM/4.0.0"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.pinyougou</groupId>
<artifactId>pinyougou</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<!-- 集中定義依賴版本號 -->
<properties>
<junit.version>4.12</junit.version>
<spring.version>4.3.10.RELEASE</spring.version>
<spring.security.version>4.2.3.RELEASE</spring.security.version>
<mybatis.version>3.4.5</mybatis.version>
<mybatis.spring.version>1.3.1</mybatis.spring.version>
<mysql.version>5.1.32</mysql.version>
<druid.version>1.1.5</druid.version>
<pagehelper.version>5.1.2</pagehelper.version>
<mapper.version>3.5.0</mapper.version>
<dubbo.version>2.6.0</dubbo.version>
<slf4j.version>1.7.12</slf4j.version>
<javax.persistence.version>1.0</javax.persistence.version>
<fastjson.version>1.2.44</fastjson.version>
<zookeeper.version>3.4.9</zookeeper.version>
<zkclient.version>0.1</zkclient.version>
<jedis.version>2.9.0</jedis.version>
<spring.data.redis.version>1.8.9.RELEASE</spring.data.redis.version>
<servlet.api.version>2.5</servlet.api.version>
<commons.fileupload.version>1.3.1</commons.fileupload.version>
<fastdfs.client.version>1.25</fastdfs.client.version>
<freemarker.version>2.3.23</freemarker.version>
<activemq.version>5.14.3</activemq.version>
<cas.client.core.version>3.4.1</cas.client.core.version>
<spring.data.solr.version>1.5.5.RELEASE</spring.data.solr.version>
<httpclient.version>4.5.3</httpclient.version>
<wxpay.sdk.version>0.0.3</wxpay.sdk.version>
<httpcore.version>4.4.8</httpcore.version>
<javassist.version>3.12.1.GA</javassist.version>
<commons.codec.version>1.11</commons.codec.version>
<dom4j.version>1.6.1</dom4j.version>
<xml.apis.version>2.0.2</xml.apis.version>
<kaptcha.version>2.3.2</kaptcha.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit.version}</version>
</dependency>
<!-- Spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jms</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- Mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>${mybatis.version}</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>${mybatis.spring.version}</version>
</dependency>
<!-- 日志 -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>${slf4j.version}</version>
</dependency>
<!-- dubbo相關 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>${dubbo.version}</version>
</dependency>
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>${zookeeper.version}</version>
</dependency>
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>${zkclient.version}</version>
</dependency>
<!-- json的解析 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>${fastjson.version}</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>${servlet.api.version}</version>
<scope>provided</scope>
</dependency>
<!-- mybaits分頁助手 -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>${pagehelper.version}</version>
</dependency>
<!-- 通用 Mapper -->
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper</artifactId>
<version>${mapper.version}</version>
</dependency>
<!-- MySql -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<!-- 連接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>${druid.version}</version>
</dependency>
<!-- jpa 注解 -->
<dependency>
<groupId>javax.persistence</groupId>
<artifactId>persistence-api</artifactId>
<version>${javax.persistence.version}</version>
</dependency>
<!-- redis緩存 -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>${jedis.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-redis</artifactId>
<version>${spring.data.redis.version}</version>
</dependency>
<!-- 文件上傳組件 -->
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>${commons.fileupload.version}</version>
</dependency>
<!--fastDFS客戶端工具類包 -->
<dependency>
<groupId>fastdfs_client</groupId>
<artifactId>fastdfs_client</artifactId>
<version>${fastdfs.client.version}</version>
</dependency>
<!--freemarker-->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>${freemarker.version}</version>
</dependency>
<!-- ActiveMQ -->
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-client</artifactId>
<version>${activemq.version}</version>
</dependency>
<!-- 身份驗證 -->
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-web</artifactId>
<version>${spring.security.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-config</artifactId>
<version>${spring.security.version}</version>
</dependency>
<!-- cas -->
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-cas</artifactId>
<version>${spring.security.version}</version>
</dependency>
<dependency>
<groupId>org.jasig.cas.client</groupId>
<artifactId>cas-client-core</artifactId>
<version>${cas.client.core.version}</version>
<!-- 排除 log4j包沖突 -->
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>log4j-over-slf4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- solr相關 -->
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-solr</artifactId>
<version>${spring.data.solr.version}</version>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>${httpclient.version}</version>
</dependency>
<!-- 微信支付 sdk -->
<dependency>
<groupId>com.github.wxpay</groupId>
<artifactId>wxpay-sdk</artifactId>
<version>${wxpay.sdk.version}</version>
</dependency>
<!-- 驗證碼工具類包 -->
<dependency>
<groupId>com.github.penggle</groupId>
<artifactId>kaptcha</artifactId>
<version>${kaptcha.version}</version>
<exclusions>
<exclusion>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- 加密解密 -->
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
<version>${commons.codec.version}</version>
</dependency>
<dependency>
<groupId>javassist</groupId>
<artifactId>javassist</artifactId>
<version>${javassist.version}</version>
</dependency>
<dependency>
<groupId>dom4j</groupId>
<artifactId>dom4j</artifactId>
<version>${dom4j.version}</version>
</dependency>
<dependency>
<groupId>xml-apis</groupId>
<artifactId>xml-apis</artifactId>
<version>${xml.apis.version}</version>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<!-- java編譯插件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.6.0</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
</plugins>
<pluginManagement>
<plugins>
<!-- tomcat插件 -->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>
6.3.2. pinyougou-common
通用工具類工程;放置其它工程經常使用的工具類或者組件。
6.3.2.1. 創建 
6.3.2.2. 依賴
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>pinyougou</artifactId>
<groupId>com.pinyougou</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>pinyougou-common</artifactId>
</project>
6.3.3. pinyougou-pojo
實體類工程;統一放置品優購的所有數據庫實體類或者其它領域模型。
6.3.3.1. 創建
創建 pinyougou 的子模塊工程,與 pinyougou-common 的創建方式類似;后面的若是pinyougou 的子模塊工程的創建也都如此;不再每一步都截圖了。
6.3.3.2. 依賴
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>pinyougou</artifactId>
<groupId>com.pinyougou</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>pinyougou-pojo</artifactId>
<dependencies>
<!-- jpa 注解 -->
<dependency>
<groupId>javax.persistence</groupId>
<artifactId>persistence-api</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-solr</artifactId>
</dependency>
</dependencies>
</project>
6.3.4. pinyougou-dao
數據庫通用訪問層工程;放置 Mybatis 中對應於數據庫操作的所有 Mapper 接口類。
6.3.4.1. 創建
6.3.4.2. 依賴
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://maven.apache.org/POM/4.0.0"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>pinyougou</artifactId>
<groupId>com.pinyougou</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>pinyougou-dao</artifactId>
<dependencies>
<dependency>
<groupId>com.pinyougou</groupId>
<artifactId>pinyougou-pojo</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
</dependency>
<!-- Mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
</dependency>
<!-- mybaits分頁助手 -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
</dependency>
<!-- 通用 Mapper -->
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper</artifactId>
</dependency>
<!-- MySql -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!-- 連接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
</dependency>
<!-- 日志 -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</dependency>
</dependencies>
</project>
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. 依賴
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://maven.apache.org/POM/4.0.0"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>pinyougou-sellergoods</artifactId>
<groupId>com.pinyougou</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>pinyougou-sellergoods-interface</artifactId>
<dependencies>
<dependency>
<groupId>com.pinyougou</groupId>
<artifactId>pinyougou-pojo</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
</project>
6.3.7. pinyougou-sellergoods-service
6.3.7.1. 創建
注意這個工程是 pinyougou-sellergoods 的聚合子工程。
安裝插件JBLJavaToWeb
6.3.7.3. 依賴
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://maven.apache.org/POM/4.0.0"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>pinyougou-sellergoods</artifactId>
<groupId>com.pinyougou</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>pinyougou-sellergoods-service</artifactId>
<packaging>war</packaging>
<dependencies>
<dependency>
<groupId>com.pinyougou</groupId>
<artifactId>pinyougou-sellergoods-interface</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>com.pinyougou</groupId>
<artifactId>pinyougou-dao</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
</dependency>
<!-- dubbo相關 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
</dependency>
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
</dependency>
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
</dependency>
<dependency>
<groupId>com.pinyougou</groupId>
<artifactId>pinyougou-common</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
<build>
<plugins>
<!-- tomcat插件 -->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<configuration>
<path>/</path>
<port>9000</port>
</configuration>
</plugin>
</plugins>
</build>
</project>
6.3.8. pinyougou-manage-web
6.3.8.1. 創建
6.3.8.2. 轉換為 web 工程
6.3.8.3. 依賴
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://maven.apache.org/POM/4.0.0"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>pinyougou</artifactId>
<groupId>com.pinyougou</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>pinyougou-manage-web</artifactId>
<packaging>war</packaging>
<dependencies>
<dependency>
<groupId>com.pinyougou</groupId>
<artifactId>pinyougou-sellergoods-interface</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</dependency>
<!-- dubbo相關 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
</dependency>
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
</dependency>
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
</dependency>
<!-- json的解析 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<scope>provided</scope>
</dependency>
</dependencies>
<build>
<plugins>
<!-- tomcat插件 -->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<configuration>
<path>/</path>
<port>9100</port>
</configuration>
</plugin>
</plugins>
</build>
</project>
6.4. 整合工程
6.4.1. pinyougou-dao
6.4.1.1. applicationContext-dao.xml
添加
pinyougou\pinyougou-dao\src\main\resources\spring\applicationContext-dao.xml
內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns="http://www.springframework.org/schema/beans"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 加載配置文件 -->
<context:property-placeholder location="classpath*:properties/*.properties"/>
<!-- 數據庫連接池 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
destroy-method="close">
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="maxActive" value="10"/>
<property name="minIdle" value="5"/>
</bean>
<!-- 配置 sqlSessionFactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 數據源 -->
<property name="dataSource" ref="dataSource"/>
<!-- mybatis總配置文件 -->
<property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>
<!-- 配置實體類別名 -->
<property name="typeAliasesPackage" value="com.pinyougou.pojo"/>
<!--配置掃描xml文件-->
<property name="mapperLocations" value="classpath:com/pinyougou/mapper/*.xml"/>
</bean>
<!-- 掃描 mapper -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.pinyougou.mapper"/>
</bean>
</beans>
6.4.1.2. mybatis-config.xml
添加
pinyougou\pinyougou-dao\src\main\resources\mybatis\mybatis-config.xml
內容如下:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<settings>
<!-- 開啟駝峰規則自動映射字段屬性值;如字段為 user_name的可以映射到 userName屬性中 -->
<setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>
</configuration>
6.4.1.3. db.properties
添加
pinyougou\pinyougou-dao\src\main\resources\properties\db.properties
內容如下:
jdbc.driver=com.mysql.jdbc.Driver
#下面的按照自己實際的填寫。如果連接服務器的mysql,就填寫你服務器的ip。如果連接的是本地的mysql,就填寫localhost
jdbc.url=jdbc:mysql://192.168.25.128:3306/pinyougoudb?useUnicode=true&characterEncoding=utf8&autoReconnect=true
jdbc.username=root
jdbc.password=root
6.4.1.4. log4j.properties
添加
pinyougou\pinyougou-dao\src\main\resources\log4j.properties
內容如下:
log4j.rootLogger=DEBUG,stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS} [%t] [%c]-[%p] %m%n
6.4.2. pinyougou-sellergoods-service
6.4.2.1. applicationContext-service.xml
添加
pinyougou-sellergoods-service\src\main\resources\spring\applicationContext
service.xml
內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
xmlns="http://www.springframework.org/schema/beans"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://code.alibabatech.com/schema/dubbo
http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<dubbo:protocol name="dubbo" port="20881"/>
<dubbo:application name="pinyougou-sellergoods-service"/>
<!--根據服務器實際ip填寫-->
<dubbo:registry address="zookeeper://192.168.25.128:2181"/>
<dubbo:annotation package="com.pinyougou.sellergoods.service.impl"/>
</beans>
6.4.2.2. web.xml
修改pinyougou-sellergoods-service\src\main\webapp\WEB-INF\web.xml內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5">
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:spring/applicationContext*.xml</param-value>
</context-param>
</web-app>
6.4.3. pinyougou-manage-web
6.4.3.1. springmvc.xml
添加
pinyougou\pinyougou-manage-web\src\main\resources\spring\springmvc.xml
內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns="http://www.springframework.org/schema/beans"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://code.alibabatech.com/schema/dubbo
http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<mvc:annotation-driven>
<mvc:message-converters register-defaults="true">
<bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter">
<property name="supportedMediaTypes" value="application/json"/>
</bean>
</mvc:message-converters>
</mvc:annotation-driven>
<!-- 引用 dubbo 服務 -->
<dubbo:application name="pinyougou-manage-web"/>
<!-- 根據實際ip填寫 -->
<dubbo:registry address="zookeeper://192.168.25.128:2181"/>
<dubbo:annotation package="com.pinyougou.manage.controller"/>
</beans>
6.4.3.2. log4j.properties
添加
pinyougou\pinyougou-manage-web\src\main\resources\log4j.properties
內容如下:
log4j.rootLogger=DEBUG,stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS} [%t] [%c]-[%p] %m%n
6.4.3.3. web.xml
修改
pinyougou\pinyougou-manage-web\src\main\webapp\WEB-INF\web.xml
內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5">
<!-- 解決 post亂碼 -->
<filter>
<filter-name>CharacterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter
</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>utf-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 指定加載的配置文件 ,通過參數 contextConfigLocation加載 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/springmvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
</web-app>
6.4.4. 引入品優購實體類
在 pinyougou-pojo 工程創建 com.pinyougou.pojo 包;然后將“資料/pojo”下的所有
實體類復制到上述創建的包中。
7. 查詢品牌列表數據
7.1. 需求分析
在瀏覽器上訪問:http://localhost:9100/brand/findAll.do 把品牌數據(json 格式字
符串)加載並顯示。
7.2. 數據庫表
7.3. 后端代碼
7.3.1. BrandMapper 接口
添加
pinyougou-dao\src\main\java\com\pinyougou\mapper\BrandMapper.java
內容如下:
package com.pinyougou.mapper;
import com.pinyougou.pojo.TbBrand;
import java.util.List;
public interface BrandMapper {
List<TbBrand> queryAll();
}
7.3.2. BrandMapper.xml 配置文件
添加
pinyougou-dao\src\main\resources\com\pinyougou\mapper\BrandMapper.xml
內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.pinyougou.mapper.BrandMapper">
<select id="queryAll" resultType="com.pinyougou.pojo.TbBrand">
SELECT *
FROM tb_brand
</select>
</mapper>
7.3.3. BrandService 接口
添加
pinyougou-sellergoods\pinyougou-sellergoods
interface\src\main\java\com\pinyougou\sellergoods\service\BrandService.java
內容如下:
package com.pinyougou.sellergoods.service;
import com.pinyougou.pojo.TbBrand;
import java.util.List;
public interface BrandService {
public List<TbBrand> queryAll();
}
7.3.4. BrandServiceImpl 實現類
添加
pinyougou-sellergoods\pinyougou-sellergoods
service\src\main\java\com\pinyougou\sellergoods\service\impl\BrandServiceImpl.ja
va
內容如下:
package com.pinyougou.sellergoods.service.impl;
import java.util.List;
import com.pinyougou.mapper.BrandMapper;
import com.pinyougou.sellergoods.service.BrandService;
import org.springframework.beans.factory.annotation.Autowired;
import com.alibaba.dubbo.config.annotation.Service;
import com.pinyougou.pojo.TbBrand;
/**
* 注意:該Service注解是alibaba的,不是spring的
*/
@Service(interfaceClass = BrandService.class)
public class BrandServiceImpl implements BrandService {
@Autowired
private BrandMapper brandMapper;
@Override
public List<TbBrand> queryAll() {
return brandMapper.queryAll();
}
}
7.3.5. BrandController 處理器
添加
pinyougou-manage
web\src\main\java\com\pinyougou\manage\controller\BrandController.java
內容如下:
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<TbBrand> 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,或者不失效的