|
1 | 1 | ## 版本区别 |
2 | | -passJavaCloud 为腾讯云开发版,不需要后台即可访问题库。 |
3 | | -小程序的题库都在腾讯云开发的数据库中。可以自行添加题库。新增题库的方式后续会有专门的文章进行介绍。请关注公众号第一时间获取。使用方式我也会同步到这个仓库中。 |
| 2 | +### passJavaCloud |
| 3 | + |
| 4 | +passJavaCloud:腾讯云开发版小程序,不需要后台即可访问题库。 |
| 5 | +小程序的题库都在腾讯云开发的数据库中。可以自行添加题库。 |
| 6 | + |
| 7 | +### passJavaRest |
| 8 | +passJavaRest:进阶版小程序。后端采用 Spring Cloud 微服务作为服务支撑,数据库也不是云数据库了,而是 mysql。Rest 版本虽然目前还不完善,但已经和后端打通。 |
| 9 | + |
| 10 | + |
| 11 | +本文主要内容如下: |
| 12 | + |
| 13 | + |
| 14 | +## 一、缘起 |
| 15 | + |
| 16 | +PassJava 开源项目是一个`面试刷题`的开源系统,后端采用 Spring Cloud 微服务可以用零碎时间利用`小程序`查看常见面试题,夯实Java 技术栈,当然题库不限于 Java,还有微服务。 |
| 17 | + |
| 18 | +之前有读者问我小程序开源么,因之前在写分布式算法系列的文章,所以开源项目中断了一段时间,现在继续更新开源项目。 |
| 19 | + |
| 20 | +为了让读者朋友们更好地学习该项目,我已经将小程序代码开源。 |
| 21 | + |
| 22 | + |
| 23 | + |
| 24 | +小程序的代码地址在 github 上面,别忘记点个 star,素质三连哈~ |
| 25 | + |
| 26 | +> https://github.com/Jackson0714/PassJava-Platform/tree/master/passjava-miniApp |
| 27 | +
|
| 28 | +小程序体验码如下: |
| 29 | + |
| 30 | + |
| 31 | + |
| 32 | +小程序界面: |
| 33 | + |
| 34 | + |
| 35 | + |
| 36 | +小程序有两个版本:云开发版和进阶版。下面分别进行介绍。 |
| 37 | + |
| 38 | +## 二、云开发版 |
| 39 | + |
| 40 | +### 2.1 小程序简介 |
| 41 | + |
| 42 | +小程序·云开发是微信团队联合腾讯云推出的专业的小程序开发服务。 |
| 43 | + |
| 44 | +开发者可以使用云开发快速开发小程序、小游戏、公众号网页等,并且原生打通微信开放能力。 |
| 45 | + |
| 46 | +开发者无需搭建服务器,可免鉴权直接使用平台提供的 API 进行业务开发。 |
| 47 | + |
| 48 | +#### 2.1.1 优势: |
| 49 | + |
| 50 | +- 无需搭建服务器,只需使用平台提供的各项能力,即可快速开发业务。 |
| 51 | +- 无需管理证书、签名、秘钥,直接调用微信 API 。复用微信私有协议及链路,保证业务安全性。 |
| 52 | +- 支持环境共享,一个后端环境可开发多个小程序、公众号、网页等,便捷复用业务代码与数据。 |
| 53 | +- 开发者可以使用任意语言和框架进行代码开发,构建为容器后,快速将其托管至云开发。 |
| 54 | +- 支持按量计费模式,后端资源根据业务流量自动扩容,先使用后付费,无需支付闲置成本。 |
| 55 | + |
| 56 | +#### 2.1.2 特点 |
| 57 | + |
| 58 | +**云数据库**:文档型数据库,稳定可靠;支持在小程序端和云函数中调用。 |
| 59 | + |
| 60 | +**存储**:云端文件存储,自带 CDN 加速,支持在前端直接上传/下载,可在云开发控制台可视化管理。 |
| 61 | + |
| 62 | +**云函数**:在云端运行的代码,微信私有协议天然鉴权,开发者只需编写自身业务逻辑代码。 |
| 63 | + |
| 64 | +**云托管**:支持托管服务容器,不限框架和语言,常驻运行、天然鉴权,可快速进行业务迁移 |
| 65 | + |
| 66 | +#### 2.1.3 缺点 |
| 67 | + |
| 68 | +- 适合个人开发。 |
| 69 | +- 按照流量付费,访问人多了的话,需要购买流量。 |
| 70 | +- 因服务端是腾讯自带的,所以不能使用其他后端中间件来实现功能增强,比如 Redis,RabbitMQ。 |
| 71 | +- 数据库和存储也是腾讯自带的,所以不能使用其他数据库和存储,比如 mysql、阿里云。 |
| 72 | + |
| 73 | +### 2.2 小程序下载使用 |
| 74 | + |
| 75 | +#### 2.2.1 题库简介 |
| 76 | + |
| 77 | +题库功能如下图所示: |
| 78 | + |
| 79 | +- 第一步:进入到选择题目类型。这里有 12 种类别,点击其中一个可跳转到题目列表页。 |
| 80 | + |
| 81 | + |
| 82 | + |
| 83 | +- 第二步:进入到题库列表页。下图是 Spring 题库列表页,可以点击查看进入到题目的详情页。 |
| 84 | + |
| 85 | + |
| 86 | + |
| 87 | +- 第三步:进入到题目详情页。如下图所示就是 spring 面试题的详情页,加载的内容就是上传到云存储的 markdown 文件。后面会讲解如何上传题目。 |
| 88 | + |
| 89 | + |
| 90 | + |
| 91 | +#### 2.2.3 上传题目 |
| 92 | + |
| 93 | +要用这套云开发版的小程序的话,需要先上传题目文件到云存储。 |
| 94 | + |
| 95 | +如下图所示,我上传了很多 markdown 文件,大家可以自行编写 markdown 文件,每一个文件对应一个题目,里面的内容是题目的问题+答案。 |
| 96 | + |
| 97 | + |
| 98 | + |
| 99 | +#### 2.2.3 添加题目记录 |
| 100 | + |
| 101 | +然后需要在数据库中插入数据,来提供给小程序查询。 |
| 102 | + |
| 103 | + |
| 104 | + |
| 105 | +我导出了一条记录,大家可以直接插入到数据库中。 |
| 106 | + |
| 107 | +```json |
| 108 | +{ |
| 109 | + "_id": "27a98c6c-0477-4edb-8ef3-e35f0501b31c", |
| 110 | + "question": "1.JAVA 异常分类及处理?", |
| 111 | + "answer": "cloud://test-0jlva.7465-test-0jlva-1254012214/markdown/02_JavaBasic/一、JAVA 异常分类及处理.md", |
| 112 | + "number": "1", |
| 113 | + "subTitle": "每天进步一点点", |
| 114 | + "type": "javaBasic", |
| 115 | + "level": "1" |
| 116 | +} |
| 117 | +``` |
| 118 | + |
| 119 | +- question:题目的问题。 |
| 120 | +- answer:题目的答案。 |
| 121 | +- number:题目的序号。 |
| 122 | +- subTitle:题目的副标题。 |
| 123 | +- type:题目的类型,目前有 `javaBasic`、`jvm`、`spring` 等 12 种。也可以自行添加。 |
| 124 | + |
| 125 | + |
| 126 | + |
| 127 | +markdown 格式的题目已经上传到了 github,目前只有部分,欢迎大家 commit。 |
| 128 | + |
| 129 | +```http |
| 130 | +https://github.com/Jackson0714/passJavaKnowledge/tree/master |
| 131 | +``` |
| 132 | + |
| 133 | +另外我还有 1000 道面试题的 pdf 也可以用作题库,需要的同学在公众号后台回复`悟空`领取下。 |
| 134 | + |
| 135 | +### 2.3 小程序原理 |
| 136 | + |
| 137 | +小程序原理图如下: |
| 138 | + |
| 139 | + |
| 140 | + |
| 141 | +原理图说明: |
| 142 | + |
| 143 | +1)调用 自己编写的云函数 getJavaQuestionList 获取列表; |
| 144 | + |
| 145 | +2)调用 自己编写的云函数 getJavaQuestionDetail 获取详情的 Markdown文件路径; |
| 146 | + |
| 147 | +3)调用 系统自带的云函数 downloadFile 下载 Markdown文件保存为临时文件; |
| 148 | + |
| 149 | +4)调用 小程序自带的 saveFileSync 将临时文件保存到本地; |
| 150 | + |
| 151 | +5)调用 小程序自带的 readFileSync 将本地文件读入缓存(注意:开发者工具上不需要保存到本地也可以正常读取); |
| 152 | + |
| 153 | +6)使用 towxml 开源组件将缓存中markdown内容转成小程序可以识别的元素 |
| 154 | + |
| 155 | +7)给 图片元素添加预览事件 |
| 156 | + |
| 157 | +因小程序主要是用来刷题,附加的功能比如 banner 广告位、热点推荐等就不在这里介绍了。 |
| 158 | + |
| 159 | +对于有些同学来说,云开发还比较陌生,需要多看看官方文档熟悉下才能熟练进行二次开发。 |
| 160 | + |
| 161 | +## 三、进阶版 |
| 162 | + |
| 163 | +该项目的小程序进阶版指的是不用云开发,后端采用 Spring Cloud 微服务作为服务支撑,数据库也不是云数据库了,而是 mysql。Rest 版本虽然目前还不完善,但已经和后端打通。 |
| 164 | + |
| 165 | +### 3.1 使用条件 |
| 166 | + |
| 167 | +目前需要以下条件才能将前端和后端连起来一起用: |
| 168 | + |
| 169 | +- 本地后台微服务启动成功。 |
| 170 | + |
| 171 | + 目前要求 passjava-gateway、passjava-question、renren 启动成功。 |
| 172 | + |
| 173 | + |
| 174 | + |
| 175 | +- MySQL 数据库和表结构创建成功。 |
| 176 | + |
| 177 | + 数据库文件在 \data\sql 目录,需要都执行。执行成功后,业务表总共有 5 个业务模块, 7 张表,如下图所示: |
| 178 | + |
| 179 | + |
| 180 | + |
| 181 | +- Nacos 服务启动成功且已配置好微服务的相关配置。 |
| 182 | + |
| 183 | + 如何配置可参考前面的文章。访问地址:http://192.168.56.1:8848/nacos。访问 Nacos,并登陆 Nacos 后,如下图所示: |
| 184 | + |
| 185 | + |
| 186 | + |
| 187 | +- passjava-portal 管理控制台启动成功。 |
| 188 | + |
| 189 | + 通过 http://localhost:8001/ 访问。 |
| 190 | + |
| 191 | + |
| 192 | + |
| 193 | +- 题目管理功能正常使用。 |
| 194 | + |
| 195 | + 可以创建题目类型和创建题目。 |
| 196 | + |
| 197 | + |
| 198 | + |
| 199 | +- 打开小程序代码正常。 |
| 200 | + |
| 201 | + 另外需要注意下,Rest 版目前的首页题目类型和题目列表正在开发中,所以还是用的云函数,获取题目用到的 id 是 1。目前阶段仅供学习,本人时间有限,欢迎大家来帮助 commit。 |
| 202 | + |
| 203 | + |
| 204 | + |
| 205 | +## 四、开源地址 |
| 206 | + |
| 207 | +我把后端、前端、小程序都上传到同一个仓库里面了,大家可以通过 github 或 码云访问。地址如下: |
| 208 | + |
| 209 | +> **Github**: https://github.com/Jackson0714/PassJava-Platform |
| 210 | +> |
| 211 | +> **码云**:https://gitee.com/jayh2018/PassJava-Platform |
| 212 | +> |
| 213 | +> **配套教程**:www.passjava.cn |
| 214 | +
|
| 215 | +调试代码是个辛苦活,精力有限,在写技术文章时,还需要抽出时间倒腾这个开源项目,所以是否值得一赞? |
| 216 | + |
| 217 | + |
| 218 | + |
| 219 | +参考资料: |
| 220 | + |
| 221 | +https://developers.weixin.qq.com/miniprogram/dev/wxcloud/basis/getting-started.html |
0 commit comments