JSP中用request.getParameter("name")替代PHP的$_GET["name"]或$_POST["name"],需注意返回字符串且可能为null,HTTP方法须用request.getMethod()判断;中文参数需先调用request.setCharacterEncoding("UTF-8")。

PHP的$_GET、$_POST在JSP里怎么写
JSP没有全局超全局数组,必须显式从HttpServletRequest对象取值。直接写request.getParameter("name")替代$_GET["name"]或$_POST["name"],注意它只返回字符串(且可能为null),没有自动区分GET/POST——HTTP方法需用request.getMethod()判断。
常见错误:直接套用PHP思维写request["name"]或$_POST.name,会报javax.servlet.ServletException或ELException。
- 若需兼容GET和POST,统一用
request.getParameter("key") - 获取多个同名参数用
request.getParameterValues("key")(对应PHP的$_GET["key"][]) - 中文参数务必在
request.setCharacterEncoding("UTF-8")后调用,否则乱码
JSP里没有echo和print_r等输出函数
JSP默认使用EL表达式${variable}或JSTL 输出,脚本片段中才用out.print()——它才是最接近PHP echo的等价物,但必须确保out已存在(JSP隐式对象)。
print_r($arr)这种调试输出在JSP里没有内置等价物,得手写循环或用java.util.Arrays.toString()(仅限一维数组);复杂结构建议用com.fasterxml.jackson.databind.ObjectMapper转JSON再输出,或直接用IDE调试。
立即学习“PHP免费学习笔记(深入)”;
- 避免在JSP中混用
和${...},易导致输出顺序错乱 -
out.println()会多输出换行,HTML中可能破坏布局 - JSTL
比裸${obj}更安全,防XSS
PHP的include和require在JSP中对应什么
JSP有两个机制:是运行时包含(类似include),是编译时静态包含(更像require)。关键区别在于:前者每次请求都检查被包含文件是否变化,后者只在JSP第一次编译时读入,改了被包含文件不生效,必须重启应用或清work目录。
容易踩坑的是路径:JSP中file属性只接受相对路径(相对于当前JSP),而page属性支持以/开头的Web应用根路径。
- 动态内容(如带参数的头尾)用
,并配合 - 静态模板(如CSS/JS引用、常量定义)用
- 不要用
file包含WEB-INF下的文件——Servlet规范禁止外部直接访问,会404
PHP的$_SESSION和$_COOKIE怎么迁移
JSP里session通过request.getSession()获取HttpSession对象,存取用setAttribute("key", obj)和getAttribute("key"),不是数组式访问。Cookie需手动创建Cookie对象再response.addCookie(),读取则遍历request.getCookies()数组匹配名字。
注意默认session有效期是30分钟(web.xml可配),且session.getAttribute()返回Object,必须强转;cookie值不能含空格、逗号、分号等特殊字符,PHP自动urlencode,JSP要自己调URLEncoder.encode(value, "UTF-8")。
- 判断session是否存在:用
request.getSession(false) == null,而非session == null - 销毁session用
session.invalidate(),不是unset($_SESSION) - cookie的path设为
/才能跨子路径共享,PHP默认如此,JSP需显式设置cookie.setPath("/")
java.text.SimpleDateFormat或java.util.Collections.sort()补足,别指望JSP标签或EL能覆盖全部PHP函数能力。











