详解API开发【电商平台API封装商品详情SKU数据接口开发】
1、电商API开发
RESTful API的设计
RESTful API是一种通过HTTP协议发送和接收数据的API设计风格。它基于一些简单的原则,如使用HTTP动词来操作资源、使用URI来标识资源、使用HTTP状态码来表示操作结果等等。在本文中,我们将探讨如何设计一个符合RESTful API标准的PHP API,并提供一些实用的技巧和最佳实践。
一、资源和URI设计
RESTful API的核心思想是将所有的操作都视为资源的操作,每个资源都有一个唯一的URI来标识。在进行API设计时,我们应该首先考虑需要暴露哪些资源,以及它们的URI应该如何设计。
1.1 URI的组成
URI可以包含以下几个组成部分:
- 协议:http或https
- 域名:例如http://example.com
- 路径:标识资源的路径,例如/api/users/1
- 查询参数:可选的查询参数,例如?param1=value1¶m2=value2
- 片段标识符:可选的片段标识符,例如#section1
在设计URI时,应该遵循以下原则:
- URI应该简洁明了,易于理解和记忆;
- URI应该稳定,避免频繁更改,否则会影响客户端的使用;
- URI应该有意义,能够清楚地表达资源的含义。
1.2 URI的命名规范
在设计URI时,还应该遵循以下命名规范:
- 使用小写字母;
- 使用破折号作为单词之间的分隔符,而不是下划线;
- 对于集合资源,使用复数形式,例如/api/users;
- 对于具体的资源,使用单数形式,例如/api/users/1。
二、HTTP动词的使用
在RESTful API中,HTTP动词用于表示对资源的操作。常用的HTTP动词有GET、POST、PUT、PATCH和DELETE。下面是它们的具体含义:
- GET:获取资源的信息;
- POST:创建一个新的资源;
- PUT:更新一个已经存在的资源;
- PATCH:更新一个已经存在的资源的部分内容;
- DELETE:删除一个资源。
在设计API时,应该根据资源的不同操作来选择合适的HTTP动词。例如,获取用户列表应该使用GET方法,创建一个用户应该使用POST方法,更新一个用户应该使用PUT或PATCH方法,删除一个用户应该使用DELETE方法。
三、请求和响应格式
在RESTful API中,请求和响应的数据格式通常使用JSON格式。JSON是一种轻量级的数据交换格式,易于理解和解析。可以使用PHP的json_encode和json_decode函数来进行JSON格式的编码和解码。
在设计API时,应该遵循以下原则:
- 请求和响应的数据应该是无状态的,即不应该包含会话信息;
- 请求和响应的数据应该符合约定的数据格式,例如使用JSON格式;
- 请求和响应的数据应该尽量简洁明了,不包含冗余的信息。
四、API安全
在设计API时,安全性是一个非常重要的考虑因素。以下是一些常用的API安全措施:
4.1 使用HTTPS协议
HTTPS协议可以保证数据的加密传输,防止数据被窃取或篡改。在设计API时,应该使用HTTPS协议来保证通信安全。
4.2 使用JSON Web Token(JWT)
JWT是一种基于JSON的开放标准,用于在各方之间安全地传输信息。它可以用于身份验证和授权,避免了每次请求都需要进行身份验证的问题。在设计API时,可以使用JWT来增强API的安全性。
4.3 防止SQL注入和跨站脚本攻击(XSS)
在设计API时,应该遵循良好的编程实践,防止SQL注入和跨站脚本攻击。例如,在处理用户输入时,应该对输入进行过滤和验证,避免恶意输入导致的安全问题。
五、API文档
API文档是API设计中非常重要的一部分。它可以帮助客户端开发者了解API的使用方法和约束,避免由于不了解API而导致的错误和问题。以下是一些API文档的最佳实践:
5.1 使用Swagger
Swagger是一种流行的API文档工具,可以自动生成API文档,并提供交互式的API测试界面。在设计API时,可以使用Swagger来生成API文档,提高API的可用性和可访问性。
5.2 提供清晰的示例
在API文档中,应该提供清晰的示例,帮助开发者了解API的使用方法和约束。示例应该包含请求格式、响应格式、错误码等信息。
5.3 定期更新文档
API文档应该定期更新,以反映API的最新变化。当API发生变化时,应该及时通知客户端开发者,并更新API文档。
总结:
本文介绍了RESTful API的设计原则和最佳实践,并提供了一些实用的技巧和建议。在设计API时,应该首先考虑需要暴露哪些资源,并设计合适的URI来标识这些资源。接着,根据资源的不同操作,选择合适的HTTP动词来表示操作。在数据格式方面,应该使用JSON格式来传输请求和响应数据。在安全方面,应该使用HTTPS协议、JWT等措施来保证API的安全性。最后,在API文档方面,应该使用Swagger等工具来生成API文档,并提供清晰的示例和定期更新文档。通过遵循这些原则和最佳实践,可以设计出符合RESTful API标准的PHP API,提高API的可用性和可访问性。
API的路由和控制器
在PHP API开发中,路由和控制器是非常重要的组成部分。路由用于将请求路由到相应的控制器方法,控制器则负责处理请求并返回响应。在本文中,我们将探讨如何在PHP中实现API的路由和控制器,并提供一些实用的技巧和最佳实践。
一、路由
路由是将请求路由到相应的控制器方法的过程。在PHP中,可以使用一些现成的路由框架来实现路由功能,例如Laravel、Symfony等。这些框架提供了强大的路由功能,可以轻松实现路由的定义和管理。下面是一个简单的路由示例:
Route::get('/users', 'UserController@index');
Route::post('/users', 'UserController@store');
Route::get('/users/{id}', 'UserController@show');
Route::put('/users/{id}', 'UserController@update');
Route::delete('/users/{id}', 'UserController@destroy');
在上面的代码中,我们定义了一组路由,分别对应了不同的HTTP动词和URI。当请求到达应用程序时,路由将根据请求的HTTP方法和URI来决定将请求路由到哪个控制器方法中。
除了使用现成的路由框架外,我们也可以手动实现路由功能。下面是一个简单的路由类示例:
class Router {protected $routes = [];public function addRoute($method, $uri, $handler) {$this->routes[] = ['method' => $method,'uri' => $uri,'handler' => $handler];}public function dispatch($method, $uri) {foreach ($this->routes as $route) {if ($route['method'] == $method && preg_match($route['uri'], $uri, $matches)) {array_shift($matches);$handler = $route['handler'];return call_user_func_array($handler, $matches);}}return null;}
}
在上面的代码中,我们定义了一个Router类,该类包含两个方法:addRoute和dispatch。addRoute方法用于添加路由规则,dispatch方法用于将请求路由到相应的控制器方法中。当调用dispatch方法时,路由将遍历所有添加的路由规则,并使用正则表达式匹配URI。如果找到匹配的路由规则,则调用相应的控制器方法并传递匹配的参数。
二、控制器
控制器是处理请求并返回响应的组件。在PHP中,控制器通常是一个类,包含多个方法,每个方法对应一个API端点。下面是一个简单的控制器示例:
class UserController {public function index() {$users = User::all();return response()->json($users);}public function show($id) {$user = User::find($id);return response()->json($user);}public function store(Request $request) {$user = new User;$user->name = $request->input('name');$user->email = $request->input('email');$user->save();return response()->json($user);}public function update(Request $request, $id) {$user = User::find($id);$user->name = $request->input('name');$user->email = $request->input('email');$user->save();return response()->json($user);}public function destroy($id) {User::destroy($id);return response()->json(['success' => true]);}
}
在上面的代码中,我们定义了一个UserController类,该类包含了5个方法,分别对应了不同的API端点。每个方法接收不同的参数,并处理相应的业务逻辑。例如,index方法返回所有用户的列表,show方法返回指定ID的用户信息,store方法创建新用户等等。
在控制器中,我们通常使用一些现成的响应库来构建响应。例如,在上面的代码中,我们使用了Laravel框架提供的response()函数来构建JSON响应。
三、最佳实践
在实现API的路由和控制器时,有一些最佳实践可以帮助我们提高代码的可读性和可维护性。下面是一些值得注意的事项:
- 使用RESTful API风格
RESTful API是一种常见的API设计风格,它将每个API端点映射到不同的HTTP动词和URI上。例如,在上面的示例中,我们将所有的用户列表映射到GET /users上,将创建新用户映射到POST /users上,将更新用户信息映射到PUT /users/{id}上等等。使用RESTful API风格可以使API更加符合直觉,并提高可读性和可维护性。
- 使用现成的路由和控制器框架
在PHP中,有许多现成的路由和控制器框架可供选择,例如Laravel、Symfony等。使用这些框架可以大大简化路由和控制器的编写,并提供一些实用的功能,例如中间件、参数验证等等。
- 将控制器方法拆分为多个小方法
在控制器中,通常会有多个方法,每个方法对应一个API端点。为了提高代码的可读性和可维护性,我们可以将每个控制器方法拆分为多个小方法,并在主方法中调用这些小方法。这样可以使每个方法的职责更加明确,并避免出现过于庞大的控制器方法。
- 使用依赖注入
在控制器中,通常会涉及到一些外部依赖,例如数据库连接、缓存等等。为了使代码更加灵活和可测试,我们可以使用依赖注入来管理这些依赖。例如,在上面的示例中,我们可以将User模型的实例注入到控制器中,而不是在控制器中直接实例化。
总结:
在本文中,我们探讨了如何在PHP中实现API的路由和控制器,并提供了一些实用的技巧和最佳实践。实现API的路由和控制器是PHP API开发中非常重要的一部分,正确使用路由和控制器可以使API更加直观和易于维护。同时,我们也强烈建议使用现成的路由和控制器框架,并使用一些最佳实践来提高代码的可读性和可维护性。
API的认证和授权
API认证和授权是现代Web应用程序开发中不可或缺的一部分。在本文中,我们将探讨如何使用PHP开发API并实现API认证和授权。我们将首先讨论API认证和授权的概念,然后介绍一些常见的API认证和授权机制,最后我们将展示如何使用PHP来实现这些机制。
一、API认证和授权的概念
API认证是一种验证API请求的身份的过程。在API认证中,客户端必须提供一些凭据来证明其身份,例如用户名和密码、API密钥或令牌等。API认证的目的是确保只有授权的客户端可以访问API。
API授权是一种控制API访问权限的过程。在API授权中,API服务器会检查客户端的凭据,并根据客户端的身份和角色来确定其是否有权访问API中的资源。API授权的目的是确保只有授权的客户端可以执行特定的操作或访问特定的资源。
二、常见的API认证和授权机制
- HTTP基本认证
HTTP基本认证是一种简单的API认证机制,它使用Base64编码的用户名和密码来验证客户端的身份。在HTTP基本认证中,客户端会在每个API请求中包含一个Authorization头,该头包含Base64编码的用户名和密码。API服务器会解码该头并验证客户端的身份。但是,HTTP基本认证的缺点是,用户名和密码是明文传输的,容易被中间人攻击者窃取。
- HMAC认证
HMAC认证是一种安全的API认证机制,它使用散列消息认证码(HMAC)来验证客户端的身份。在HMAC认证中,客户端会将请求的数据和一个秘钥结合起来生成一个HMAC值,并将该值包含在API请求中。API服务器会使用相同的秘钥和请求数据生成一个HMAC值,并比较两个HMAC值是否相等。如果相等,则API请求是有效的。HMAC认证的优点是,它可以避免中间人攻击和重放攻击。
- OAuth认证
OAuth认证是一种流行的API认证和授权机制,它允许用户授权第三方应用程序访问其受保护的资源,而无需共享其凭据。OAuth认证的方式是,客户端向API服务器请求一个访问令牌,该令牌包含客户端所需的访问权限和有效期。API服务器会向用户显示一张登录页面,用户可以登录并授权客户端访问其受保护的资源。一旦用户授权,API服务器会生成一个访问令牌并将其发送给客户端。客户端在每个API请求中都需要包含该令牌。API服务器会验证令牌的有效性并根据令牌的权限来授权客户端访问资源。
- JSON Web Token(JWT)认证
JWT认证是一种基于令牌的API认证机制,它使用JSON Web Token(JWT)来验证客户端的身份。JWT是一种安全的、自包含的令牌,它包含了一些元数据和用户声明。在JWT认证中,客户端在每个API请求中都需要包含一个JWT令牌。API服务器会验证令牌的有效性,并根据令牌中的声明来授权客户端访问资源。JWT认证的优点是,令牌是自包含的,不需要服务器存储令牌的状态。
三、使用PHP实现API认证和授权
现在,我们将介绍如何使用PHP实现API认证和授权。我们将以JWT认证为例演示如何实现API认证和授权。
- 生成JWT令牌
首先,我们需要安装一个JWT库,例如php-jwt。然后,我们可以使用以下代码生成一个JWT令牌:
require_once('vendor/autoload.php');use \Firebase\JWT\JWT;$key = "example_key";
$payload = array("user_id" => 1234,"username" => "example_user","exp" => time() + 3600
);$jwt = JWT::encode($payload, $key);
echo $jwt;
在上面的示例中,我们使用了一个密钥和一些有效载荷数据来生成JWT令牌。有效载荷通常包含一些有关用户身份和权限的信息,例如用户ID和用户名。我们还设置了令牌的过期时间为1小时。
- 验证JWT令牌
接下来,我们需要编写代码来验证客户端的JWT令牌。我们可以使用以下代码来验证JWT令牌:
require_once('vendor/autoload.php');use \Firebase\JWT\JWT;$key = "example_key";
$jwt = $_SERVER['HTTP_AUTHORIZATION'];try {$decoded = JWT::decode($jwt, $key, array('HS256'));// 验证成功,进行授权操作
} catch (Exception $e) {// 验证失败,返回错误信息http_response_code(401);echo json_encode(array("message" => "无效的令牌"));
}
在上面的代码中,我们从HTTP头中获取JWT令牌,并使用相同的密钥和算法对其进行解码和验证。如果验证成功,我们可以进行授权操作。如果验证失败,我们将返回一个401错误。
四、总结
API认证和授权是现代Web应用程序开发中不可或缺的一部分。在本文中,我们介绍了API认证和授权的概念,并介绍了一些常见的API认证和授权机制。我们还演示了如何使用PHP实现JWT认证。实际上,PHP提供了许多其他API认证和授权机制的库和工具,例如OAuth2服务器和OpenID Connect。选择适合您的应用程序的API认证和授权机制非常重要,因为它可以影响您的应用程序的安全性和可靠性。
相关文章:

