在JSP中获取URL参数:几种经典方法详解

处理URL参数(比如 ?xx=yy 中的 xx)是JSP开发中的常见操作。这事儿其实不难,关键在于选对方法。下面咱们就聊聊几种主流方式,从最现代的到比较传统的都有。

一、使用 EL 表达式(推荐,最简洁)

要说方便,EL表达式当仁不让。它能让代码干净不少,也不用纠结那些繁琐的脚本片段。


参数xx的值是:${param.xx}

xx参数存在,值是:${param.xx}

第一个值:${paramValues.xx[0]}

第二个值:${paramValues.xx[1]}

二、使用 JSP 脚本(传统方式)

在一些老项目或者特定场景下,可能还是会遇到传统的JSP脚本方式。它的好处是直接,所有逻辑一手掌控。

<%
    // 获取单个参数值
    String xxValue = request.getParameter("xx");
    
    // 获取多值参数
    String[] xxValues = request.getParameterValues("xx");
%>


参数xx的值是:<%= xxValue %>

<% if (xxValues != null && xxValues.length > 1) { %>

所有值:

    <% for (String value : xxValues) { %>
  • <%= value %>
  • <% } %>
<% } %>

三、完整示例

光说不练假把式,来看一个把两种方法都囊括的完整页面例子,这样对比就更清晰了。

<%@ page contentType="text/html;charset=UTF-8" language="ja va" %>


    获取URL参数示例


    

URL参数获取演示

使用EL表达式:

参数xx的值:${param.xx}

参数yy的值:${param.yy}

xx参数存在,值是:${param.xx}

xx参数不存在

使用JSP脚本:

<% String xx = request.getParameter("xx"); String yy = request.getParameter("yy"); if (xx != null && !xx.trim().isEmpty()) { %>

参数xx的值:<%= xx %>

<% } else { %>

xx参数不存在或为空

<% } %>
<% String keyword = request.getParameter("keyword"); if (keyword != null) { %>

搜索结果显示:

您搜索的关键词是:<%= keyword %>

<% } %>

四、实际应用场景

了解了基本操作,咱们再看看这些技巧在实战中怎么用。

1. 搜索功能

这大概是URL参数最经典的用武之地了。


<%
    String keyword = request.getParameter("keyword");
    String category = request.getParameter("category");
    
    // 执行搜索逻辑...
%>

搜索结果

关键词:${param.keyword}

分类:${param.category}

2. 分页功能

列表分页离不开 pagesize 这两个参数。


<%
    int page = Integer.parseInt(request.getParameter("page") != null ? 
                request.getParameter("page") : "1");
    int size = Integer.parseInt(request.getParameter("size") != null ? 
                request.getParameter("size") : "10");
    
    // 分页查询逻辑...
%>

当前第 ${param.page} 页,每页 ${param.size} 条

3. 带默认值的处理

用户可能不传某些参数,这时设置合理的默认值就非常有必要。




当前页码:${pageNum}

每页大小:${pageSize}

五、重要注意事项

方法会用了,但还有几个关键点必须时刻牢记,这能避免很多“坑”。

空值处理:永远不要假设参数一定存在,判空是基本功。

编码问题:遇到中文参数乱码?很可能是URL编码没处理好。


<%
    String keyword = request.getParameter("keyword");
    if (keyword != null) {
        keyword = new String(keyword.getBytes("ISO-8859-1"), "UTF-8");
    }
%>

安全性:这是重中之重。用户输入的参数直接输出到页面是XSS攻击的温床,务必进行转义。


<%@ taglib prefix="fn" uri="http://ja va.sun.com/jsp/jstl/functions" %>

安全显示:${fn:escapeXml(param.userInput)}

总结

总而言之,在大多数情况下,EL表达式都是获取URL参数更优、更现代的选择,它能显著提升代码的可读性和可维护性。

本文转载于:https://www.jb51.net/program/352866f71.htm 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。