- 添加用户管理功能的测试,包括创建、更新、停用、激活用户及用户登录 JWT 测试 - 提供用户管理相关的请求验证类与控制器 - 引入 CORS 配置信息,支持跨域请求 - 添加数据库播种器以便创建根用户 - 配置 API 默认使用 JWT 认证 - 添加聊天会话和消息的模型、迁移文件及关联功能
85 lines
2.5 KiB
Markdown
85 lines
2.5 KiB
Markdown
# 接口文档(JWT,无状态 API)
|
||
|
||
基地址:`http://localhost:8000/api`(容器默认映射 8000 端口)
|
||
自然语言:中文
|
||
|
||
- 认证方式:在请求头添加 `Authorization: Bearer {token}`。
|
||
- 默认账号(来自 `php artisan db:seed`):`root@example.com` / `Root@123456`。
|
||
- 所有接口均返回 JSON;失败时返回 `{ "message": "错误信息" }`。
|
||
- 跨域:默认允许 `http://localhost:5173`,可通过环境变量 `CORS_ALLOWED_ORIGINS`(逗号分隔多个域名)调整。
|
||
|
||
## 健康检查
|
||
- `GET /health`
|
||
响应:`{ "status": "ok" }`
|
||
|
||
## 登录
|
||
- `POST /login`
|
||
- 请求体:
|
||
```json
|
||
{ "email": "user@example.com", "password": "Password123" }
|
||
```
|
||
- 响应 200:
|
||
```json
|
||
{
|
||
"token": "jwt-token",
|
||
"token_type": "bearer",
|
||
"expires_in": 3600,
|
||
"user": { "id": 1, "name": "root", "email": "root@example.com", "is_active": true }
|
||
}
|
||
```
|
||
- 401:凭证无效;403:用户已停用。
|
||
|
||
## 当前用户
|
||
- `GET /me`(需要 JWT)
|
||
- 响应 200:当前登录用户信息。
|
||
|
||
## 用户管理(需 JWT)
|
||
字段约束:`name` 必填字符串(<=255)、`email` 邮箱唯一、`password` 最少 8 字符。
|
||
|
||
### 用户列表
|
||
- `GET /users`
|
||
- 查询参数:`page`(默认 1)、`per_page`(默认 15,最大 100)
|
||
- 响应 200:分页列表,`data` 为用户数组,包含 `id/name/email/is_active/created_at/updated_at`。
|
||
|
||
### 创建用户
|
||
- `POST /users`
|
||
- 请求体:
|
||
```json
|
||
{ "name": "Alice", "email": "alice@example.com", "password": "Password123" }
|
||
```
|
||
- 响应 201:新建用户(含 `is_active: true`)。
|
||
|
||
### 更新用户
|
||
- `PUT /users/{id}`
|
||
- 请求体(任意字段可选):
|
||
```json
|
||
{ "name": "New Name", "email": "new@example.com", "password": "NewPass123" }
|
||
```
|
||
- 响应 200:更新后的用户。
|
||
|
||
### 停用用户
|
||
- `POST /users/{id}/deactivate`
|
||
- 响应 200:`is_active` 为 `false`。
|
||
|
||
### 启用用户
|
||
- `POST /users/{id}/activate`
|
||
- 响应 200:`is_active` 为 `true`。
|
||
|
||
## 示例(cURL)
|
||
```bash
|
||
# 登录
|
||
curl -X POST http://localhost:8000/api/login \
|
||
-H "Content-Type: application/json" \
|
||
-d '{"email":"root@example.com","password":"Root@123456"}'
|
||
|
||
# 创建用户(替换 TOKEN)
|
||
curl -X POST http://localhost:8000/api/users \
|
||
-H "Authorization: Bearer TOKEN" \
|
||
-H "Content-Type: application/json" \
|
||
-d '{"name":"Alice","email":"alice@example.com","password":"Password123"}'
|
||
|
||
# 获取用户列表(替换 TOKEN)
|
||
curl -X GET http://localhost:8000/api/users \
|
||
-H "Authorization: Bearer TOKEN"
|
||
```
|