微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

正则表达式只允许这些 [A-Z] / [a-z] / [0-9] / "-" / "." / "_" / "~"

如何解决正则表达式只允许这些 [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 之前的点。

Source for most definitions

所以我们可以看到您的正则表达式当前执行以下操作:

它首先匹配单个字符 a-z A-Z 0-9 ~ - _ 或 。在字符串的开头。然后它匹配任何非空白字符 42-128 次,并期望输入的结尾紧随其后。这意味着我们期望一个总长度为 43-129 个字符的字符串。

正如您的问题所述,您只想匹配这些特定字符,因此您的表达式实际上应该是这样的(我已删除了 \S):

^[a-zA-Z0-9~\-_.]{42,128}$

至于您的具体输入:

longenoughlongenoughlongenoughlongenoughlongenoughlongenoughlongenoughlongenoughAABSC__-......~~~.~-!

您似乎在输入的末尾包含了感叹号 (!),这当然与您的约束不符。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?