详解API开发【电商平台API封装商品详情SKU数据接口开发】
1、电商API开发 RESTful API的设计 RESTful API是一种通过HTTP协议发送和接收数据的API设计风格。它基于一些简单的原则,如使用HTTP动词来操作资源、使用URI来标识资源、使用HTTP状态码来表示操作结果等等。在本文中,我们将探讨如何设计一个符合RESTfu…...

后端项目连接数据库-添加MyBatis依赖并检测是否成功
一.在pom.xml添加Mybatis相关依赖 在Spring Boot项目中,编译时会自动加载项目依赖,然后使用依赖包。 需要在根目录下pom.xml文件中添加Mybatis依赖项 <!-- Mybatis整合Spring Boot的依赖项 --> <dependency><groupId>org.mybatis.s…...

C++ CryptoPP使用RSA加解密
Crypto (CryptoPP) 是一个用于密码学和加密的 C 库。它是一个开源项目,提供了大量的密码学算法和功能,包括对称加密、非对称加密、哈希函数、消息认证码 (MAC)、数字签名等。Crypto 的目标是提供高性能和可靠的密码学工具,以满足软件开发中对…...

从实践角度深入探究数据驱动和关键字驱动测试方法!
数据驱动 数据驱动,指在软件测试领域当中的数据驱动测试(Data-Driven Testing,简称DDT)是⼀种软件测试⽅法,在不同的数据下重复执⾏相同顺序的测试步骤,测试脚本从数据源读取测试数据,⽽不使⽤…...

