提交 c0722413 编写于 作者: W wangqi

Description: Upload Readme

Signed-off-by: N王琪 <wangqi327@huawei.com>
上级 0416ff76
# 设备管理 # 设备管理
- 升级服务
- [示例服务器开发概述](sample_server_overview.md)
- [示例服务器开发指导](sample_server_guidelines.md)
- USB服务 - USB服务
- [USB服务开发概述](usb-overview.md) - [USB服务开发概述](usb-overview.md)
- [USB服务开发指导](usb-guidelines.md) - [USB服务开发指导](usb-guidelines.md)
...@@ -16,3 +13,6 @@ ...@@ -16,3 +13,6 @@
- 振动 - 振动
- [振动开发概述](vibrator-overview.md) - [振动开发概述](vibrator-overview.md)
- [振动开发指导](vibrator-guidelines.md) - [振动开发指导](vibrator-guidelines.md)
- 升级服务
- [示例服务器开发概述](sample-server-overview.md)
- [示例服务器开发指导](sample-server-guidelines.md)
...@@ -2,13 +2,13 @@ ...@@ -2,13 +2,13 @@
## 场景介绍 ## 场景介绍
升级服务示例服务器开发指导的主要工作是为了解决升级服务的实际应用场景测试中缺乏相应搜包服务器提供查询升级包、获取升级包下载url等功能,使得测试升级服务和二次开发功能验证比较困难的问题得到解决,为升级服务的应用场景提供尽可能完善的端到端环境搭建。开发者能够基于此指导快速开发一个简易的搜包服务器用于升级服务应用场景测试。 示例服务器解决了升级服务的实际应用场景测试中缺乏相应搜包服务器提供查询升级包、获取升级包下载url等问题,支持测试升级服务和二次开发功能验证,为升级服务的应用场景提供尽可能完善的端到端环境搭建。开发者能够基于此指导快速开发一个简易的搜包服务器用于升级服务应用场景测试。
## 开发步骤 ## 开发步骤
1. 生成SSL证书 1. 生成SSL证书
会生成serverKey.pem和serverCert.cer两个文件 生成serverKey.pem和serverCert.cer两个文件,用于示例服务器的SSL协议通信
```bash ```bash
openssl req -newkey rsa:2048 -nodes -keyout serverKey.pem -x509 -days 365 -out serverCert.cer -subj "/C=CN/ST=GD/L=GZ/O=abc/OU=defg/CN=hijk/emailAddress=test.com" openssl req -newkey rsa:2048 -nodes -keyout serverKey.pem -x509 -days 365 -out serverCert.cer -subj "/C=CN/ST=GD/L=GZ/O=abc/OU=defg/CN=hijk/emailAddress=test.com"
...@@ -29,15 +29,17 @@ openssl req -newkey rsa:2048 -nodes -keyout serverKey.pem -x509 -days 365 -out s ...@@ -29,15 +29,17 @@ openssl req -newkey rsa:2048 -nodes -keyout serverKey.pem -x509 -days 365 -out s
3. 下载代码仓 3. 下载代码仓
通过repo下载OpenHarmony全仓,或者通过git clone下载本代码仓。 repo方式下载OpenHarmony全仓
```bash ```bash
// repo下载OpenHarmony全仓
repo init -u https://gitee.com/openharmony/manifest.git -b master --no-repo-verify repo init -u https://gitee.com/openharmony/manifest.git -b master --no-repo-verify
repo sync -c repo sync -c
repo forall -c 'git lfs pull' repo forall -c 'git lfs pull'
```
git clone方式下载本代码仓
// git clone下载本代码仓 ```bash
git clone https://gitee.com/openharmony/update_updateservice.git -b master git clone https://gitee.com/openharmony/update_updateservice.git -b master
``` ```
...@@ -45,7 +47,7 @@ git clone https://gitee.com/openharmony/update_updateservice.git -b master ...@@ -45,7 +47,7 @@ git clone https://gitee.com/openharmony/update_updateservice.git -b master
4. 建立代码目录 4. 建立代码目录
进入到本仓update_updateservice目录下,执行以下命令,建立代码目录。 进入到update_updateservice目录下,执行以下命令,建立代码目录。
```bash ```bash
mkdir server_sample // 建立示例服务器server_sample目录 mkdir server_sample // 建立示例服务器server_sample目录
...@@ -59,52 +61,52 @@ touch server_sample/src/main.cpp // 创建main.cpp文件 ...@@ -59,52 +61,52 @@ touch server_sample/src/main.cpp // 创建main.cpp文件
5. 编译文件BUILD.gn编写 5. 编译文件BUILD.gn编写
文件BUILD.gn一共编译两个ohos组件,一个是ohos_shared_library库文件libserver_process.z.so,一个是ohos_executable可执行文件testserver。 文件BUILD.gn一共编译两个ohos组件,一个是ohos_shared_library库文件libserver_process.z.so,一个是ohos_executable可执行文件testserver。
```cmake ```cmake
import("//build/ohos.gni") import("//build/ohos.gni")
ohos_shared_library("server_process") { ohos_shared_library("server_process") {
sources = [ sources = [
"//base/update/updateservice/./src/server_process.c", "//base/update/updateservice/./src/server_process.c",
] ]
include_dirs = [ include_dirs = [
"//base/update/updateservice/server_sample/include", "//base/update/updateservice/server_sample/include",
"//third_party/openssl/include", "//third_party/openssl/include",
] ]
deps = [ deps = [
"//base/update/updater/services/log:libupdaterlog", "//base/update/updater/services/log:libupdaterlog",
"//third_party/bounds_checking_function:libsec_static", "//third_party/bounds_checking_function:libsec_static",
"//third_party/openssl:crypto_source", "//third_party/openssl:crypto_source",
"//third_party/openssl:ssl_source", "//third_party/openssl:ssl_source",
"//utils/native/base:utils", "//utils/native/base:utils",
] ]
part_name = "update_service" part_name = "update_service"
} }
ohos_executable("testserver") { ohos_executable("testserver") {
source = [ source = [
"//base/update/updateservice/server_sample/src/main.cpp", "//base/update/updateservice/server_sample/src/main.cpp",
] ]
include_dirs = [ include_dirs = [
"//base/update/updateservice/server_sample/include", "//base/update/updateservice/server_sample/include",
] ]
deps = [ deps = [
"//base/update/updateservice/server_sample:server_process", "//base/update/updateservice/server_sample:server_process",
] ]
part_name = "update_service" part_name = "update_service"
} }
``` ```
6. 头文件server_process.h编写 6. 头文件server_process.h编写
文件server_process.h声明了示例服务器的一些接口。 文件server_process.h声明了示例服务器的接口。
```c++ ```c++
#ifndef __SERVER_PROCESS_H__ #ifndef __SERVER_PROCESS_H__
...@@ -150,7 +152,7 @@ int Close(); ...@@ -150,7 +152,7 @@ int Close();
7. server_process.c、main.cpp编写 7. server_process.c、main.cpp编写
文件server_process.c主要声明了服务器的返回报文格式respondContent;main.cpp编写在此略去,可参考普通SSL协议的服务器编写,注意包含相关头文件,同时加载serverKey.pem和serverCert.cer两个证书。 文件server_process.c主要声明了服务器的返回报文格式respondContent,main.cpp可参考普通SSL协议的服务器编写,注意包含相关头文件,同时加载serverKey.pem和serverCert.cer两个证书。
```c ```c
#include "server_process.h" #include "server_process.h"
...@@ -203,16 +205,12 @@ respondContent = "{" ...@@ -203,16 +205,12 @@ respondContent = "{"
9. 升级包制作 9. 升级包制作
参考OpenHarmony的update_packaging_tools仓制作升级包。 [参考OpenHarmony的update_packaging_tools仓制作升级包。](https://gitee.com/openharmony/update_packaging_tools)
```http
https://gitee.com/openharmony/update_packaging_tools
```
10. 启动搜包服务器 10. 启动搜包服务器
建议在开发板上新建一个纯英文路径然后将testserver、libserver_process.z.so、serverCert.cer和serverKey.pem放到同一个目录下,进入该目录,执行以下启动命令即可启动搜包服务器。 建议在开发板上新建一个纯英文路径然后将testserver、libserver_process.z.so、serverCert.cer和serverKey.pem放到同一个目录下,进入该目录,执行以下启动命令即可启动搜包服务器。
```bash ```bash
./testserver ./libserver_process.z.so & ./testserver ./libserver_process.z.so &
......
# 示例服务器开发概述 # 示例服务器开发概述
升级服务示例服务器提供一个简易的升级包部署的服务器实例参考,用于升级服务子系统的辅助验证环境搭建。 示例服务器提供一个简易的升级包部署的服务器实例参考,用于升级服务子系统的辅助验证环境搭建。
## 基本概念 ## 基本概念
- 搜包服务:升级服务(UpdateService)提供的服务能力之一,依赖环境需要TCP连接并支持SSL协议的服务器。 - 搜包服务:升级服务(UpdateService)提供的服务能力之一,依赖支持TCP和SSL协议的服务器。
- 搜包服务器:即上文支持搜包服务的通过TCP连接并支持SSL协议的服务器,本概述提及的升级服务示例服务器即是符合要求的搜包服务器之一。 - 搜包服务器:即支持搜包服务的通过TCP连接并支持SSL协议的服务器,本概述提及的升级服务示例服务器即是符合要求的搜包服务器之一。
- 下载服务器:普通的HTTP服务器即可满足下载服务器的要求,可以参考Nginx和Tomcat搭建,并将升级包放在对应路径下。 - 下载服务器:普通的HTTP服务器即可满足下载服务器的要求,可以参考Nginx和Tomcat搭建,并将升级包放在对应路径下。
- 设置升级包下载url:在搜包报文的url字段指定升级包下载url即可完成设置。 - update.serverip.search:系统参数,指升级服务(UpdateService)侧配置的搜包服务器IP地址,默认值:127.0.0.1。
- 系统参数update.serverip.search:指升级服务(UpdateService)侧配置的搜包服务器IP地址,默认值:127.0.0.1。
## 约束与限制 ## 约束与限制
- 服务器返回报文格式Json示例 - 服务器返回报文格式Json示例,注意verifyInfo字段是升级包的sha256值,size字段是升级包的大小,单位为字节。
```json ```json
{ {
...@@ -28,7 +26,7 @@ ...@@ -28,7 +26,7 @@
"verifyInfo": "verifyInfoSHA256Value1234567", "verifyInfo": "verifyInfoSHA256Value1234567",
"size": 1234567, "size": 1234567,
"packageType": 1, "packageType": 1,
"url": "http://serverAddressSample/packageNameSample.fileTypeSample". "url": "http://serverAddressSample/packageNameSample.fileTypeSample",
"descriptPackageId": "packageNameSample.fileTypeSample" "descriptPackageId": "packageNameSample.fileTypeSample"
}], }],
"descriptInfo": [{ "descriptInfo": [{
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册