MAUI android连接sqlserver

PDA是android系统,调用金蝶云星空webapi实现仓库收发料,使用读取webapi有些功能无法实现,需要直接读写数据库,读取报错,如图:

用控制台程序测试正常读取

google搜索了一圈, 都需要使用ssl证书才能解决,终于找到不用证书的解决办法,参考地址

c# - "Trust anchor for certification path not found." in a .NET Maui Project trying to contact a local .NET WebApi - Stack Overflow

操作步骤:

在Platforms\Android下新建DangerousTrustProvider.cs文件,如下图

添加命名空间

cs 复制代码
using System;
using Java.Net;
using Java.Security;
using Java.Security.Cert;
using Javax.Net.Ssl;

添加代码

cs 复制代码
internal class DangerousTrustProvider : Provider
{
    private const string TRUST_PROVIDER_ALG = "DangerousTrustAlgorithm";
    private const string TRUST_PROVIDER_ID = "DangerousTrustProvider";

    public DangerousTrustProvider() : base(TRUST_PROVIDER_ID, 1, string.Empty)
    {
        var key = "TrustManagerFactory." + DangerousTrustManagerFactory.GetAlgorithm();
        var val = Java.Lang.Class.FromType(typeof(DangerousTrustManagerFactory)).Name;
        Put(key, val);
    }

    public static void Register()
    {
        Provider registered = Security.GetProvider(TRUST_PROVIDER_ID);
        if (null == registered)
        {
            Security.InsertProviderAt(new DangerousTrustProvider(), 1);
            Security.SetProperty("ssl.TrustManagerFactory.algorithm", TRUST_PROVIDER_ALG);
        }
    }

    public class DangerousTrustManager : X509ExtendedTrustManager
    {
        public override void CheckClientTrusted(X509Certificate[] chain, string authType, Socket socket) { }
        public override void CheckClientTrusted(X509Certificate[] chain, string authType, SSLEngine engine) { }
        public override void CheckClientTrusted(X509Certificate[] chain, string authType) { }
        public override void CheckServerTrusted(X509Certificate[] chain, string authType, Socket socket) { }
        public override void CheckServerTrusted(X509Certificate[] chain, string authType, SSLEngine engine) { }
        public override void CheckServerTrusted(X509Certificate[] chain, string authType) { }
        public override X509Certificate[] GetAcceptedIssuers() => Array.Empty<X509Certificate>();
    }

    public class DangerousTrustManagerFactory : TrustManagerFactorySpi
    {
        protected override void EngineInit(IManagerFactoryParameters mgrparams) { }
        protected override void EngineInit(KeyStore keystore) { }
        protected override ITrustManager[] EngineGetTrustManagers() => new ITrustManager[] { new DangerousTrustManager() };
        public static string GetAlgorithm() => TRUST_PROVIDER_ALG;
    }
}

复制上面的代码,粘贴替换,如图

完整代码如图

打开,MauiProgram.cs增加调用代码

cs 复制代码
#if ANDROID
	Platforms.Android.DangerousTrustProvider.Register();
#endif

如图

再次用模拟器测试,读取成功

相关推荐
钛态2 小时前
Flutter 三方库 http_mock_adapter — 赋能鸿蒙应用开发的高效率网络接口 Mock 与自动化测试注入引擎(适配鸿蒙 HarmonyOS Next ohos)
android·网络协议·flutter·http·华为·中间件·harmonyos
王码码20352 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
左手厨刀右手茼蒿3 小时前
Flutter for OpenHarmony: Flutter 三方库 shamsi_date 助力鸿蒙应用精准适配波斯历法(中东出海必备)
android·flutter·ui·华为·自动化·harmonyos
代码飞天3 小时前
wireshark的高级使用
android·java·wireshark
2501_915918414 小时前
苹果App Store上架审核卡住原因分析与解决方案指南
android·ios·小程序·https·uni-app·iphone·webview
skiy4 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
小小小点5 小时前
Android四大常用布局详解与实战
android
MinQ6 小时前
binder和socket区别及原理
android
Ehtan_Zheng6 小时前
Jetpack Compose 中绘制发光边框的多种方式
android
智塑未来6 小时前
像素蛋糕安卓版 AI 专业修图全场景输出高清成片
android·人工智能