高级用户搜索
直接使用 Management API 利用高级用户搜索条件。
执行搜索请求
使用 GET /api/users
来搜索用户。请注意,它是一个需要认证的 Management API。请参阅 与 Management API 交互 以获取交互指南。
示例
请求
curl \
--location \
--request GET \
'http://<your-logto-endpoint>/api/users?search=%25alice%25'
响应
一个 User
实体的数组。
[
{
"id": "MgUzzDsyX0iB",
"username": "alice_123",
"primaryEmail": "alice@some.email.domain",
"primaryPhone": null,
"name": null,
"avatar": null
// ...
}
]
参数
搜索请求由以下参数键组成:
- 搜索关键词:
search
,search.*
- 字段的搜索模式:
mode
,mode.*
(默认值'like'
,可用['exact', 'like', 'similar_to', 'posix']
) - 联合模式:
joint
或jointMode
(默认值'or'
,可用['or', 'and']
) - 是否区分大小写:
isCaseSensitive
(默认值false
)
此 API 启用了分页。
让我们通过一些示例来了解它们。所有搜索参数将被格式化为 URLSearchParams
的构造函数。
搜索模式默认设置为 like
,使用近似字符串匹配(“模糊搜索”)。
所有模糊搜索模式仅支持每个字段匹配一个值。如果你需要为单个字段匹配多个值,你应该使用“exact”模式。详情请参阅精确匹配和区分大小写。
基本模糊搜索
如果你想在所有可用字段上执行模糊搜索,只需为键 search
提供一个值。它将在底层使用like
操作符:
new URLSearchParams([['search', '%foo%']]);
此搜索将遍历用户搜索中的所有可用字段,即 id
,primaryEmail
,primaryPhone
,username
,name
。
指定字段
如果你只想在 name
中限制搜索呢?要搜索名字中包含 foo
的人,只需使用 .
符号指定字段:
new URLSearchParams([['search.name', '%foo%']]);
请记住,不支持嵌套字段,例如 search.name.first
会导致错误。
你还可以同时指定多个字段:
new URLSearchParams([
['search.name', '%foo%'],
['search.primaryEmail', '%@gmail.com'],
]);
意味着搜索名字中有 foo
或 电子邮件以 @gmail.com
结尾的用户。
更改联合模式
如果你希望 API 仅返回满足所有条件的结果,请将联合模式设置为 and
:
new URLSearchParams([
['search.name', '%foo%'],
['search.primaryEmail', '%@gmail.com'],
['joint', 'and'],
]);
意味着搜索名字中有 foo
且 电子邮件以 @gmail.com
结尾的用户。
精确匹配和区分大小写
假设你想搜索名字精确为 "Alice" 的人。你可以设置 mode.name
使用精确匹配。
new URLSearchParams([
['search.name', 'Alice'],
['mode.name', 'exact'],
]);
你可能会发现使用 like
模式(默认)与指定 exact
时效果相同。一个区别是 exact
模式使用 =
进行比较,而 like
使用 like
或 ilike
。理论上 =
应该有更好的性能。
此外,在 exact
模式下,你可以传递多个值进行匹配,它们将用 or
连接:
new URLSearchParams([
['search.name', 'Alice'],
['search.name', 'Bob'],
['mode.name', 'exact'],
]);
它将匹配名字为 "Alice" 或 "Bob" 的用户。
默认情况下,搜索是不区分大小写的。为了更精确,可以将搜索设置为区分大小写:
new URLSearchParams([
['search.name', 'Alice'],
['search.name', 'Bob'],
['mode.name', 'exact'],
['isCaseSensitive', 'true'],
]);
注意 isCaseSensitive
是一个全局配置。因此每个字段都会遵循它。
正则表达式 (RegEx)
PostgreSQL 支持两种类型的正则表达式,similar to 和 posix。设置 mode
为 similar_to
或 posix
以通过正则表达式进行搜索:
new URLSearchParams([
['search', '^T.?m Scot+$'],
['mode', 'posix'],
]);
注意模式 similar_to 仅在区分大小写的搜索中有效。
匹配模式覆盖
默认情况下,所有关键词将继承一般搜索的匹配模式:
new URLSearchParams([
['search', '^T.?m Scot+$'],
['mode', 'posix'],
['search.primaryEmail', 'tom%'], // Posix 模式
['joint', 'and'],
]);
要为特定字段覆盖:
new URLSearchParams([
['search', '^T.?m Scot+$'],
['mode', 'posix'],
['search.primaryEmail', 'tom%'], // Like 模式
['mode.primaryEmail', 'like'],
['search.phone', '0{3,}'], // Posix 模式
['joint', 'and'],
]);