一转眼就已经大三了,作为非CS专业的一个某理工学院普通大学生,应该对自己的未来做规划了。于是,大三开始我就开始着手准备一个“大项目”。将前两年学习的知识做一个总结,归纳,恰巧,当时快到双11了。于是就有了这个项目。项目的名字叫OscsMall,为什么叫这个名字我也不知道。当时想着是 Open Source Soda Cream Mall
。至于Almost是因为整个项目缺少了支付部分的代码,原因是需要企业资格,而且八阿哥很多,所以借用了锤子手机的Almost概念。整个项目分为后端和客户端,后端代码显得稚嫩,客户端代码也算拿的的出手。还恳请个位大佬轻喷。项目自然参考了其他大神的代码。这个项目我也会一直维护下去的,恳请大佬们star一下。也希望个位大大能够开发前端与IOS端,和我一起将这个项目做好。
后台
后台其实没什么好介绍的,整个项目使用Spring+MyBatis+MySQL,项目采用MVC模式。包含前台和后台管理部分代码。是一个很普通的电商项目,包含了8大结构,6大模块。
API
项目结构
common
作用:用来处理公共的信息,包括Token,常量,全局异常,公共类等封装
controller
作用:包括前台和后台部分的controller
代码
service
作用:项目中要到的service
部分
dao
作用:负责dao
层
pojo
作用:数据库对象
vo
作用:view object
前端对象
util
作用:一些简单的工具类
项目模块(详情见文档)
用户信息
包括:用户登录,注册,信息获取,注销等流程,管理登录
商品信息
商品增加删除更新,同时放置非管理员对商品的属性进行操作
商品分类信息
商品分类信息,包括子分类的信息获取
购物车
购物车添加,删除,选择,更新等管理
订单
订单生成,不同类型的订单查询等管理
地址
地址增加,删除,选择等功能
具体的内容在wiki里
客户端
先上动图吧
-
首页(真机测试非常流畅,gif是用ffmpeg处理过的,所以十分卡顿)
-
分类
-
寻觅(混合开发,图中展示了js与java互相调用的场景)
-
购物车(购物车每次点击都以为着网络请求,所以这里的请求是相对比较密集的)
-
个人中心(我的,其中空白的是由于我直接更改数据库造成的)
当然还有物品搜索,二维码,启动页,引导页等页面我就不展示了。
客户端的整体架构
整体采用了单Activity多fragment的设计思路
网络模块(两种)
- 使用rxJava与retrofit2和okhttp3组成网络请求框架(有些时候Rxjava并不能按照预期给出结果,让我有点苦恼。水平不够,嘤嘤嘤)
- 未使用rxJava的网络框架,整个请求写法上类似于Velloy
App配置相关
- 整个App的图标全部使用icon
- 使用Builder设计模式来配置整个应用信息(使用什么icon,内置了iconify中给出的所有Icon)
代理Activity
作为整个程序唯一一个Activity,作为所有Fragment的代理
MVP相关
作为MVP模式的基类
UI相关
UI处理部分
App的整体流程
App的整体流程分为三部分
第一部分
流程:首页展示前,整个Activity作为Fragment的调度站,负责Fragment的跳转和信息传递。这样的好处是,避免跳转流程复杂,导致自己开发时候很晕。一般Fragment的跳转需要App的当前状态,用户的当前状态,通过这两状态去决定下一个Fragment是什么。
同时整个Activity代理了所有的toast信息的展示,和Loading加载。这样整个流程更加清晰。
第二部分
首页展示后,整个Bottom Fragment
作为调度站,负责在各个页面之间进行跳转。
第三部分
不同页面需要其他额外的Fragment
,由该Fragment
自己掌控。
目的:
App整体流程是我自己的一些小技巧的总结,让同级的Fragment
之间的调用更加清楚,这样设计,如果App加入新的类型的启动页,我们就不用更改相关所有Fragment
的代码,而只需要更改Activity
的代码就可以了。
总结
整个App被分成4层,第一层是
Activity
,把握了第二层的Fragment
的调用顺序,第二层Fragment
把握了第三层的调用,以此类推。如果我们发现某一层的调用出现问题,那么可以找到它的上一层进行修改。
使用到的依赖
//iconify icon图标库
compile 'com.joanzapata.iconify:android-iconify:2.2.2'
compile 'com.joanzapata.iconify:android-iconify-fontawesome:2.2.2'
// (v4.5)
compile 'com.joanzapata.iconify:android-iconify-entypo:2.2.2'
// (v3,2015)
compile 'com.joanzapata.iconify:android-iconify-typicons:2.2.2'
// (v2.0.7)
compile 'com.joanzapata.iconify:android-iconify-material:2.2.2'
// (v2.0.0)
compile 'com.joanzapata.iconify:android-iconify-material-community:2.2.2'
// (v1.4.57)
compile 'com.joanzapata.iconify:android-iconify-meteocons:2.2.2'
// (latest)
compile 'com.joanzapata.iconify:android-iconify-weathericons:2.2.2'
// (v2.0)
compile 'com.joanzapata.iconify:android-iconify-simplelineicons:2.2.2'
// (v1.0.0)
compile 'com.joanzapata.iconify:android-iconify-ionicons:2.2.2'
// (v2.0.1)
//AndroidUtilCode安卓工具类
compile 'com.blankj:utilcode:1.9.8'
//logger
compile 'com.orhanobut:logger:2.1.1'
//网络请求依赖
compile 'com.squareup.okio:okio:1.13.0'
compile 'com.squareup.okhttp3:okhttp:3.8.1'
compile 'com.squareup.retrofit2:retrofit:2.3.0'
compile 'com.squareup.retrofit2:converter-scalars:2.3.0'
//rx全家桶
compile 'io.reactivex.rxjava2:rxjava:2.1.6'
compile 'io.reactivex.rxjava2:rxandroid:2.0.1'
compile 'com.squareup.retrofit2:adapter-rxjava2:2.3.0'
//JSON依赖Android版
compile 'com.alibaba:fastjson:1.1.57.android'
//AVLoadIndicatorView 加载
compile 'com.wang.avi:library:2.1.3'
// fragmentation Fragment
compile 'me.yokeyword:fragmentation:1.1.8'
compile 'me.yokeyword:fragmentation-swipeback:1.1.8'
//ButterKnife依赖
compile 'com.jakewharton:butterknife:8.6.0'
annotationProcessor 'com.jakewharton:butterknife-compiler:8.6.0'
//Banner依赖
compile 'com.bigkoo:convenientbanner:2.0.5'
compile 'com.ToxicBakery.viewpager.transforms:view-pager-transforms:1.2.32@aar'
//RecyclerView依赖
compile 'com.github.CymChad:BaseRecyclerViewAdapterHelper:2.9.32'
//RecyclerView分割线
compile 'com.choices.divider:RecyclerView_Divider:1.0.0'
//StatusBarCompat
dependencies {
compile('com.github.niorgai:StatusBarCompat:2.1.4', {
exclude group: 'com.android.support'
})
}
//Google AutoValue provided代表只在编译期间,产生作用,最后在源码中是不存在的
provided 'com.google.auto.value:auto-value:1.4.1'
annotationProcessor "com.google.auto.value:auto-value:1.4.1"
//图片加载
compile 'com.github.bumptech.glide:glide:4.0.0-RC0'
compile 'com.github.bumptech.glide:okhttp3-integration:4.0.0-RC0@aar'
annotationProcessor 'com.github.bumptech.glide:compiler:4.0.0-RC0'
//circleimageview 圆形头像
compile 'de.hdodenhof:circleimageview:2.2.0'
//数据库依赖
compile 'org.greenrobot:greendao-generator:3.2.2'
compile 'org.greenrobot:greendao:3.2.2'
//图片裁剪
compile 'com.github.yalantis:ucrop:2.2.1-native'
//permissionsdispatcher
compile("com.github.hotchemi:permissionsdispatcher:3.0.1") {
exclude module: "support-v13"
}
annotationProcessor "com.github.hotchemi:permissionsdispatcher-processor:3.0.1"
//富文本
compile 'com.zzhoujay.richtext:richtext:2.5.4'
//二维码扫描
compile 'me.dm7.barcodescanner:zbar:1.9.3'
最后求求你们给个star,长这么大一个star都没有,好心痛
(ps:这里我要说明一下,我的作品和某课网很相似的原因。因为做这个作品之初的时候,我刚好在一个技术交流群里面的附件里找到一份电商的源码,并且做了研究,我发现了其中精华的地方,包括网络请求和RecyclerView的Adapter以及其他优秀的地方,我也就拿来使用了。但是,那份源码,我拿到手是没有后台的。而且很多地方看不懂。如果看过我的源码的人都知道,我用的是MVP模式,而某课的不是。我添加了很多自己的想法与实践在里面。还请大佬们轻喷)