
接下来,安装必要的依赖:
npm install express php-express cors
其中,express是Express框架,php-express是PHP中间件,cors用于处理跨域请求(如果React应用和Express服务器运行在不同的域名或端口上)。
创建一个名为server.js的文件,并添加以下代码:
const express = require('express');
const path = require('path');
const phpExpress = require('php-express')({
  binPath: 'php' // 确保PHP可执行文件在系统PATH中
});
const cors = require('cors'); // 引入 cors
const app = express();
const port = 3001; // 选择一个合适的端口
// 使用 CORS 中间件,允许来自所有域的请求
app.use(cors());
// 设置视图目录
app.set('views', path.join(__dirname, 'views/php'));
app.engine('php', phpExpress.engine);
app.set('view engine', 'php');
// 路由配置,处理所有以 .php 结尾的请求
app.all(/.+\.php$/, phpExpress.router);
app.listen(port, () => {
  console.log(`PHP server listening at http://localhost:${port}`);
});在项目根目录下创建一个名为 views 的文件夹,并在 views 文件夹下创建一个名为 php 的文件夹。将你的 PHP 文件(例如 file.php)放入 views/php 文件夹中。
React应用中的请求
立即学习“PHP免费学习笔记(深入)”;
现在,你可以从你的React应用向该服务器发起HTTP请求,例如:
import React, { useState, useEffect } from 'react';
function MyComponent() {
  const [data, setData] = useState(null);
  useEffect(() => {
    fetch('http://localhost:3001/file.php') // 替换为你的服务器地址和PHP文件路径
      .then(response => response.text()) // 获取文本响应
      .then(data => setData(data))
      .catch(error => console.error('Error fetching data:', error));
  }, []);
  return (
    <div>
      {data ? (
        <div dangerouslySetInnerHTML={{ __html: data }} />
      ) : (
        <p>Loading...</p>
      )}
    </div>
  );
}
export default MyComponent;注意事项:
总结
虽然不能直接在React应用中使用php-express,但可以通过构建一个独立的Express服务器来处理PHP代码,然后React应用通过HTTP请求与该服务器通信。这种方法可以实现React应用与PHP代码的集成。然而,在没有特殊需求的情况下,建议使用专门的PHP服务器(如Nginx)来运行PHP代码,这样可以获得更好的性能和安全性。
以上就是将PHP嵌入React应用:使用php-express的正确姿势的详细内容,更多请关注php中文网其它相关文章!
 
                        
                        PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
 
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号