javascript - 图形 API 无法识别给定过滤器字符串中的“#”
问题描述
我正在尝试使用筛选参数从 Azure AD 获取用户。例如,如果我想要电子邮件 ID 为 "Alex.ferguson@mutd.com" 的用户,以下将是我的请求,这对于给定的电子邮件工作正常。
var filteredUsers = await client
.api("/users")
.select("displayName,userPrincipalName,jobTitle,companyName,id")
.filter("userPrincipalName eq 'Alex.ferguson@mutd.com'")
.get();
但是,如果电子邮件中包含“#”字符并且我的过滤器查询看起来像
"userPrincipalName eq 'wayne.rooney#Wazza#@mutd.com'"
api 给了我 400 Bad request 错误。url 路径看起来像这样
https://graph.microsoft.com/v1.0/users?$select=displayName,userPrincipalName,jobTitle,companyName,id&$filter=userPrincipalName%20eq%20%27wayne.rooney
电子邮件在第一个“#”字符处被修剪。我能做些什么呢。我的 Azure AD 中有许多用户,其电子邮件 ID 带有“#”字符。我尝试在 '#' 之前使用转义字符 '',仍然没有用。
解决方案
尝试对电子邮件进行编码。
https://graph.microsoft.com/v1.0/users?$filter=userPrincipalName eq 'wayne.rooney%23Wazza%23%40mutd.com'
在你的代码中
var filteredUsers = await client
.api("/users")
.select("displayName,userPrincipalName,jobTitle,companyName,id")
.filter("userPrincipalName eq 'wayne.rooney%23Wazza%23%40mutd.com'")
.get();
推荐阅读
- python - 在二叉搜索树中查找地板和天花板
- javascript - 如何同步绘图?
- batch-file - 如何使用 robocopy 从变量创建新文件夹?
- python - 如何使用准备好的语句将可变数量的值插入到 SQLite 中的表中
- excel - 查找日期格式的文本并将其替换为当前日期
- c++ - 在 VS C++ 调试器中调查变量
- firebase - 使用令牌信息创建地图时出错
- android - Dagger Hilt Android 给出错误:类 DefaultViewModelFactories 中的方法 getActivityFactory 不能应用于给定类型
- c - 在 XV6 中双重获得自旋锁
- arrays - 为什么此数组比较在 Google 表格中不起作用(使用 Apps 脚本)?