From 239b565aa9cc17fcbad7626b7737e66534216f23 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=A4=A7=E7=9F=B3=E5=A4=B4?= Date: Wed, 1 Jan 2025 20:14:47 +0800 Subject: [PATCH] =?UTF-8?q?v3.2.2025.0101=20=E6=94=B9=E8=BF=9B=E5=BA=94?= =?UTF-8?q?=E7=94=A8=E7=BA=BF=E7=A8=8B=E6=B1=A0=E6=80=A7=E8=83=BD=E9=87=87?= =?UTF-8?q?=E9=9B=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ClientTest/ClientTest.csproj | 4 +- ClientTest/StarFactoryTests.cs | 1 + DeployAgent/DeployAgent.csproj | 4 +- Installer/Installer.csproj | 2 +- Plugins/MySqlAgent/MySqlAgent.csproj | 4 +- Plugins/NetworkDetect/NetworkDetect.csproj | 2 +- Readme.MD | 25 ++--- Samples/TestA/TestA.csproj | 6 +- Samples/TestB/TestB.csproj | 6 +- Samples/TestC/TestC.csproj | 4 +- StarAgent/StarAgent.csproj | 6 +- StarAgentTool/StarAgentTool.csproj | 4 +- StarGateway/StarGateway.csproj | 2 +- Stardust.Data/Entity/应用系统.Biz.cs | 2 +- Stardust.Data/Platform/星系项目.Biz.cs | 2 +- Stardust.Data/Stardust.Data.csproj | 4 +- .../Stardust.Extensions.csproj | 2 +- Stardust.Server/Controllers/ApiController.cs | 2 +- Stardust.Server/Stardust.Server.csproj | 8 +- Stardust.ServerTests/Controllers/ApiTests.cs | 11 +- .../Controllers/OAuthControllerTests.cs | 102 +++++++++--------- .../Services/AppServiceTests.cs | 2 +- Stardust.Web/Stardust.Web.csproj | 8 +- Stardust/Stardust.csproj | 10 +- Test/Test.csproj | 2 +- 25 files changed, 118 insertions(+), 107 deletions(-) diff --git a/ClientTest/ClientTest.csproj b/ClientTest/ClientTest.csproj index 303ff4a6..39d17972 100644 --- a/ClientTest/ClientTest.csproj +++ b/ClientTest/ClientTest.csproj @@ -21,8 +21,8 @@ - - + + all diff --git a/ClientTest/StarFactoryTests.cs b/ClientTest/StarFactoryTests.cs index a9cf29c1..2d24dd29 100644 --- a/ClientTest/StarFactoryTests.cs +++ b/ClientTest/StarFactoryTests.cs @@ -85,6 +85,7 @@ public class StarFactoryTests public void IocTest() { using var star = new StarFactory("http://127.0.0.1:6600", "test", null); + star.Register(ObjectContainer.Current); var provider = ObjectContainer.Provider; diff --git a/DeployAgent/DeployAgent.csproj b/DeployAgent/DeployAgent.csproj index 0f3c9fc1..9f7b2aca 100644 --- a/DeployAgent/DeployAgent.csproj +++ b/DeployAgent/DeployAgent.csproj @@ -1,4 +1,4 @@ - + Exe @@ -6,7 +6,7 @@ 星尘发布 自动下载代码,编译后打包输出并推送发布中心。 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 1.0 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) diff --git a/Installer/Installer.csproj b/Installer/Installer.csproj index 2ec24ebb..44dedfd8 100644 --- a/Installer/Installer.csproj +++ b/Installer/Installer.csproj @@ -6,7 +6,7 @@ 安装器 安装辅助工具 新生命开发团队 - ©2002-2023 NewLife + ©2002-2025 NewLife 1.0 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) diff --git a/Plugins/MySqlAgent/MySqlAgent.csproj b/Plugins/MySqlAgent/MySqlAgent.csproj index 2c1fe440..c3cc5f1b 100644 --- a/Plugins/MySqlAgent/MySqlAgent.csproj +++ b/Plugins/MySqlAgent/MySqlAgent.csproj @@ -5,7 +5,7 @@ MySql助手 监控MySql性能,上报星尘平台 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 1.0 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) @@ -20,7 +20,7 @@ - + diff --git a/Plugins/NetworkDetect/NetworkDetect.csproj b/Plugins/NetworkDetect/NetworkDetect.csproj index 78efdc2c..89536e73 100644 --- a/Plugins/NetworkDetect/NetworkDetect.csproj +++ b/Plugins/NetworkDetect/NetworkDetect.csproj @@ -5,7 +5,7 @@ 网络监测 检测网络,如果长期不可用,则重启系统,主要应用于嵌入式工控机 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 1.0 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) diff --git a/Readme.MD b/Readme.MD index ab9551b8..3c0deccc 100644 --- a/Readme.MD +++ b/Readme.MD @@ -86,18 +86,18 @@ Sidecar设计模式正在收到越来越多的关注和采用。作为Service Me ``` ## 新生命项目矩阵 -各项目默认支持net7.0/netstandard2.1/netstandard2.0/net4.61,旧版(2022.1225)支持net4.5/net4.0/net2.0 +各项目默认支持net9.0/netstandard2.1/netstandard2.0/net4.62/net4.5,旧版(2024.0801)支持net4.0/net2.0 | 项目 | 年份 | 说明 | | :--------------------------------------------------------------: | :---: | -------------------------------------------------------------------------------------- | | 基础组件 | | 支撑其它中间件以及产品项目 | | [NewLife.Core](https://github.com/NewLifeX/X) | 2002 | 核心库,日志、配置、缓存、网络、序列化、APM性能追踪 | -| [NewLife.XCode](https://github.com/NewLifeX/NewLife.XCode) | 2005 | 大数据中间件,单表百亿级,MySql/SQLite/SqlServer/Oracle/TDengine/达梦,自动分表 | +| [NewLife.XCode](https://github.com/NewLifeX/NewLife.XCode) | 2005 | 大数据中间件,单表百亿级,MySql/SQLite/SqlServer/Oracle/PostgreSql/达梦,自动分表 | | [NewLife.Net](https://github.com/NewLifeX/NewLife.Net) | 2005 | 网络库,单机千万级吞吐率(2266万tps),单机百万级连接(400万Tcp) | -| [NewLife.Remoting](https://github.com/NewLifeX/NewLife.Remoting) | 2011 | RPC通信框架,内网高吞吐或物联网硬件设备场景 | +| [NewLife.Remoting](https://github.com/NewLifeX/NewLife.Remoting) | 2011 | RPC通信框架,内网高吞吐,物联网设备低开销易接入 | | [NewLife.Cube](https://github.com/NewLifeX/NewLife.Cube) | 2010 | 魔方快速开发平台,集成了用户权限、SSO登录、OAuth服务端等,单表100亿级项目验证 | | [NewLife.Agent](https://github.com/NewLifeX/NewLife.Agent) | 2008 | 服务管理组件,把应用安装成为操作系统守护进程,Windows服务、Linux的Systemd | -| [NewLife.Zero](https://github.com/NewLifeX/NewLife.Zero) | 2020 | Zero零代脚手架,基于NewLife组件生态的项目模板,Web、WebApi、Service | +| [NewLife.Zero](https://github.com/NewLifeX/NewLife.Zero) | 2020 | Zero零代脚手架,基于NewLife组件生态的项目模板NewLife.Templates,Web、WebApi、Service | | 中间件 | | 对接知名中间件平台 | | [NewLife.Redis](https://github.com/NewLifeX/NewLife.Redis) | 2017 | Redis客户端,微秒级延迟,百万级吞吐,丰富的消息队列,百亿级数据量项目验证 | | [NewLife.RocketMQ](https://github.com/NewLifeX/NewLife.RocketMQ) | 2018 | RocketMQ纯托管客户端,支持Apache RocketMQ和阿里云消息队列,十亿级项目验 | @@ -105,29 +105,30 @@ Sidecar设计模式正在收到越来越多的关注和采用。作为Service Me | [NewLife.IoT](https://github.com/NewLifeX/NewLife.IoT) | 2022 | IoT标准库,定义物联网领域的各种通信协议标准规范 | | [NewLife.Modbus](https://github.com/NewLifeX/NewLife.Modbus) | 2022 | ModbusTcp/ModbusRTU/ModbusASCII,基于IoT标准库实现,支持IoT平台和IoTEdge | | [NewLife.Siemens](https://github.com/NewLifeX/NewLife.Siemens) | 2022 | 西门子PLC协议,基于IoT标准库实现,支持IoT平台和IoTEdge | -| [NewLife.Map](https://github.com/NewLifeX/NewLife.Map) | 2022 | 地图组件库,封装百度地图、高德地图和腾讯地图 | -| [NewLife.IP](https://github.com/NewLifeX/NewLife.IP) | 2022 | IP地址库,IP地址转物理地址 | +| [NewLife.Map](https://github.com/NewLifeX/NewLife.Map) | 2022 | 地图组件库,封装百度地图、高德地图、腾讯地图、天地图 | +| [NewLife.Audio](https://github.com/NewLifeX/NewLife.Audio) | 2023 | 音频编解码库,PCM/ADPCMA/G711A/G722U/WAV/AAC | | 产品平台 | | 产品平台级,编译部署即用,个性化自定义 | -| [AntJob](https://github.com/NewLifeX/AntJob) | 2019 | 蚂蚁调度,分布式大数据计算平台(实时/离线),蚂蚁搬家分片思想,万亿级数据量项目验证 | | [Stardust](https://github.com/NewLifeX/Stardust) | 2018 | 星尘,分布式服务平台,节点管理、APM监控中心、配置中心、注册中心、发布中心 | +| [AntJob](https://github.com/NewLifeX/AntJob) | 2019 | 蚂蚁调度,分布式大数据计算平台(实时/离线),蚂蚁搬家分片思想,万亿级数据量项目验证 | | [NewLife.ERP](https://github.com/NewLifeX/NewLife.ERP) | 2021 | 企业ERP,产品管理、客户管理、销售管理、供应商管理 | | [CrazyCoder](https://github.com/NewLifeX/XCoder) | 2006 | 码神工具,众多开发者工具,网络、串口、加解密、正则表达式、Modbus | +| [EasyIO](https://github.com/NewLifeX/EasyIO) | 2023 | 简易文件存储,支持分布式系统中文件集中存储。 | | [XProxy](https://github.com/NewLifeX/XProxy) | 2005 | 产品级反向代理,NAT代理、Http代理 | | [HttpMeter](https://github.com/NewLifeX/HttpMeter) | 2022 | Http压力测试工具 | | [GitCandy](https://github.com/NewLifeX/GitCandy) | 2015 | Git源代码管理系统 | | [SmartOS](https://github.com/NewLifeX/SmartOS) | 2014 | 嵌入式操作系统,完全独立自主,支持ARM Cortex-M芯片架构 | | [SmartA2](https://github.com/NewLifeX/SmartA2) | 2019 | 嵌入式工业计算机,物联网边缘网关,高性能.NET6主机,应用于工业、农业、交通、医疗 | -| 菲凡物联FIoT | 2020 | 物联网整体解决方案,建筑、环保、农业,软硬件及大数据分析一体化,单机十万级点位项目验证 | -| NewLife.UWB | 2020 | 厘米级(10~20cm)高精度室内定位,软硬件一体化,与其它系统联动,大型展厅项目验证 | +| FIoT物联网平台 | 2020 | 物联网整体解决方案,建筑、环保、农业,软硬件及大数据分析一体化,单机十万级点位项目验证 | +| UWB高精度室内定位 | 2020 | 厘米级(10~20cm)高精度室内定位,软硬件一体化,与其它系统联动,大型展厅项目验证 | ## 新生命开发团队 ![XCode](https://newlifex.com/logo.png) 新生命团队(NewLife)成立于2002年,是新时代物联网行业解决方案提供者,致力于提供软硬件应用方案咨询、系统架构规划与开发服务。 -团队主导的开源NewLife系列组件已被广泛应用于各行业,Nuget累计下载量高达60余万次。 -团队开发的大数据核心组件NewLife.XCode、蚂蚁调度计算平台AntJob、星尘分布式平台Stardust、缓存队列组件NewLife.Redis以及物联网平台NewLife.IoT,均成功应用于电力、高校、互联网、电信、交通、物流、工控、医疗、文博等行业,为客户提供了大量先进、可靠、安全、高质量、易扩展的产品和系统集成服务。 +团队主导的80多个开源项目已被广泛应用于各行业,Nuget累计下载量高达300余万次。 +团队开发的大数据中间件NewLife.XCode、蚂蚁调度计算平台AntJob、星尘分布式平台Stardust、缓存队列组件NewLife.Redis以及物联网平台FIoT,均成功应用于电力、高校、互联网、电信、交通、物流、工控、医疗、文博等行业,为客户提供了大量先进、可靠、安全、高质量、易扩展的产品和系统集成服务。 -我们将不断通过服务的持续改进,成为客户长期信赖的合作伙伴,通过不断的创新和发展,成为国内优秀的IT服务供应商。 +我们将不断通过服务的持续改进,成为客户长期信赖的合作伙伴,通过不断的创新和发展,成为国内优秀的IoT服务供应商。 `新生命团队始于2002年,部分开源项目具有20年以上漫长历史,源码库保留有2010年以来所有修改记录` 网站:https://newlifex.com diff --git a/Samples/TestA/TestA.csproj b/Samples/TestA/TestA.csproj index 0dfb6960..785b0b77 100644 --- a/Samples/TestA/TestA.csproj +++ b/Samples/TestA/TestA.csproj @@ -1,10 +1,10 @@ - + Exe net8.0 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 1.0 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) @@ -18,7 +18,7 @@ - + diff --git a/Samples/TestB/TestB.csproj b/Samples/TestB/TestB.csproj index 0630c0a3..2e63f331 100644 --- a/Samples/TestB/TestB.csproj +++ b/Samples/TestB/TestB.csproj @@ -1,10 +1,10 @@ - + Exe net8.0 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 1.0 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) @@ -18,7 +18,7 @@ - + diff --git a/Samples/TestC/TestC.csproj b/Samples/TestC/TestC.csproj index ff9a01f0..cc4c17ff 100644 --- a/Samples/TestC/TestC.csproj +++ b/Samples/TestC/TestC.csproj @@ -1,10 +1,10 @@ - + Exe net8.0 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 1.0 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) diff --git a/StarAgent/StarAgent.csproj b/StarAgent/StarAgent.csproj index fb252ae8..ffd1f4c6 100644 --- a/StarAgent/StarAgent.csproj +++ b/StarAgent/StarAgent.csproj @@ -1,4 +1,4 @@ - + Exe @@ -6,7 +6,7 @@ 星尘代理 星尘,分布式资源调度,部署于每一个节点,连接服务端,支持节点监控、远程发布。 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 3.1 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) @@ -47,7 +47,7 @@ - + diff --git a/StarAgentTool/StarAgentTool.csproj b/StarAgentTool/StarAgentTool.csproj index b48fbff7..6818e51c 100644 --- a/StarAgentTool/StarAgentTool.csproj +++ b/StarAgentTool/StarAgentTool.csproj @@ -1,4 +1,4 @@ - + Exe @@ -7,7 +7,7 @@ 星尘代理 星尘,分布式资源调度,部署于每一个节点,连接服务端,支持节点监控、远程发布。 新生命开发团队 - ©2002-2022 NewLife + ©2002-2025 NewLife 2.5 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) diff --git a/StarGateway/StarGateway.csproj b/StarGateway/StarGateway.csproj index 2c395072..8138efff 100644 --- a/StarGateway/StarGateway.csproj +++ b/StarGateway/StarGateway.csproj @@ -6,7 +6,7 @@ 星尘网关 星尘网关,转发网络请求,实现路由切换。 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 3.0 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) diff --git a/Stardust.Data/Entity/应用系统.Biz.cs b/Stardust.Data/Entity/应用系统.Biz.cs index 7f7c1de2..e2684b40 100644 --- a/Stardust.Data/Entity/应用系统.Biz.cs +++ b/Stardust.Data/Entity/应用系统.Biz.cs @@ -261,8 +261,8 @@ public partial class App : Entity /// public Boolean MatchIp(String ip) { - if (ip.IsNullOrEmpty()) return false; if (WhiteIPs.IsNullOrEmpty() && BlackIPs.IsNullOrEmpty()) return true; + if (ip.IsNullOrEmpty()) return false; // 黑名单优先,黑名单里面有的,直接拒绝 var bs = (BlackIPs + "").Split(",", ";"); diff --git a/Stardust.Data/Platform/星系项目.Biz.cs b/Stardust.Data/Platform/星系项目.Biz.cs index c6750180..ff067170 100644 --- a/Stardust.Data/Platform/星系项目.Biz.cs +++ b/Stardust.Data/Platform/星系项目.Biz.cs @@ -171,8 +171,8 @@ public partial class GalaxyProject : Entity, ITenantSource /// public Boolean MatchIp(String ip) { - if (ip.IsNullOrEmpty()) return false; if (WhiteIPs.IsNullOrEmpty() && BlackIPs.IsNullOrEmpty()) return true; + if (ip.IsNullOrEmpty()) return false; // 黑名单优先,黑名单里面有的,直接拒绝 var bs = (BlackIPs + "").Split(",", ";"); diff --git a/Stardust.Data/Stardust.Data.csproj b/Stardust.Data/Stardust.Data.csproj index edb8b371..d8c1b731 100644 --- a/Stardust.Data/Stardust.Data.csproj +++ b/Stardust.Data/Stardust.Data.csproj @@ -1,4 +1,4 @@ - + netstandard2.1 @@ -41,7 +41,7 @@ - + diff --git a/Stardust.Extensions/Stardust.Extensions.csproj b/Stardust.Extensions/Stardust.Extensions.csproj index 24e690f0..9b5e1b6c 100644 --- a/Stardust.Extensions/Stardust.Extensions.csproj +++ b/Stardust.Extensions/Stardust.Extensions.csproj @@ -6,7 +6,7 @@ 星尘分布式服务扩展 星尘,分布式服务框架扩展。节点管理,监控中心,配置中心,发布中心,注册中心 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 3.2 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) diff --git a/Stardust.Server/Controllers/ApiController.cs b/Stardust.Server/Controllers/ApiController.cs index 8cdef5c8..55354a8f 100644 --- a/Stardust.Server/Controllers/ApiController.cs +++ b/Stardust.Server/Controllers/ApiController.cs @@ -29,7 +29,7 @@ public class ApiController : ControllerBase var asmx = AssemblyX.Entry; var conn = HttpContext.Connection; var remote = conn.RemoteIpAddress; - if (remote.IsIPv4MappedToIPv6) remote = remote.MapToIPv4(); + if (remote != null && remote.IsIPv4MappedToIPv6) remote = remote.MapToIPv4(); var ip = HttpContext.GetUserHost(); var rs = new diff --git a/Stardust.Server/Stardust.Server.csproj b/Stardust.Server/Stardust.Server.csproj index c00951cd..e8b94938 100644 --- a/Stardust.Server/Stardust.Server.csproj +++ b/Stardust.Server/Stardust.Server.csproj @@ -1,4 +1,4 @@ - + net8.0 @@ -6,7 +6,7 @@ 星尘服务平台 星尘,分布式服务框架。节点管理,监控中心,配置中心,发布中心,注册中心 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 3.0 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) @@ -45,8 +45,8 @@ - - + + diff --git a/Stardust.ServerTests/Controllers/ApiTests.cs b/Stardust.ServerTests/Controllers/ApiTests.cs index f5ea15c4..c753f726 100644 --- a/Stardust.ServerTests/Controllers/ApiTests.cs +++ b/Stardust.ServerTests/Controllers/ApiTests.cs @@ -31,10 +31,13 @@ public class ApiTests var response = await client.GetAsync("api", new { state }); response.EnsureSuccessStatusCode(); - Assert.Equal("application/json", response.Content.Headers.ContentType + ""); + Assert.StartsWith("application/json", response.Content.Headers.ContentType + ""); var rs = await client.GetAsync>("api", new { state }); - Assert.Null(rs["state"]); + if (state == null) + Assert.Null(rs["state"]); + else + Assert.NotNull(rs["state"]); } [Theory(DisplayName = "信息测试")] @@ -44,7 +47,7 @@ public class ApiTests { var client = _server.CreateClient(); - var rs = await client.GetAsync>("api/info", new { state }); + var rs = await client.GetAsync>("api", new { state }); if (state.IsNullOrEmpty()) Assert.Null(rs["state"]); else @@ -59,7 +62,7 @@ public class ApiTests { var client = _server.CreateClient(); - var rs = await client.PostAsync("api/info2", state.ToHex()); + var rs = await client.PostAsync("api/info2", state.ToHex()); Assert.NotNull(rs); } } \ No newline at end of file diff --git a/Stardust.ServerTests/Controllers/OAuthControllerTests.cs b/Stardust.ServerTests/Controllers/OAuthControllerTests.cs index bb7fade2..b7b06fec 100644 --- a/Stardust.ServerTests/Controllers/OAuthControllerTests.cs +++ b/Stardust.ServerTests/Controllers/OAuthControllerTests.cs @@ -4,24 +4,54 @@ using Microsoft.AspNetCore.Hosting; using Microsoft.AspNetCore.TestHost; using NewLife.Remoting; using NewLife.Web; -using Stardust.Models; +using Stardust.Data; using Stardust.Server.Models; using Xunit; -namespace Stardust.Server.Controllers.Tests -{ - public class OAuthControllerTests - { - private readonly TestServer _server; +namespace Stardust.Server.Controllers.Tests; - public OAuthControllerTests() +public class OAuthControllerTests +{ + private readonly TestServer _server; + + public OAuthControllerTests() + { + _server = new TestServer(WebHost.CreateDefaultBuilder() + .UseStartup()); + } + + [Fact] + public async Task Token_password() + { + var app = App.FindByName("stone"); + if (app != null) { - _server = new TestServer(WebHost.CreateDefaultBuilder() - .UseStartup()); + app.Enable = true; + app.Update(); } - [Fact] - public async Task Token_password() + var model = new TokenInModel + { + grant_type = "password", + UserName = "stone", + }; + + var client = _server.CreateClient(); + + var rs = await client.PostAsync("oauth/token", model); + Assert.NotNull(rs); + Assert.NotEmpty(rs.AccessToken); + Assert.NotEmpty(rs.RefreshToken); + Assert.Equal(7200, rs.ExpireIn); + Assert.Equal("JWT", rs.TokenType); + } + + [Fact] + public async Task Token_refresh_token() + { + var client = _server.CreateClient(); + + var refresh_token = ""; { var model = new TokenInModel { @@ -29,51 +59,27 @@ namespace Stardust.Server.Controllers.Tests UserName = "stone", }; - var client = _server.CreateClient(); - var rs = await client.PostAsync("oauth/token", model); Assert.NotNull(rs); - Assert.NotEmpty(rs.AccessToken); Assert.NotEmpty(rs.RefreshToken); - Assert.Equal(7200, rs.ExpireIn); - Assert.Equal("JWT", rs.TokenType); + + refresh_token = rs.RefreshToken; } - [Fact] - public async Task Token_refresh_token() + // 刷新令牌 { - var client = _server.CreateClient(); - - var refresh_token = ""; + var model2 = new TokenInModel { - var model = new TokenInModel - { - grant_type = "password", - UserName = "stone", - }; + grant_type = "refresh_token", + refresh_token = refresh_token, + }; - var rs = await client.PostAsync("oauth/token", model); - Assert.NotNull(rs); - Assert.NotEmpty(rs.RefreshToken); - - refresh_token = rs.RefreshToken; - } - - // 刷新令牌 - { - var model2 = new TokenInModel - { - grant_type = "refresh_token", - refresh_token = refresh_token, - }; - - var rs2 = await client.PostAsync("oauth/token", model2); - Assert.NotNull(rs2); - Assert.NotEmpty(rs2.AccessToken); - Assert.NotEmpty(rs2.RefreshToken); - Assert.Equal(7200, rs2.ExpireIn); - Assert.Equal("JWT", rs2.TokenType); - } + var rs2 = await client.PostAsync("oauth/token", model2); + Assert.NotNull(rs2); + Assert.NotEmpty(rs2.AccessToken); + Assert.NotEmpty(rs2.RefreshToken); + Assert.Equal(7200, rs2.ExpireIn); + Assert.Equal("JWT", rs2.TokenType); } } } \ No newline at end of file diff --git a/Stardust.ServerTests/Services/AppServiceTests.cs b/Stardust.ServerTests/Services/AppServiceTests.cs index fc62957d..4035cc50 100644 --- a/Stardust.ServerTests/Services/AppServiceTests.cs +++ b/Stardust.ServerTests/Services/AppServiceTests.cs @@ -37,7 +37,7 @@ public class AppServiceTests Assert.Equal(app.Id, rs.Id); // 错误验证 - Assert.Throws(() => service.Authorize("test", "yyy", true)); + Assert.Throws(() => service.Authorize("test", "yyy", true)); } [Fact] diff --git a/Stardust.Web/Stardust.Web.csproj b/Stardust.Web/Stardust.Web.csproj index 3f1f6e9d..4c8cd1a6 100644 --- a/Stardust.Web/Stardust.Web.csproj +++ b/Stardust.Web/Stardust.Web.csproj @@ -1,4 +1,4 @@ - + net8.0 @@ -6,7 +6,7 @@ 星尘管理平台 星尘,分布式服务框架。节点管理,监控中心,配置中心,发布中心,注册中心 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 3.0 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) @@ -52,8 +52,8 @@ - - + + diff --git a/Stardust/Stardust.csproj b/Stardust/Stardust.csproj index a2cb5b05..15b79ca4 100644 --- a/Stardust/Stardust.csproj +++ b/Stardust/Stardust.csproj @@ -1,4 +1,4 @@ - + net45;net461;netstandard2.0;netstandard2.1;netcoreapp3.1;net5.0;net6.0;net6.0-windows;net7.0;net7.0-windows;net8.0;net8.0-windows;net9.0;net9.0-windows @@ -6,7 +6,7 @@ 星尘分布式服务核心 星尘,分布式服务框架。节点管理,监控中心,配置中心,发布中心,注册中心 新生命开发团队 - ©2002-2024 NewLife + ©2002-2025 NewLife 3.2 $([System.DateTime]::Now.ToString(`yyyy.MMdd`)) $(VersionPrefix).$(VersionSuffix) @@ -32,7 +32,7 @@ https://github.com/NewLifeX/Stardust git 新生命团队;X组件;NewLife;$(AssemblyName) - 远程发布支持拉起桌面应用 + 改进应用线程池性能采集 MIT true true @@ -119,10 +119,10 @@ - + - + diff --git a/Test/Test.csproj b/Test/Test.csproj index 87bbb93e..2271ae59 100644 --- a/Test/Test.csproj +++ b/Test/Test.csproj @@ -30,7 +30,7 @@ - +