- 修复 LeaderboardController 查询不存在的 sign 字段导致 500 错误 - 修复 leaderboard/index 和 guestbook/index 引用不存在的 layouts.app 布局 - 将排行榜和留言板改为独立 HTML 页面结构(含 Tailwind CDN) - 修复退出登录返回 JSON 而非重定向的问题,现在会正确跳转回登录页 - 将 REDIS_CLIENT 从 phpredis 改为 predis(兼容无扩展环境) - 新增 RoomSeeder 自动创建默认公共大厅房间 - 新增 Nginx 生产环境配置示例(含 WebSocket 反向代理) - 重写 README.md 为完整的中文部署指南 - 修复 rooms/index 和 chat/frame 中 Alpine.js 语法错误 - 将 chat.js 加入 Vite 构建配置 - 新增验证码配置文件
66 lines
1.9 KiB
PHP
66 lines
1.9 KiB
PHP
<?php
|
||
|
||
/**
|
||
* 文件功能:登录/注册请求验证器
|
||
*
|
||
* @author ChatRoom Laravel
|
||
*
|
||
* @version 1.0.0
|
||
*/
|
||
|
||
namespace App\Http\Requests;
|
||
|
||
use Illuminate\Foundation\Http\FormRequest;
|
||
|
||
class LoginRequest extends FormRequest
|
||
{
|
||
/**
|
||
* Determine if the user is authorized to make this request.
|
||
*/
|
||
public function authorize(): bool
|
||
{
|
||
return true;
|
||
}
|
||
|
||
/**
|
||
* Get the validation rules that apply to the request.
|
||
*
|
||
* @return array<string, \Illuminate\Contracts\Validation\ValidationRule|array<mixed>|string>
|
||
*/
|
||
public function rules(): array
|
||
{
|
||
return [
|
||
'username' => [
|
||
'required',
|
||
'string',
|
||
'min:2',
|
||
'max:12',
|
||
// 允许中英文数字及常见符号,但严格过滤可能引起XSS/SQL注入的危险字符:< > ' "
|
||
'regex:/^[^<>\'"]+$/u',
|
||
],
|
||
'password' => ['required', 'string', 'min:1'],
|
||
// 'captcha' => ['required', 'captcha'],
|
||
'captcha' => ['nullable'], // 【本地调试临时绕过验证码强校验,跳过session丢失问题】
|
||
];
|
||
}
|
||
|
||
/**
|
||
* 获取已定义验证规则的错误消息。
|
||
*
|
||
* @return array<string, string>
|
||
*/
|
||
public function messages(): array
|
||
{
|
||
return [
|
||
'username.required' => '必须填写用户名。',
|
||
'username.min' => '用户名长度不得少于 2 个字符。',
|
||
'username.max' => '用户名长度不得超过 12 个字符。',
|
||
'username.regex' => '用户名包含非法字符(不允许使用尖括号或引号)。',
|
||
'password.required' => '必须填写密码。',
|
||
'password.min' => '密码长度不得少于 1 个字符。',
|
||
'captcha.required' => '必须填写验证码。',
|
||
'captcha.captcha' => '验证码不正确。',
|
||
];
|
||
}
|
||
}
|