设计一个PHP文件操作的架构需要考虑多个方面,包括性能、安全性、可维护性和可扩展性。以下是一个基本的架构设计思路:
首先,设计一个清晰的目录结构,以便于管理和维护代码。
/project-root
/app
/controllers
/models
/views
/config
database.php
routes.php
/public
index.php
/vendor
/storage
/logs
控制器负责处理用户请求,调用模型进行数据操作,并返回视图。
// /app/controllers/UserController.php
namespace App\Controllers;
use App\Models\UserModel;
class UserController {
public function index() {
$userModel = new UserModel();
$users = $userModel->getAllUsers();
require 'views/user/index.php';
}
public function create() {
// Handle user creation logic
}
}
模型负责与数据库交互,进行数据的增删改查操作。
// /app/models/UserModel.php
namespace App\Models;
use PDO;
class UserModel {
private $db;
public function __construct() {
$this->connectDB();
}
private function connectDB() {
$config = require 'config/database.php';
$dsn = "mysql:host={$config['host']};dbname={$config['dbname']};charset=utf8mb4";
$options = [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
];
$this->db = new PDO($dsn, $config['username'], $config['password'], $options);
}
public function getAllUsers() {
$stmt = $this->db->query('SELECT * FROM users');
return $stmt->fetchAll();
}
}
配置文件用于存储数据库连接信息和路由信息。
// /config/database.php
return [
'host' => 'localhost',
'dbname' => 'mydb',
'username' => 'root',
'password' => '',
];
// /config/routes.php
return [
'user' => 'App\Controllers\UserController',
];
路由负责将URL映射到控制器方法。
// /public/index.php
require 'vendor/autoload.php';
$router = require 'config/routes.php';
$requestMethod = $_SERVER['REQUEST_METHOD'];
$uri = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH);
$uri = trim($uri, '/');
$segments = explode('/', $uri);
$routeFound = false;
$controllerName = '';
$actionName = '';
foreach ($router as $route => $handler) {
$regex = sprintf('#^%s$#', preg_replace('#\s+#', '+', preg_quote($route, '#')));
if (preg_match($regex, $segments)) {
list($controllerName, $actionName) = explode('@', $handler);
$routeFound = true;
break;
}
}
if (!$routeFound) {
header('HTTP/1.0 404 Not Found');
require 'views/error/404.php';
exit();
}
$controllerClass = "App\\Controllers\\{$controllerName}";
$controller = new $controllerClass();
$controller->$actionName();
公共文件用于处理入口文件和加载必要的库。
// /public/index.php
require 'vendor/autoload.php';
$router = require 'config/routes.php';
$requestMethod = $_SERVER['REQUEST_METHOD'];
$uri = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH);
$uri = trim($uri, '/');
$segments = explode('/', $uri);
$routeFound = false;
$controllerName = '';
$actionName = '';
foreach ($router as $route => $handler) {
$regex = sprintf('#^%s$#', preg_replace('#\s+#', '+', preg_quote($route, '#')));
if (preg_match($regex, $segments)) {
list($controllerName, $actionName) = explode('@', $handler);
$routeFound = true;
break;
}
}
if (!$routeFound) {
header('HTTP/1.0 404 Not Found');
require 'views/error/404.php';
exit();
}
$controllerClass = "App\\Controllers\\{$controllerName}";
$controller = new $controllerClass();
$controller->$actionName();
视图负责展示数据给用户。
// /app/views/user/index.php
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Users</title>
</head>
<body>
<h1>Users List</h1>
<ul>
<?php foreach ($users as $user): ?>
<li><?php echo htmlspecialchars($user['name']); ?></li>
<?php endforeach; ?>
</ul>
</body>
</html>
日志用于记录应用的运行状态和错误信息。
// /storage/logs/app.log
<?php
$filename = __DIR__ . '/../storage/logs/app.log';
$timestamp = date('Y-m-d H:i:s');
$message = sprintf("[%s] %s\n", $timestamp, $_SERVER['REQUEST_URI']);
file_put_contents($filename, $message, FILE_APPEND);
以上是一个基本的PHP文件操作架构设计,涵盖了目录结构、控制器、模型、配置文件、路由、公共文件、视图和日志等方面。根据具体需求,可以进一步扩展和优化这个架构。