Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
c0722413
D
Docs
项目概览
OpenHarmony
/
Docs
1 年多 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
c0722413
编写于
4月 15, 2022
作者:
W
wangqi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Description: Upload Readme
Signed-off-by:
N
王琪
<
wangqi327@huawei.com
>
上级
0416ff76
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
53 addition
and
57 deletion
+53
-57
zh-cn/application-dev/device/Readme-CN.md
zh-cn/application-dev/device/Readme-CN.md
+3
-3
zh-cn/application-dev/device/sample-server-guidelines.md
zh-cn/application-dev/device/sample-server-guidelines.md
+44
-46
zh-cn/application-dev/device/sample-server-overview.md
zh-cn/application-dev/device/sample-server-overview.md
+6
-8
未找到文件。
zh-cn/application-dev/device/Readme-CN.md
浏览文件 @
c0722413
# 设备管理
# 设备管理
-
升级服务
-
[
示例服务器开发概述
](
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
)
zh-cn/application-dev/device/sample
_server_
guidelines.md
→
zh-cn/application-dev/device/sample
-server-
guidelines.md
浏览文件 @
c0722413
...
@@ -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 &
...
...
zh-cn/application-dev/device/sample
_server_
overview.md
→
zh-cn/application-dev/device/sample
-server-
overview.md
浏览文件 @
c0722413
# 示例服务器开发概述
# 示例服务器开发概述
升级服务
示例服务器提供一个简易的升级包部署的服务器实例参考,用于升级服务子系统的辅助验证环境搭建。
示例服务器提供一个简易的升级包部署的服务器实例参考,用于升级服务子系统的辅助验证环境搭建。
## 基本概念
## 基本概念
-
搜包服务:升级服务(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.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录