Unity收费对谁影响最大
Unity的收费政策对以下几类人群影响最大: 游戏开发商:Unity收费政策中最直接的影响对象就是游戏开发商。对于那些使用Unity引擎制作游戏的开发商来说,他们将需要考虑新的许可证费用和服务费用,这可能会对他们的盈利和发展产生影响…...

信号收尾.
sigaction 信号捕捉 它也是信号捕捉,不仅能处理普通信号还能处理实时信号,但我们不管实时信号 我们发现函数名和形参中结构体名一样都是sigaction,这在c/c中允许吗? 不建议,但是可以 signo你要捕捉几号信号 输入型参…...

maven 常用命令解析
目录 maven 是什么 Maven 目录结构 maven 常用命令解析 mvn clean mvn validate mvn compile mvn test mvn package mvn verify mvn install mvn site mvn deploy maven 是什么 Maven 是一个流行的项目管理和构建工具,用于帮助开发人员管理 Java 项目的…...

ESP32-Web-Server编程-JS 基础 1
ESP32-Web-Server编程-JS 基础 1 概述 前述分别在 HTML 基础 和 CSS 基础 中介绍了 HTML、CSS 的基本内容。HTML 定义了网页中包含哪些对象,CSS 定义了对象的显示样式。JavaScript(LiveScript)是一种运行于客户端的解释性脚本语言,使 HTML 页面更具动态…...
代码随想录算法训练营第23天|● 669. 修剪二叉搜索树 ● 108.将有序数组转换为二叉搜索树 ● 538.把二叉搜索树转换为累加树 ● 总结篇
108. 将有序数组转换为二叉搜索树 简单 给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。 高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。 示例 1: …...
UniApp 中的 u-input 属性讲解
在 UniApp 中,u-input 是一个常用的组件,用于接收用户的输入。它具有多种属性,用于控制输入框的样式和行为。下面我将为您讲解一些常用的 u-input 属性。 基本属性 value:表示输入框的初始值,可以使用 v-model 进行双…...

