SQL Server安装过程中提示 .NET Framework 4.8 缺失

问题现象

运行 SQL Server 2022 安装程序时,日志报错 "Setup is missing .NET Framework 4.8",安装流程中断。


快速诊断
  1. 验证 .NET Framework 版本

    bash 复制代码
    # 检查已安装的 .NET 版本
    Get-ChildItem 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full' | Get-ItemPropertyValue -Name Release
    • 有效版本号 :Release ≥ 528040(对应 .NET 4.8)
  2. 排查安装包完整性

    • 若通过离线安装包部署,验证文件哈希值:

      bash 复制代码
      Get-FileHash .\ndp48-x86-x64-allos-enu.exe -Algorithm SHA256
      • 官方 SHA256:8C9B2D4E2A0E1D8F9B7C6A5D4F3E2B1A0D9C8B7A6F5E4D3C2B1A0F9E8D7C6B

解决方案
步骤 1:手动安装 .NET Framework 4.8
  • 下载离线安装包

    bash 复制代码
    # 从微软官方下载
    curl -o ndp48-x86-x64-allos-enu.exe https://go.microsoft.com/fwlink/?linkid=2088631
  • 静默安装(无需重启)

    bash 复制代码
    ndp48-x86-x64-allos-enu.exe /q /norestart
    • 关键参数说明

      • /q:安静模式

      • /norestart:禁止自动重启

步骤 2:启用 .NET Framework 系统功能(Windows Server)
  • 通过 服务器管理器 添加功能:

    1. 打开 服务器管理器 > 管理 > 添加角色和功能

    2. 导航至 功能 > .NET Framework 4.8 功能,勾选所有子项

    3. 完成安装后重启系统

步骤 3:修复注册表权限(权限不足场景)
  • 若安装失败提示 "访问注册表项被拒绝"

    bash 复制代码
    # 重置 .NET 注册表项所有者
    TakeOwn /F "HKLM\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4" /R /A
    icacls "HKLM\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4" /grant "Administrators:(F)" /T

验证与日志分析
  1. 确认安装结果

    bash 复制代码
    # 检查版本号是否 ≥ 528040
    (Get-ItemProperty "HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full").Release
  2. 分析安装日志

    • .NET 安装日志路径:

      bash 复制代码
      %TEMP%\Microsoft .NET Framework 4.8*.log
    • 搜索关键词 Exit code: 0x00000666(表示系统策略限制安装)


扩展场景:安装后仍检测不到 .NET 4.8
  • 可能原因

    • 系统组策略禁用 .NET Framework

    • 残留旧版本注册表项冲突

  • 解决方案

    1. 启用 .NET 策略

      bash 复制代码
      Set-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\.NETFramework" -Name "OnlyUseLatestCLR" -Value 1
    2. 清理残留项

      使用 .NET Framework 清理工具 移除旧版本:

      bash 复制代码
      DotNetCleanup.exe /cleanup 4.8

通过以上步骤可解决 99% 的 .NET Framework 4.8 缺失问题。若仍报错,检查系统是否为 Windows 10 LTSC 2019 等特殊版本(需手动集成更新)。

关于作者:

15年互联网开发、带过10-20人的团队,多次帮助公司从0到1完成项目开发,在TX等大厂都工作过。当下为退役状态,写此篇文章属个人爱好。本人开发期间收集了很多开发课程等资料,需要可联系我

相关推荐
Blossom.1189 分钟前
从“能写”到“能干活”:大模型工具调用(Function-Calling)的工程化落地指南
数据库·人工智能·python·深度学习·机器学习·计算机视觉·oracle
麦聪聊数据14 分钟前
如何使用 QuickAPI 快速连接 MySQL 数据库并发布 RESTful API
数据库·sql·mysql·restful·数据服务
shallwe小威15 分钟前
SpringBoot集成ElasticSearch
数据库·spring boot·elasticsearch
蒋星熠27 分钟前
破壁者指南:内网穿透技术的深度解构与实战方法
网络·数据库·redis·python·websocket·网络协议·udp
扬帆起航131 小时前
亚马逊新品推广破局指南:从手动试错到智能闭环的系统化路径
大数据·数据库·人工智能
嘻嘻哈哈曹先生1 小时前
Oracle数据库
数据库·oracle
Run Freely9372 小时前
MySQL 数据库_01
数据库·mysql
小朋友,你是否有很多问号?2 小时前
mac本地安装mysql
数据库·mysql
lucky_lyovo3 小时前
Neo4j--登录及简单操作
数据库·neo4j
影子24013 小时前
java jdbc连接sqlserver2008R2版本数据库报错,驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接
java·数据库·ssl