0

0

php数据库怎么进跨域的mysql_php跨域连mysql法【教程】

雪夜

雪夜

发布时间:2026-01-25 19:11:33

|

131人浏览过

|

来源于php中文网

原创

PHP连接MySQL不涉及跨域,跨域仅存在于前端JavaScript调用PHP接口时;需在PHP中设置Access-Control-Allow-Origin等响应头解决CORS错误。

php数据库怎么进跨域的mysql_php跨域连mysql法【教程】

PHP 连 MySQL 本身不涉及跨域

“PHP 跨域连 MySQL”这个说法存在概念混淆。PHP 是服务端语言,mysqli_connect()PDO 连接 MySQL 时走的是服务器内部网络(如 127.0.0.1localhost 或内网 IP),和浏览器的“跨域(CORS)”完全无关。真正触发跨域的是前端 JavaScript 发起的 HTTP 请求(比如 fetch 调用 PHP 接口),而不是 PHP 自己连数据库。

前端 AJAX 请求 PHP 接口报 CORS 错误怎么办

这是实际中最常被误认为“PHP 跨域连 MySQL”的场景:前端页面在 http://a.com,调用 http://b.com/api.php,后者查 MySQL 并返回 JSON,但浏览器报 Access-Control-Allow-Origin 错误。

  • 问题不在 PHP 连数据库,而在 PHP 接口未声明允许跨源请求
  • 只需在 PHP 脚本开头加响应头:
    header('Access-Control-Allow-Origin: *');
    (生产环境建议指定域名,如 http://a.com
  • 若带 Cookie 或认证头,还需:
    header('Access-Control-Allow-Credentials: true');
    ,且前端 fetch 要加 credentials: 'include'
  • 预检请求(OPTIONS)需单独处理,尤其是用了自定义 header 或非 GET/POST 方法时

PHP 连远程 MySQL 被拒绝的常见原因

如果真要让 PHP 从一台服务器连另一台服务器上的 MySQL(例如 PHP 在腾讯云,MySQL 在阿里云),那不是跨域,而是网络与权限问题:

  • MySQL 用户没授权远程访问:CREATE USER 'user'@'%' IDENTIFIED BY 'pass'; GRANT ALL ON db.* TO 'user'@'%'; FLUSH PRIVILEGES;
  • MySQL 配置绑定了 127.0.0.1(查看 bind-address 是否为 0.0.0.0 或注释掉)
  • 云服务器安全组/防火墙没放行 3306 端口(注意:不是 PHP 所在机器的防火墙,是 MySQL 服务器的)
  • PHP 使用了 localhost —— 这会走 socket 连接,改用 127.0.0.1 或真实 IP 才走 TCP

为什么不要直接让前端连 MySQL

有人想绕过 PHP,用 JS 直连 MySQL(比如通过 WebSocket 或第三方库),这绝对不可行:

机械设备钢材建材网站2.8.9
机械设备钢材建材网站2.8.9

机械设备钢材建材网站是基是一个以PHP+MySQL/Sqlite进行开发的四网合一网站源码。 系统功能特点: 四网合一企业网站管理系统支持在线升级(支持跨版本)、插件在线安装、系统内置严格的过滤体系、可以有效应对安全检测报告。 四网合一:电脑网站、手机站(数据同步、支持绑定域名)、小程序、公众号管理一个后台即可搞定。 双数据库引擎、运行环境全面:同时支持Sqlite

下载

立即学习PHP免费学习笔记(深入)”;

  • MySQL 协议不是 HTTP,浏览器禁止非 HTTP/HTTPS 的原始 socket 连接
  • 暴露数据库地址、账号、密码到前端 = 彻底裸奔,几秒内就被扫库拖库
  • 没有服务端校验,SQL 注入、越权访问毫无防御
  • 现代 MySQL 默认禁用旧认证插件(caching_sha2_password),纯 JS 客户端基本不支持

真正的边界很清晰:浏览器 ↔ PHP(HTTP 接口,可配 CORS),PHP ↔ MySQL(内网直连,无需跨域)。把权限控制、连接复用、错误隔离这些事留在 PHP 层,别试图在前端碰数据库连接细节。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2887

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1730

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1563

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1099

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1545

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1277

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1649

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1309

2023.11.13

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

58

2026.01.23

热门下载

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

精品课程

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

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 810人学习

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

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