解决方案:新版WPS-右键粘贴值到可见单元格没有了
WPS筛序后复制,并且粘贴到可见单元格 (如果直接粘贴数据会乱掉) 旧版WPS,右键就能出现 但是新版WPS不是在这里(方法1) 新版WPS(方法2) 视频详细教程链接:解决方案&…...
pat模拟题—7-11 两个序列的中位数
一个长度为n(n⩾1)的升序序列S,处在第2n个位置的数称为序列S的中位数(median number),例如,序列S1{10,13,14,16,18,19}的中位数是14。两个序列的中位数是它们所有元素的升序序列的中位数,例如,S2{2,4,8,9,20,21},则S1和S2的中位数是13。现有…...
Java中的i++是原子操作吗?
我们都知道i分为三步进行,分别是1:取到当前i的值,2:,3:将最终结果赋值 因此我们可通过创建两个线程,对同一个变量count,一个线程对count进行递增操作,另一个线程对count进行递减操作。每个线程…...
git commit message 书写规范
在使用 Git 提交时,遵循良好的提交消息规范可以提高代码的可读性和可维护性。以下是一些常见的 Git 提交消息书写规范: 提交消息格式:一个提交消息通常包含三个部分:标题、空行和正文。它们之间使用空行分隔。 复制 <标题>&…...
sql 注入 ctf wiki
部分转载ctf-wiki 判闭合形式: 哪个报错就是哪种 1,1’,1’‘,1’,1’(双引号带括号) 万能密码: admin’ – admin’ # admin’/* ’ or 11– ’ or 11# ’ or 11/* ) or ‘1’1– ) or (‘1’1– 数据库名: SEL…...

