gpt4 book ai didi

jsp - 如何使用jsp测试request.getHeader中的值?

转载 作者:行者123 更新时间:2023-12-05 00:03:35 24 4
gpt4 key购买 nike

我设置了一个变量:

<% String userAgent = request.getHeader("user-agent");%>

如何使用 userAgent 测试不同的场景
<c:choose></c:choose>

我不知道如何设置?

最佳答案

您不想将 scriptlet 与 taglibs/EL 混合使用。它们不在同一范围内运行。

所有请求头都在 EL 中,由隐式映射对象 ${header} 提供.自 user-agent标题名称包含特殊字符 -以便 ${header.user-agent}没有按预期工作,您需要使用大括号表示法 []引用它。

${header['user-agent']}

所以,这应该做:

<c:choose>
<c:when test="${fn:contains(header['user-agent'], 'Gecko')}">
You're pretending to use a Gecko based browser.
</c:when>
<c:when test="${fn:contains(header['user-agent'], 'MSIE')}">
You're pretending to use a MSIE based browser.
</c:when>
<c:when test="${fn:contains(header['user-agent'], 'Webkit')}">
You're pretending to use a Webkit based browser.
</c:when>
<c:otherwise>
It's not clear which browser you're pretending to use.
</c:otherwise>
</c:choose>

无关 问题:以这种方式检查用户代理 header 是一种代码异味。用户代理头完全由客户端控制,很容易被伪装成一个完全不同的值(这就是我在上面的代码示例中使用术语“伪装”的原因)。如何正确解决真正的功能需求,你想详细说明一下真正的功能需求。

例如,在 JavaScript 中你应该更喜欢 feature detection通过浏览器检测。

或者当你想根据媒体类型加载特定的样式表时,你应该使用 media attribute .例如。
<link rel="stylesheet" href="screen.css" media="screen,projection,tv" />
<link rel="stylesheet" href="smartphone.css" media="only screen and (max-device-width:480px)"/>
<link rel="stylesheet" href="handheld.css" media="handheld" />
<link rel="stylesheet" href="print.css" media="print" />

或者,当您想向最终用户呈现用户代理 header 中信息的用户友好摘要时,您想使用单独的服务,例如 http://user-agent-string.info/ .他们还提供 Java API example .

关于jsp - 如何使用jsp测试request.getHeader中的值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6792053/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com