16 Commits

Author SHA1 Message Date
tk
2b15b748b6 chore(release): 2.3.7 2025-06-28 11:45:46 +08:00
4aee3cd210 feat: 转36进制 (#38)
[skip ci]

Co-authored-by: tk <fiyne1a@dingtalk.com>
2025-06-28 11:45:36 +08:00
0a9f93c5d3 chore(release): 2.3.6 (#37)
Co-authored-by: tk <fiyne1a@dingtalk.com>
2025-06-23 09:45:24 +08:00
a288f21679 perf: nuget update (#36)
[skip ci]

Co-authored-by: tk <fiyne1a@dingtalk.com>
2025-06-23 09:44:53 +08:00
c9975472bf chore(release): 2.3.5 (#35)
Co-authored-by: tk <fiyne1a@dingtalk.com>
2025-03-26 15:13:35 +08:00
97c93bd854 perf: nuget update (#34)
[skip ci]

Co-authored-by: tk <fiyne1a@dingtalk.com>
2025-03-26 15:13:08 +08:00
322cbc32df chore(release): 2.3.4 (#33)
Co-authored-by: tk <fiyne1a@dingtalk.com>
2025-03-06 09:55:07 +08:00
fa84cc315b perf: nuget update (#32)
[skip ci]

Co-authored-by: tk <fiyne1a@dingtalk.com>
2025-03-06 09:54:33 +08:00
d4a92aca6f chore(release): 2.3.3 (#31)
Co-authored-by: tk <fiyne1a@dingtalk.com>
2025-01-02 12:03:36 +08:00
a9f3416c37 perf: nuget update (#30)
[skip ci]

Co-authored-by: tk <fiyne1a@dingtalk.com>
2025-01-02 12:03:13 +08:00
890b229683 Merge pull request #29 from nsnail/release
chore(release): 2.3.2
2024-11-25 17:51:14 +08:00
tk
c3c6819a99 chore(release): 2.3.2 2024-11-25 17:50:57 +08:00
efa6a564dc Merge pull request #28 from nsnail/release
chore(release): 2.3.1
2024-11-25 17:39:29 +08:00
tk
7c5b5443cb chore(release): 2.3.1 2024-11-25 17:39:13 +08:00
689d9560a8 fix: 🐛 a stable release of a package should not have a prerelease dependency (#27)
[skip ci]

Co-authored-by: tk <fiyne1a@dingtalk.com>
2024-11-25 17:39:04 +08:00
49de51d649 Merge pull request #26 from nsnail/release
chore(release): 2.3.0
2024-11-25 17:35:51 +08:00
10 changed files with 89 additions and 45 deletions

View File

@ -2,6 +2,30 @@
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
### [2.3.7](https://github.com/nsnail/NSExt/compare/v2.3.2...v2.3.7) (2025-06-28)
### Features
* ✨ 转36进制 ([#38](https://github.com/nsnail/NSExt/issues/38)) ([4aee3cd](https://github.com/nsnail/NSExt/commit/4aee3cd210722ec4861176dd53178f5f72cb2481))
### [2.3.6](https://github.com/nsnail/NSExt/compare/v2.3.2...v2.3.6) (2025-06-23)
### [2.3.5](https://github.com/nsnail/NSExt/compare/v2.3.2...v2.3.5) (2025-03-26)
### [2.3.4](https://github.com/nsnail/NSExt/compare/v2.3.2...v2.3.4) (2025-03-06)
### [2.3.3](https://github.com/nsnail/NSExt/compare/v2.3.2...v2.3.3) (2025-01-02)
### [2.3.2](https://github.com/nsnail/NSExt/compare/v2.3.1...v2.3.2) (2024-11-25)
### [2.3.1](https://github.com/nsnail/NSExt/compare/v2.3.0...v2.3.1) (2024-11-25)
### Bug Fixes
* 🐛 a stable release of a package should not have a prerelease dependency ([#27](https://github.com/nsnail/NSExt/issues/27)) ([689d956](https://github.com/nsnail/NSExt/commit/689d9560a858c0ac308ec198b041fdc23720beba))
## [2.3.0](https://github.com/nsnail/NSExt/compare/v2.2.1...v2.3.0) (2024-11-25) ## [2.3.0](https://github.com/nsnail/NSExt/compare/v2.2.1...v2.3.0) (2024-11-25)

View File

@ -26,7 +26,7 @@
<Title>$(AssemblyName)</Title> <Title>$(AssemblyName)</Title>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="MinVer" Version="6.0.0"> <PackageReference Include="MinVer" Version="6.1.0-beta.1">
<PrivateAssets>all</PrivateAssets> <PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference> </PackageReference>

View File

@ -15,15 +15,15 @@
<PrivateAssets>all</PrivateAssets> <PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference> </PackageReference>
<PackageReference Include="Microsoft.VisualStudio.Threading.Analyzers" Version="17.12.19"> <PackageReference Include="Microsoft.VisualStudio.Threading.Analyzers" Version="17.14.15">
<PrivateAssets>all</PrivateAssets> <PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference> </PackageReference>
<PackageReference Include="Roslynator.Analyzers" Version="4.12.9"> <PackageReference Include="Roslynator.Analyzers" Version="4.13.1">
<PrivateAssets>all</PrivateAssets> <PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference> </PackageReference>
<PackageReference Include="SonarAnalyzer.CSharp" Version="9.32.0.97167"> <PackageReference Include="SonarAnalyzer.CSharp" Version="10.12.0.118525">
<PrivateAssets>all</PrivateAssets> <PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference> </PackageReference>

View File

@ -1,5 +1,5 @@
{ {
"version": "2.3.0", "version": "2.3.7",
"devDependencies": { "devDependencies": {
"cz-git": "^1.11.0", "cz-git": "^1.11.0",
"commitizen": "^4.3.1", "commitizen": "^4.3.1",

View File

@ -1,12 +1,12 @@
<Project Sdk="Microsoft.NET.Sdk"> <Project Sdk="Microsoft.NET.Sdk">
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.12.0"/> <PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.14.1"/>
<PackageReference Include="xunit" Version="2.9.2"/> <PackageReference Include="xunit" Version="2.9.3"/>
<PackageReference Include="xunit.runner.visualstudio" Version="3.0.0-pre.49"> <PackageReference Include="xunit.runner.visualstudio" Version="3.1.1">
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
<PrivateAssets>all</PrivateAssets> <PrivateAssets>all</PrivateAssets>
</PackageReference> </PackageReference>
<PackageReference Include="coverlet.collector" Version="6.0.2"> <PackageReference Include="coverlet.collector" Version="6.0.4">
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
<PrivateAssets>all</PrivateAssets> <PrivateAssets>all</PrivateAssets>
</PackageReference> </PackageReference>

View File

@ -27,7 +27,7 @@ public static class EnumExtensions
var resDescAttr = typeOfField!.GetCustomAttribute<ResourceDescriptionAttribute<T>>(true); var resDescAttr = typeOfField!.GetCustomAttribute<ResourceDescriptionAttribute<T>>(true);
return resDescAttr is null return resDescAttr is null
? Enum.GetName(typeOfEnum, e) ? Enum.GetName(typeOfEnum, e)
: typeof(T).GetProperty(resDescAttr.ResourceName)?.GetValue(default) as string; : typeof(T).GetProperty(resDescAttr.ResourceName)?.GetValue(null) as string;
} }
/// <summary> /// <summary>

View File

@ -36,6 +36,8 @@ public static class IntExtensions
/// </summary> /// </summary>
public static string ToIpV4(this int me) public static string ToIpV4(this int me)
{ {
return string.Join(".", BitConverter.GetBytes(me).Reverse()); var bytes = BitConverter.GetBytes(me);
Array.Reverse(bytes);
return string.Join('.', bytes);
} }
} }

View File

@ -5,6 +5,8 @@ namespace NSExt.Extensions;
/// </summary> /// </summary>
public static class LongExtensions public static class LongExtensions
{ {
private const string _CHARS_36 = "0123456789abcdefghijklmnopqrstuvwxyz";
/// <summary> /// <summary>
/// 判断枚举是否包含某个位 /// 判断枚举是否包含某个位
/// </summary> /// </summary>
@ -24,6 +26,22 @@ public static class LongExtensions
return new Random(Guid.NewGuid().GetHashCode()).NextInt64(me[0], me[1]); return new Random(Guid.NewGuid().GetHashCode()).NextInt64(me[0], me[1]);
} }
/// <summary>
/// 转36进制
/// </summary>
public static string Sys36(this long me)
{
var ret = new StringBuilder();
while (me > 35)
{
_ = ret.Insert(0, _CHARS_36[(int)(me % 36)]);
me /= 36;
}
_ = ret.Insert(0, _CHARS_36[(int)me]);
return ret.ToString();
}
/// <summary> /// <summary>
/// 1970毫秒数转换成日期对象 /// 1970毫秒数转换成日期对象
/// </summary> /// </summary>

View File

@ -14,7 +14,7 @@ namespace NSExt.Extensions;
/// </summary> /// </summary>
public static partial class StringExtensions public static partial class StringExtensions
{ {
private const string _CHARACTERS = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; private const string _CHARS_62 = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
private static readonly Regex _regexIpV4 = RegexIpV4(); private static readonly Regex _regexIpV4 = RegexIpV4();
/// <summary> /// <summary>
@ -51,15 +51,43 @@ public static partial class StringExtensions
return decrypted.HexDe(); return decrypted.HexDe();
} }
/// <summary>
/// 将指定的输入字符串进行Base62编码
/// </summary>
public static string Base62(this string me)
{
// Convert string to byte array
var bytes = Encoding.UTF8.GetBytes(me);
// Convert byte array to BigInteger for easier processing
var bigInteger = new BigInteger(bytes);
if (bigInteger == 0)
{
return _CHARS_62[0].ToString();
}
var result = new StringBuilder();
while (bigInteger > 0)
{
var remainder = (int)(bigInteger % 62);
bigInteger /= 62;
_ = result.Insert(0, _CHARS_62[remainder]);
}
return result.ToString();
}
/// <summary> /// <summary>
/// 将指定的输入字符串进行Base62解码 /// 将指定的输入字符串进行Base62解码
/// </summary> /// </summary>
/// <exception cref="ArgumentException">ArgumentException</exception> /// <exception cref="ArgumentException">ArgumentException</exception>
public static string Base62Decode(this string me) public static string Base62De(this string me)
{ {
BigInteger result = 0; BigInteger result = 0;
foreach (var index in me.Select(c => _CHARACTERS.IndexOf(c))) foreach (var index in me.Select(c => _CHARS_62.IndexOf(c)))
{ {
if (index < 0) if (index < 0)
{ {
@ -81,34 +109,6 @@ public static partial class StringExtensions
return Encoding.UTF8.GetString(bytes); return Encoding.UTF8.GetString(bytes);
} }
/// <summary>
/// 将指定的输入字符串进行Base62编码
/// </summary>
public static string Base62Encode(this string me)
{
// Convert string to byte array
var bytes = Encoding.UTF8.GetBytes(me);
// Convert byte array to BigInteger for easier processing
var bigInteger = new BigInteger(bytes);
if (bigInteger == 0)
{
return _CHARACTERS[0].ToString();
}
var result = new StringBuilder();
while (bigInteger > 0)
{
var remainder = (int)(bigInteger % 62);
bigInteger /= 62;
_ = result.Insert(0, _CHARACTERS[remainder]);
}
return result.ToString();
}
/// <summary> /// <summary>
/// base64编码 /// base64编码
/// </summary> /// </summary>

View File

@ -7,9 +7,9 @@
<Import Project="$(SolutionDir)/build/copy.pkg.xml.comment.files.targets"/> <Import Project="$(SolutionDir)/build/copy.pkg.xml.comment.files.targets"/>
<Import Project="$(SolutionDir)/build/prebuild.targets"/> <Import Project="$(SolutionDir)/build/prebuild.targets"/>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CodeAnalysis.CSharp.Scripting" Version="4.12.0-3.final"/> <PackageReference Include="Microsoft.CodeAnalysis.CSharp.Scripting" Version="4.14.0"/>
<PackageReference Include="Microsoft.Extensions.Logging" Version="9.0.0"/> <PackageReference Include="Microsoft.Extensions.Logging" Version="9.0.6"/>
<PackageReference Include="System.IO.Hashing" Version="9.0.0"/> <PackageReference Include="System.IO.Hashing" Version="9.0.6"/>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<None Update="*.json"> <None Update="*.json">