在ThinkPHP 6中,要实现通过每个用户的密钥访问的对外开放用户信息API接口,你需要为每个用户分配一个唯一的密钥,并在API请求中验证这个密钥。以下是一个简单的示例,展示了如何实现这个功能:
1.生成和存储用户密钥
首先,你需要有一个系统来生成和存储每个用户的唯一密钥。这通常可以通过在数据库中为用户表添加一个密钥字段来实现。例如,你可以在
user
表中添加一个api_key
字段。
2.定义路由
在
route/api.php
文件中定义API路由:
use think\facade\Route;
// 假设你的API接口是/api/user/{user_id}/info
Route::get('api/user/:user_id/info', 'api/User/info');
这里使用了路由参数user_id
来指定要查询的用户。
3.创建控制器
在
app/api
目录下创建User.php
控制器文件,并添加以下代码
<?php
namespace app\api;
use think\Controller;
use think\Request;
use app\model\User as UserModel;
class User extends Controller
{
public function info(Request $request, $user_id)
{
// 从请求中获取API密钥
$apiKey = $request->param('api_key');
// 查找用户信息,并验证API密钥
$userModel = new UserModel();
$user = $userModel->where('id', $user_id)->where('api_key', $apiKey)->find();
if (!$user) {
// 如果用户不存在或API密钥不正确,返回401错误
return json(['error' => 'Invalid user or API key'], 401);
}
// 返回用户信息(根据需要可以只返回部分字段)
return json($user);
}
}
在这个控制器中,我们首先从请求中获取API密钥,然后使用这个密钥和用户ID来查询数据库中的用户信息。如果找不到用户或者API密钥不正确,我们返回401错误。如果验证通过,我们返回用户信息。
4.创建模型
<?php
namespace app\model;
use think\Model;
class User extends Model
{
// 定义表名
protected $table = 'user';
// 定义主键
protected $pk = 'id';
// 其他模型方法...
}