XUpdateService

Introduction: 使用 Spring Boot 简易搭建,Gradle 构建,为 XUpdate 提供的更新服务。
More: Author   ReportBugs   OfficialWebsite   
Tags:

使用 Spring Boot 简易搭建,Gradle 构建,为 XUpdate 提供的更新服务。

内容

  • 使用 spring boot 快速搭建,并使用 Gradle 进行构建【区别 Maven】。

  • 使用阿里的 druid 数据库连接池和 tk.mybatis 进行数据库的连接。

  • 使用 MySql 作为数据库。

  • 提供了应用版本后台管理所需的 API 服务,使用 Html 和 ajax 简单实现了应用版本管理界面。

  • 使用了 AOP 对 api 请求进行动态日志记录。

  • 实现通用的文件上传(包括多文件上传)和下载功能。

  • 增加了请求流量以及请求权限的控制。

  • 支持浏览器跨域请求。

搭建方法

  1. clone 项目到本地
git clone https://github.com/xuexiangjys/XUpdateService.git

2.使用 IntelliJ IDEA 导入该项目。

3.进行本地数据库的配置。

因为使用的是 MySql 数据库,如果你电脑上没有安装 MySql 的话,请先点击安装。你可以安装MySQL Community ServerMySQL Workbench,建议下载的 MySql 版本是 5.7。

  • MySql 安装完成后,请执行根目录下sql文件夹下的脚本,创建数据库表和内容。

  • 配置src/main/resources/application.yml文件,包括服务端口、数据库配置、mybatis 配置、文件上传配置等。

  • 如果你需要使用 mybatis 的自动生成代码脚本generator,请配置src/main/resources/db-mysql.properties文件,然后执行./gradlew mybatisGenerate或者在 Gradle 的 Task 列表中选择mybatisGenerate双击即可。

4.直接运行XUpdateServiceApplication即可运行服务。

程序打包

1.执行./gradlew bootJar或点击 Gradle 任务栏点击Tasks -> Build -> bootJar.

2.打包后的是 jar 文件,打包路径:build/libs/ 下,如下图:

3.最后执行 jar 包即可.

java -jar build/libs/xxxxx.jar

4.目前最新的已打包好的 jar 在项目的Packagexupdateservice-1.0.0.jar, 运行前请保证你的数据库连接正常。

版本更新管理后台

由于使用 Java 编写 web 管理后台不是很好看,因此我特地去学习了最近比较火的 Vue.js 编写了一个简洁优美的管理后台供大家参考。

项目地址: https://github.com/xuexiangjys/xupdate-management

项目预览


API 构成

管理接口

1、注册 APK 的版本信息

  • 请求类型: post
  • url : /update/addVersionInfo
  • 参数 :
{
    "updateStatus":2,
    "modifyContent":"1、优化 api 接口。\r\n2、添加使用 demo 演示。\r\n3、新增自定义更新服务 API 接口。\r\n4、优化更新提示界面。",
    "appKey":"test",
    "versionName":"1.0.3",
    "versionCode":4
}
  • 响应 :
{
    "Msg":"",
    "Code":0,
    "Data":{
        "versionId":12,
        "updateStatus":2,
        "modifyContent":"1、优化 api 接口。\r\n2、添加使用 demo 演示。\r\n3、新增自定义更新服务 API 接口。\r\n4、优化更新提示界面。",
        "appKey":"test",
        "versionName":"1.0.3",
        "versionCode":4
    }
}

2、上传 APK

  • 请求类型: post【multipart/form-data】
  • url : /update/uploadApk
  • 参数 :
file=[文件]
versionId=12
  • 响应 :
{
    "Code":0,
    "Msg":"",
    "Data":true
}

3、添加版本信息

  • 请求类型: post【multipart/form-data】
  • url : /update/addAppVersion
  • 参数 :
file=[文件]

appVersionInfo= {
    "updateStatus":2,
    "modifyContent":"1、优化 api 接口。\r\n2、添加使用 demo 演示。\r\n3、新增自定义更新服务 API 接口。\r\n4、优化更新提示界面。",
    "appKey":"test",
    "versionName":"1.0.3",
    "versionCode":4
}
  • 响应 :
{
    "Code":0,
    "Msg":"",
    "Data":true
}

版本更新接口

1、版本信息检查

  • 请求类型: post
  • url : /update/checkVersion
  • 参数 :
versionCode=1,
appKey=com.xuexiang.xupdatedemo
  • 响应 :
{
    "Msg":"",
    "Code":0,
    "Data":{
        "apkMd5":"E4B79A36EFB9F17DF7E3BB161F9BCFD8",
        "versionId":11,
        "updateStatus":1,
        "downloadUrl":"xupdate_demo_1.0.2.apk",
        "modifyContent":"1、优化 api 接口。\r\n2、添加使用 demo 演示。\r\n3、新增自定义更新服务 API 接口。\r\n4、优化更新提示界面。",
        "appKey":"com.xuexiang.xupdatedemo",
        "apkSize":1649,
        "uploadTime":"2018-07-30 09:47:25",
        "versionName":"1.23.4",
        "versionCode":34
    }
}

2、最新版本下载

  • 请求类型: get
  • url : /update/apk/{fileName:.+}
  • 响应 : 文件流
Apps
About Me
GitHub: Trinea
Facebook: Dev Tools