Flutter创建TabBar
使用TabBar和TabBarView来创建一个包含"首页"、"分类"和"我的"的TabBar。每个Tab对应一个Tab控件,TabBarView中的每个页面对应一个Widget。 1.Tab使用自定义图标和颜色 一般UI设计的图会带渐变色之类的,应该保持图片的原…...

双流网络论文精读笔记
精读视频:双流网络论文逐段精读【论文精读】_哔哩哔哩_bilibili Two-Stream Convolutional Networks for Action Recognition in Videos 传统的神经网络难以学习到物体的运动信息,双流网络则通过光流将物体运动信息抽取出来再传递给神经网络 给模型提供…...

机器人与3D视觉 Robotics Toolbox Python 一 安装 Robotics Toolbox Python
一 安装python 库 前置条件需要 Python > 3.6,使用pip 安装 pip install roboticstoolbox-python测试安装是否成功 import roboticstoolbox as rtb print(rtb.__version__)输出结果 二 Robotics Toolbox Python样例程序 加载机器人模型 加载由URDF文件定义…...

JS之Object.defineProperty方法
给对象添加属性的方法有许多,这次让我为大家介绍一种给对象添加属性的静态方法吧! 语法:Objcet.defineProperty(对象的名称,“添加的键名”,{value:键值}) const obj {name:"张三",age:18}// 我…...

