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等大厂都工作过。当下为退役状态,写此篇文章属个人爱好。本人开发期间收集了很多开发课程等资料,需要可联系我

相关推荐
一 乐1 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
玩泥巴的2 小时前
飞书 .NET SDK 事件处理的幂等性与去重机制
c#·.net·二次开发·飞书
1.14(java)3 小时前
SQL数据库操作:从CRUD到高级查询
数据库
Full Stack Developme3 小时前
数据库索引的原理及类型和应用场景
数据库
喵叔哟3 小时前
20.部署与运维
运维·docker·容器·.net
IDC02_FEIYA5 小时前
SQL Server 2025数据库安装图文教程(附SQL Server2025数据库下载安装包)
数据库·windows
辞砚技术录5 小时前
MySQL面试题——联合索引
数据库·面试
萧曵 丶5 小时前
MySQL 主键不推荐使用 UUID 的深层原因
数据库·mysql·索引
小北方城市网6 小时前
分布式锁实战指南:从选型到落地,避开 90% 的坑
java·数据库·redis·分布式·python·缓存
毕设十刻6 小时前
基于Vue的人事管理系统67zzz(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js