如何解决正则表达式只允许这些 [A-Z] / [a-z] / [0-9] / "-" / "." / "_" / "~"
我需要找到一种使用正则表达式的方法来验证我作为参数获取的字符串
这必须是一个仅由以下字符组成的单词:[A-Z] / [a-z] / [0-9] / "-" / "." / "_" / "~"
我尝试过的
var pattern = @"^[a-zA-Z0-9~\-_.]\S{42,128}$";
if (!Regex.IsMatch(authorizationRequest.CodeChallenge,pattern))
{
return new PkceResponse
{
IsValid = false,Error = OIDCErrorCodes.InvalidRequest,ErrorDescription = "Code Challenge contains invalid characters",ParameterName = "code_challenge"
};
}
但是我的测试失败了这个输入:
longenoughlongenoughlongenoughlongenoughlongenoughlongenoughlongenoughlongenoughAABSC__-......~~~.~-!
我错过了什么?
解决方法
你的表达如下:
^[a-zA-Z0-9~\-_.]\S{42,128}$
让我们把它分解成它的组成部分:
-
^
- 匹配输入的开头。 -
[a-zA-Z0-9~\-_.]
- 匹配单个字符 a-z A-Z 0-9 ~ - _ 或 . -
\S
- 匹配除空白字符以外的任何字符。 -
{42,128}
- 匹配前一个元素至少 42 次,最多 128 次。在这种情况下,前一个元素是\S
。 -
$
- 匹配输入的结尾,或输入结尾最后一个 \n 之前的点。
所以我们可以看到您的正则表达式当前执行以下操作:
它首先匹配单个字符 a-z A-Z 0-9 ~ - _ 或 。在字符串的开头。然后它匹配任何非空白字符 42-128 次,并期望输入的结尾紧随其后。这意味着我们期望一个总长度为 43-129 个字符的字符串。
正如您的问题所述,您只想匹配这些特定字符,因此您的表达式实际上应该是这样的(我已删除了 \S
):
^[a-zA-Z0-9~\-_.]{42,128}$
至于您的具体输入:
longenoughlongenoughlongenoughlongenoughlongenoughlongenoughlongenoughlongenoughAABSC__-......~~~.~-!
您似乎在输入的末尾包含了感叹号 (!
),这当然与您的约束不符。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。