AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1001212
Accepted
Sandeep Koparde
Sandeep Koparde
Asked: 2020-02-01 01:39:16 +0800 CST2020-02-01 01:39:16 +0800 CST 2020-02-01 01:39:16 +0800 CST

如何在 URL 参数中的 HTTP 基本身份验证密码中传递问号 (?)?

  • 772

我正在自动化一个需要 HTTP 基本身份验证的网站。

在大多数情况下,此链接中给出的建议就像一个魅力:

您可以在 URL 参数中传递用户/密码以进行 HTTP 基本身份验证吗?

但是,有些用户的密码中有问号 ( ?)。请告知如何转义问号。

PS我知道@在用户名中可以转义为%40.

url .htaccess selenium encoding
  • 1 1 个回答
  • 4317 Views

1 个回答

  • Voted
  1. Best Answer
    MrWhite
    2020-02-01T16:09:05+08:002020-02-01T16:09:05+08:00

    我假设您必须引用传递用户凭据的 URL 的userinfo部分,而不是“URL 参数”(它是query-string的一部分):

    https://<userinfo>@example.com/foo?<query-string>
    

    对于 URL 的任何部分中不允许出现的任何字符(因为它可能具有特殊含义),它必须是 URL 编码 ( percent-encoded )%后跟该字符的两位十六进制代码。

    所以,@是%40和?是%3F。

    但这些并不是唯一可能需要 URL 编码的两个字符。您应该通过脚本中的 URL 编码函数传递值,以正确地对 URL 的该部分进行 URL 编码。

    RFC 3986定义了 URL 的userinfo部分中允许(未编码)的字符:

    userinfo    = *( unreserved / pct-encoded / sub-delims / ":" )
    unreserved  = ALPHA / DIGIT / "-" / "." / "_" / "~"
    pct-encoded = "%" HEXDIG HEXDIG
    sub-delims  = "!" / "$" / "&" / "'" / "(" / ")"
    
                  / "*" / "+" / "," / ";" / "="
    

    因此,其他所有内容都必须进行百分比编码,包括:和%- 如果它们是用户或密码部分的一部分(为了否定那里的特殊含义)。

    在同一份文件中也有说明:

    不推荐在 userinfo 字段中使用“user:password”格式。

    因此,浏览器支持不完整,版本不断更新(安全性是主要问题)。我相信最新版本的 Chrome(经过测试的 v79)和 Firefox 确实支持 URL 中的用户凭据。我已经看到评论说这也适用于最新的 Safari(?),虽然这已经很久没有工作了,而且它目前对我不起作用(虽然我没有在 iOS 12.4.1 上运行最新的)。几年前,IE 放弃了对 URL 中用户名和密码的支持,而且看起来它不会回来了。

    • 3

相关问题

  • Sane Sharepoint 2007 网址

  • IIS 7 中的 URL 重写

  • 为什么有些网站的网址中没有“www”就无法显示?[关闭]

  • 如何将 URL 添加到 wiki (MediaWiki) 支持的文档?

  • 如何强制我的网址始终以 www 开头?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve