Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
45aae75b
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看板
提交
45aae75b
编写于
4月 15, 2022
作者:
W
wangqi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Description: Upload Readme
Signed-off-by:
N
王琪
<
wangqi327@huawei.com
>
上级
c0722413
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
164 addition
and
165 deletion
+164
-165
zh-cn/application-dev/device/sample-server-guidelines.md
zh-cn/application-dev/device/sample-server-guidelines.md
+149
-150
zh-cn/application-dev/device/sample-server-overview.md
zh-cn/application-dev/device/sample-server-overview.md
+15
-15
未找到文件。
zh-cn/application-dev/device/sample-server-guidelines.md
浏览文件 @
45aae75b
...
@@ -8,211 +8,210 @@
...
@@ -8,211 +8,210 @@
1.
生成SSL证书
1.
生成SSL证书
生成serverKey.pem和serverCert.cer两个文件,用于示例服务器的SSL协议通信。
生成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"
```
```
2.
修改bundle.json
2.
修改bundle.json
在build字段的sub_component字段中开始位置新增一行。
在build字段的sub_component字段中开始位置新增一行。
```
cmake
```cmake
"sub_component"
: [
"sub_component": [
"//base/update/updateservice/server_sample:testserver"
,
"//base/update/updateservice/server_sample:testserver",
...
...
],
],
```
```
3.
下载代码仓
3.
下载代码仓
repo方式下载OpenHarmony全仓
repo方式下载OpenHarmony全仓
```
bash
```bash
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
```bash
git clone https://gitee.com/openharmony/update_updateservice.git
-b
master
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目录
touch
server_sample/BUILD.gn
// 创建BUILD.gn编译文件
touch server_sample/BUILD.gn
// 创建BUILD.gn编译文件
mkdir
server_sample/include
// 建立示例服务器头文件include目录
mkdir server_sample/include
// 建立示例服务器头文件include目录
touch
server_process.h
// 创建server_process.h头文件
touch server_process.h
// 创建server_process.h头文件
mkdir
server_sample/src
// 建立示例服务器c/c++文件src目录
mkdir server_sample/src
// 建立示例服务器c/c++文件src目录
touch
server_sample/src/server_process.c
// 创建server_process.c文件
touch server_sample/src/server_process.c
// 创建server_process.c文件
touch
server_sample/src/main.cpp
// 创建main.cpp文件
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__
#define __SERVER_PROCESS_H__
#define __SERVER_PROCESS_H__
/*
/*
Init函数:用于创建socket环境,并预设置一些属性
Init函数:用于创建socket环境,并预设置一些属性
*/
*/
int
Init
();
int Init();
/*
/*
SetParam函数:所有插件参数设置的统一接口
SetParam函数:所有插件参数设置的统一接口
*/
*/
int
SetParam
(
const
char
*
key
,
const
char
*
value
);
int SetParam(const char *key, const char *value);
/*
/*
GetParam函数:所有插件参数获取的统一接口
GetParam函数:所有插件参数获取的统一接口
*/
*/
int
GetParam
(
const
char
*
key
,
char
*
value
);
int GetParam(const char *key, char *value);
/*
/*
ReverseSetParamCallback函数:回调
ReverseSetParamCallback函数:回调
*/
*/
int
ReverseSetParamCallback
(
int
(
*
setParam
)(
const
char
*
key
,
const
char
*
value
));
int ReverseSetParamCallback(int(*setParam)(const char *key, const char *value));
/*
/*
Open函数:用于服务打开的接口
Open函数:用于服务打开的接口
*/
*/
int
Open
();
int Open();
/*
/*
MainLoop函数:每隔100ms调用一次
MainLoop函数:每隔100ms调用一次
*/
*/
int
MainLoop
();
int MainLoop();
/*
/*
Close函数,用于关闭服务并释放资源
Close函数,用于关闭服务并释放资源
*/
*/
int
Close
();
int Close();
#endif //__SERVER_PROCESS_H__
#endif //__SERVER_PROCESS_H__
```
```
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"
#include <netinet/in.h>
#include <netinet/in.h>
#include <sys/types.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdlib.h>
#include <string.h>
#include <string.h>
#include <stdio.h>
#include <stdio.h>
#include "openssl/err.h"
#include "openssl/err.h"
#include "openssl/ssl.h"
#include "openssl/ssl.h"
#define SERVER_PEM "/data/sdcard/serverKey.pem" //使用绝对路径
#define SERVER_PEM "/data/sdcard/serverKey.pem" //使用绝对路径
#define SERVER_CER "/data/sdcard/serverCert.cer" //使用绝对路径
#define SERVER_CER "/data/sdcard/serverCert.cer" //使用绝对路径
#define LOG_PRINT(fmt, ...) printf("[ServerProcess][%s:%d] " fmt "\n", __func__, __LINE__, ##__VA_ARGS__)
#define LOG_PRINT(fmt, ...) printf("[ServerProcess][%s:%d] " fmt "\n", __func__, __LINE__, ##__VA_ARGS__)
#define DO_CHECK(cond, log, ...) \
#define DO_CHECK(cond, log, ...) \
if (!(cond)) {\
if (!(cond)) {\
LOG_PRINT(log);\
LOG_PRINT(log);\
__VA_ARGS__;\
__VA_ARGS__;\
return -1;\
return -1;\
}
}
// 请参考server_process.h的接口予以实现,注意服务器返回的内容格式。
// 请参考server_process.h的接口予以实现,注意服务器返回的内容格式。
respondContent
=
"{"
respondContent = "{"
"
\"
searchStatus
\"
: 0,"
"\"searchStatus\": 0,"
"
\"
errMsg
\"
:
\"
success
\"
,"
"\"errMsg\": \"success\","
"
\"
checkResults
\"
: [{"
"\"checkResults\": [{"
"
\"
versionName
\"
:
\"
sampleVersionName
\"
,"
"\"versionName\": \"sampleVersionName\","
"
\"
versionCode
\"
:
\"
sampleVersionCode
\"
,"
"\"versionCode\": \"sampleVersionCode\","
"
\"
verifyInfo
\"
:
\"
sampleVerifyInfoSha256Value
\"
,"
"\"verifyInfo\": \"sampleVerifyInfoSha256Value\","
"
\"
size
\"
: 1234567,"
"\"size\": 1234567,"
"
\"
packageType
\"
: 1,"
"\"packageType\": 1,"
"
\"
descriptPackageId
\"
:
\"
update.bin
\"
,"
"\"descriptPackageId\": \"update.bin\","
"}],"
"}],"
"
\"
descriptInfo
\"
: [{"
"\"descriptInfo\": [{"
"
\"
descriptPackageId
\"
:
\"
update.bin
\"
,"
"\"descriptPackageId\": \"update.bin\","
"
\"
content
\"
:
\"
This package message is used for sampleContent
\"
"
"\"content\": \"This package message is used for sampleContent\""
"}]"
"}]"
"}";
"}";
```
```
8.
编译输出产物
8.
编译输出产物
编译输出目录会新增testserver和libserver_process.z.so两个文件。
编译输出目录会新增testserver和libserver_process.z.so两个文件。
9.
升级包制作
9.
升级包制作
[
参考OpenHarmony的update_packaging_tools仓制作升级包。
](
https://gitee.com/openharmony/update_packaging_tools
)
[参考OpenHarmony的update_packaging_tools仓制作升级包。](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
./testserver ./libserver_process.z.so &
```
bash
```
./testserver ./libserver_process.z.so &
```
zh-cn/application-dev/device/sample-server-overview.md
浏览文件 @
45aae75b
...
@@ -18,21 +18,21 @@
...
@@ -18,21 +18,21 @@
```
json
```
json
{
{
"searchStatus"
:
0
,
"searchStatus"
:
0
,
"errMsg"
:
"success"
,
"errMsg"
:
"success"
,
"checkResults"
:
[{
"checkResults"
:
[{
"versionName"
:
"versionNameSample"
,
"versionName"
:
"versionNameSample"
,
"versionCode"
:
"versionCodeSample"
,
"versionCode"
:
"versionCodeSample"
,
"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"
:
[{
"descriptPackageId"
:
"packageNameSample.fileTypeSample"
,
"descriptPackageId"
:
"packageNameSample.fileTypeSample"
,
"content"
:
"This package is used for update."
"content"
:
"This package is used for update."
}]
}]
}
}
```
```
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录