0

0

Android network_security_config.xml 安卓网络安全配置文件写法

畫卷琴夢

畫卷琴夢

发布时间:2026-03-09 08:10:03

|

736人浏览过

|

来源于php中文网

原创

network_security_config.xml必须放在res/xml/目录下,文件名严格为network_security_config.xml,并在androidmanifest.xml的application标签中通过android:networksecurityconfig="@xml/network_security_config"引用,否则不生效。

android network_security_config.xml 安卓网络安全配置文件写法

network_security_config.xml 放哪才生效

必须放在 res/xml/network_security_config.xml,路径错一个字母或放错目录(比如丢进 assetsraw)都完全不生效。Android 构建系统只认这个固定路径,且文件名大小写敏感——NetworkSecurityConfig.xmlnetwork-security-config.xml 都会静默失败。

还要在 AndroidManifest.xml<application></application> 标签里显式引用:

<application
    android:networkSecurityConfig="@xml/network_security_config"
    ... >

漏掉这行,配置等于没写。

debug 模式下允许明文 HTTP 怎么配

开发时调本地 API 经常遇到 Cleartext HTTP traffic to xxx not permitted 错误,直接改全局 android:usesCleartextTraffic="true" 是错的——它绕过所有校验,上线前极易忘记关,而且 Android 9+ 默认强制禁用,仅靠这个属性无法覆盖 network_security_config 的约束。

正确做法是用 <debug-overrides></debug-overrides> 块,它只在 debug 构建类型下生效,不影响 release:

<network-security-config>
    <debug-overrides>
        <domain-config>
            <domain includeSubdomains="true">192.168.1.100</domain>
            <trust-anchors>
                <certificates src="system" />
                <certificates src="user" />
            </trust-anchors>
            <allow-clear-text-http="true" />
        </domain-config>
    </debug-overrides>
</network-security-config>
  • includeSubdomains="true" 要根据实际地址决定:如果只连 192.168.1.100:8080,设为 false 更安全
  • <allow-clear-text-http></allow-clear-text-http> 必须写在 <domain-config></domain-config> 内,写在根节点或 <domain-config></domain-config> 外无效
  • 调试用的自签名证书,记得同时加 <certificates src="user"></certificates>,否则即使开了明文,证书校验仍会失败

信任自签名证书或内网 CA 怎么写

对接测试环境或企业内网服务时,系统默认不信任自签名证书或私有 CA,会报 SSLHandshakeExceptionPKIX path building failed。不能简单关 HTTPS 校验,得精准导入证书。

网络工作室整站 for Dedecms5.7 SP1
网络工作室整站 for Dedecms5.7 SP1

基于DEDECMS5.7 SP1制作的漂亮网络工作室整站源码,生成HTML文件。利于收录。整站采用黑色配色,彰显大气。目前仅添加新闻,案例栏目。其他类别请自行在后台添加,并修改首页模板的调用。 安装方法:1.访问:域名/install 按照提示进行安装.2.完成后登陆网站后台---还原数据库3.系统设置---修改网址和网站名称.4.生成整站,后台信息:dede后台用户名:admin后台密码:www

下载

步骤分三步:

  • 把 PEM 或 DER 格式证书(后缀 .crt.cer)重命名为小写字母 + 数字 + .cer(如 myca.cer),放进 res/raw/ 目录
  • network_security_config.xml 中引用:
    <domain-config>
        <domain includeSubdomains="true">api.test.internal</domain>
        <trust-anchors>
            <certificates src="@raw/myca" />
            <certificates src="system" />
        </trust-anchors>
    </domain-config>
  • src="@raw/myca" 的路径必须和文件名完全一致(不含扩展名),@raw/myca.cer 会加载失败

注意:Android 7.0+ 才支持 @raw/ 引用;低于此版本只能靠 src="system" + 用户手动安装证书,兼容性差。

为什么 config 写对了但抓包还是被拦截

常见于用 Charles/Fiddler 抓 App 流量时,明明配了 <certificates src="user"></certificates>,却提示证书不受信任。根本原因是:Android 7.0+ 默认不信任用户安装的证书,除非明确在配置中启用。

必须确保两点同时满足:

  • 证书已通过系统设置 → “加密与凭据” → “安装证书” 正确安装(不是浏览器里点开安装)
  • 配置中对应 domain 的 <trust-anchors></trust-anchors> 块里包含 <certificates src="user"></certificates>,且该块未被更高优先级的父配置覆盖

最容易忽略的是域匹配逻辑:如果 App 请求的是 https://api.example.com/v1,但配置里只写了 <domain>example.com</domain>includeSubdomains="false",那么 api.example.com 就不命中,仍走系统默认锚点(即不信任 user 证书)。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1945

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2119

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1166

2024.11.28

android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

337

2023.08.14

android是什么系统
android是什么系统

Android是一种功能强大、灵活可定制、应用丰富、多任务处理能力强、兼容性好、网络连接能力强的操作系统。本专题为大家提供android相关的文章、下载、课程内容,供大家免费下载体验。

1819

2023.08.22

android权限限制怎么解开
android权限限制怎么解开

android权限限制可以使用Root权限、第三方权限管理应用程序、ADB命令和Xposed框架解开。详细介绍:1、Root权限,通过获取Root权限,用户可以解锁所有权限,并对系统进行自定义和修改;2、第三方权限管理应用程序,用户可以轻松地控制和管理应用程序的权限;3、ADB命令,用户可以在设备上执行各种操作,包括解锁权限;4、Xposed框架,用户可以在不修改系统文件的情况下修改应用程序的行为和权限。

2129

2023.09.19

android重启应用的方法有哪些
android重启应用的方法有哪些

android重启应用有通过Intent、PendingIntent、系统服务、Runtime等方法。本专题为大家提供Android相关的文章、下载、课程内容,供大家免费下载体验。

284

2023.10.18

Android语音播放功能实现方法
Android语音播放功能实现方法

实现方法有使用MediaPlayer实现、使用SoundPool实现两种。可以根据具体的需求选择适合的方法进行实现。想了解更多语音播放的相关内容,可以阅读本专题下面的文章。

379

2024.03.01

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

24

2026.03.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 20.8万人学习

Java 教程
Java 教程

共578课时 | 79.9万人学习

Uniapp从零开始实现新闻资讯应用
Uniapp从零开始实现新闻资讯应用

共64课时 | 7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号