0

0

Android 应用连接本地 Apache 服务器(XAMPP)完整调试指南

碧海醫心

碧海醫心

发布时间:2026-03-03 13:27:00

|

588人浏览过

|

来源于php中文网

原创

Android 应用连接本地 Apache 服务器(XAMPP)完整调试指南

本文详解 android 真机如何安全、稳定地访问同一局域网内的本地 apache 服务器(如 xampp),涵盖网络配置、https/http 适配、volley 请求实践及关键避坑要点。

本文详解 android 真机如何安全、稳定地访问同一局域网内的本地 apache 服务器(如 xampp),涵盖网络配置、https/http 适配、volley 请求实践及关键避坑要点。

在 Android 开发初期,许多开发者会遇到一个典型场景:后端已用 XAMPP 搭建好本地 PHP + MySQL 服务(例如 http://192.168.56.172/api/login.php),手机与开发机处于同一 Wi-Fi 热点下,浏览器可正常访问该地址,但 App 发起 HTTP 请求时却失败——常见报错包括 java.net.MalformedURLException: no protocol 或更普遍的 Cleartext HTTP traffic not permitted。这并非代码逻辑错误,而是 Android 9(API 28)起强制启用的网络安全策略所致。

✅ 正确配置网络权限与安全策略

首先,确保使用的是局域网 IP(非 localhost 或 127.0.0.1)。在 Windows 上通过 ipconfig 查看本机 IPv4 地址(如 192.168.56.172),并确认 Apache 监听该地址(XAMPP 控制面板 → Config → httpd.conf 中检查 Listen 80 及 权限)。手机浏览器输入 http://192.168.56.172 能打开即说明服务可达。

其次,必须显式声明允许明文流量的目标域名/IP。仅在 AndroidManifest.xml 中添加 android:usesCleartextTraffic="true" 是不够且不推荐的(尤其在生产环境或 Android 10+ 上可能被忽略)。正确做法是:

  1. 在 res/xml/network_security_config.xml 中精准配置目标地址:

    LibLib AI
    LibLib AI

    中国领先原创AI模型分享社区,拥有LibLib等于拥有了超多模型的模型库、免费的在线生图工具,不考虑配置的模型训练工具

    下载
    <?xml version="1.0" encoding="utf-8"?>
    <network-security-config>
     <domain-config>
         <!-- 关键:此处必须包含你的局域网IP或自定义域名 -->
         <domain includeSubdomains="true">192.168.56.172</domain>
         <!-- 若使用 pagekite.me 域名,也需单独添加 -->
         <domain includeSubdomains="true">mohe.pagekite.me</domain>
         <cleartextTrafficPermitted>true</cleartextTrafficPermitted>
     </domain-config>
    </network-security-config>
  2. 在 AndroidManifest.xml 的 标签中引用该配置:

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

⚠️ 注意: 不能共存;若使用 ,必须将目标 IP/域名明确写入 标签,否则配置无效——这正是原问题中“添加了配置仍报错”的根本原因。

✅ Volley 请求示例(Kotlin)

以下为适配本地服务器的健壮请求代码(含基础错误处理与上下文绑定):

val queue = Volley.newRequestQueue(this)
val url = "http://192.168.56.172/hello.php" // ✅ 使用局域网IP,非localhost

val stringRequest = StringRequest(
    Request.Method.GET,
    url,
    { response ->
        val result = "Success: ${response.take(200)}"
        Toast.makeText(this, result, Toast.LENGTH_LONG).show()
    },
    { error ->
        val errorMsg = when (error) {
            is TimeoutError -> "请求超时,请检查网络和服务器状态"
            is NoConnectionError -> "无法连接到服务器,请确认Apache已启动且IP正确"
            else -> "请求失败: ${error.message}"
        }
        Toast.makeText(this, errorMsg, Toast.LENGTH_LONG).show()
    }
).apply {
    // 可选:设置超时时间(默认 2.5s,局域网建议延长)
    setRetryPolicy(DefaultRetryPolicy(
        5000, // timeoutMs
        DefaultRetryPolicy.DEFAULT_MAX_RETRIES,
        DefaultRetryPolicy.DEFAULT_BACKOFF_MULT
    ))
}

queue.add(stringRequest)

✅ 其他关键注意事项

  • 防火墙与端口开放:Windows 防火墙可能拦截外部设备对 80 端口的访问。请在「高级安全 Windows Defender 防火墙」中新建入站规则,允许 TCP 端口 80(或你自定义的端口)。
  • Apache 绑定配置:默认 XAMPP 的 httpd.conf 可能仅监听 127.0.0.1。修改为 Listen 80 并确保 下的 Require all granted 已启用。
  • 避免 PageKite 等公网隧道用于开发:虽然可行,但引入额外延迟与不稳定因素。局域网直连才是高效开发的标准方案。
  • 进阶建议:长期开发推荐启用 HTTPS(如 mkcert 生成本地证书),一劳永逸规避明文限制,并提前适配未来 Android 版本要求。

至此,你的 Android 真机即可稳定调用本地 XAMPP 提供的 PHP 接口,实现登录、数据读写等核心功能,大幅提升本地迭代效率。记住:可访问 ≠ 可通信,Android 的网络安全模型要求你主动声明信任边界——这是安全设计,而非障碍。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
Kotlin协程编程与Spring Boot集成实践
Kotlin协程编程与Spring Boot集成实践

本专题围绕 Kotlin 协程机制展开,深入讲解挂起函数、协程作用域、结构化并发与异常处理机制,并结合 Spring Boot 展示协程在后端开发中的实际应用。内容涵盖异步接口设计、数据库调用优化、线程资源管理以及性能调优策略,帮助开发者构建更加简洁高效的 Kotlin 后端服务架构。

121

2026.02.12

mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

682

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

452

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

286

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

265

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

541

2023.08.11

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

0

2026.03.03

热门下载

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

精品课程

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

共162课时 | 19.8万人学习

Java 教程
Java 教程

共578课时 | 76万人学习

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

共64课时 | 6.9万人学习

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

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