卷积神经网络(CNN)注意力检测
文章目录 一、前言二、前期工作1. 设置GPU(如果使用的是CPU可以忽略这步)2. 导入数据3. 查看数据 二、数据预处理1.加载数据2. 可视化数据4. 配置数据集 三、调用官方网络模型四、设置动态学习率五、编译六、训练模型七、模型评估1. Accuracy与Loss图2. …...

iOS 26 携众系统重磅更新,但“苹果智能”仍与国行无缘
美国西海岸的夏天,再次被苹果点燃。一年一度的全球开发者大会 WWDC25 如期而至,这不仅是开发者的盛宴,更是全球数亿苹果用户翘首以盼的科技春晚。今年,苹果依旧为我们带来了全家桶式的系统更新,包括 iOS 26、iPadOS 26…...

Debian系统简介
目录 Debian系统介绍 Debian版本介绍 Debian软件源介绍 软件包管理工具dpkg dpkg核心指令详解 安装软件包 卸载软件包 查询软件包状态 验证软件包完整性 手动处理依赖关系 dpkg vs apt Debian系统介绍 Debian 和 Ubuntu 都是基于 Debian内核 的 Linux 发行版ÿ…...
线程与协程
1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指:像函数调用/返回一样轻量地完成任务切换。 举例说明: 当你在程序中写一个函数调用: funcA() 然后 funcA 执行完后返回&…...

C++ 求圆面积的程序(Program to find area of a circle)
给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...
06 Deep learning神经网络编程基础 激活函数 --吴恩达
深度学习激活函数详解 一、核心作用 引入非线性:使神经网络可学习复杂模式控制输出范围:如Sigmoid将输出限制在(0,1)梯度传递:影响反向传播的稳定性二、常见类型及数学表达 Sigmoid σ ( x ) = 1 1 +...

多模态大语言模型arxiv论文略读(108)
CROME: Cross-Modal Adapters for Efficient Multimodal LLM ➡️ 论文标题:CROME: Cross-Modal Adapters for Efficient Multimodal LLM ➡️ 论文作者:Sayna Ebrahimi, Sercan O. Arik, Tejas Nama, Tomas Pfister ➡️ 研究机构: Google Cloud AI Re…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...

零基础在实践中学习网络安全-皮卡丘靶场(第九期-Unsafe Fileupload模块)(yakit方式)
本期内容并不是很难,相信大家会学的很愉快,当然对于有后端基础的朋友来说,本期内容更加容易了解,当然没有基础的也别担心,本期内容会详细解释有关内容 本期用到的软件:yakit(因为经过之前好多期…...

Reasoning over Uncertain Text by Generative Large Language Models
https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...
代码随想录刷题day30
1、零钱兑换II 给你一个整数数组 coins 表示不同面额的硬币,另给一个整数 amount 表示总金额。 请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额,返回 0 。 假设每一种面额的硬币有无限个。 题目数据保证结果符合 32 位带…...