struts/Servlet,action转到jsp后,路径问题(struts2,jsp路径,action路径,action跳转,相对路径,绝对路径)

问题:使用struts2,如何处理action的路径?还有,在action转到的jsp中,如何写js,css,图

片的路径?(例如访问 http://localhost/project/listUser.action后转到http://localhost/project/user /listUser.jsp,这时候浏览器还是停留在http://localhost/project/addUser.action。这时候jsp原来的图片定位可能就都出错了) 答:action的话,就不需要关心路径问题。我们不使用action的命名空间。因为使用了这样的匹配:     <filter-mapping>         <filter-name>struts2</filter-name>         <url-pattern>*.action</url-pattern>     </filter-mapping> 无论前边是什么路径,struts2只看后边的匹配。 而解决jsp的路径问题,我觉得以下方式就基本完美了(有问题,请各位前辈指出): 第一步:在jsp的head中添加base标签和一段java <%     String path = request.getContextPath();     String basePath = request.getScheme() + "://"             + request.getServerName() + ":" + request.getServerPort()             + path + "/"; %> <base href="<%=basePath%>"> 第二步:所有的路径使用“半绝对路径”。所谓半绝对路径,是我乱说的。例如:<link rel="stylesheet" type="text/css" href="style/table.css" /> 这种本来是相对路径,就是当前jsp目录下的style目录的table.css。 在我们struts2和配置了base的前提下,这里就会被浏览器解释为http://localhost/project/style/table.css。 也就是说,需要写从项目根目录算起的绝对路径,但去掉开头的"/" 第三步:所有action跳转,form提交写的action路径,都不要带目录位置。只写action名,例如addUser.action。 这样,浏览器就一直停留在http://localhost/project/XXXXX.action  这一层。

另外,我发现另外一个更自然的办法,可以使得原来用相对路径定位的jsp继续可用,不必逐个修改链接:

第一步:在jsp的head中同样添加base,但把getContextPath改为getRequestURI d <%     String path = request.getRequestURI();     String basePath = request.getScheme() + "://"             + request.getServerName() + ":" + request.getServerPort()             + path; %> <base href="<%=basePath%>"> 注意是request.getRequestURI,这样获取出来的正好就是jsp的绝对路径。 例如浏览器地址栏是:http://localhost:8084/project/listUser.action base是<base href="http://localhost:8084/project/admin/listUser.jsp"> 第二步:jsp页面内,全部使用相对路径访问。 第三步,就不必管action的路径如何了。 这个方法,可以兼容使用action和不使用action两种情况

另外,在struts.xml中配置jsp路径的时候使用项目的绝对路径。例如listUser.jsp在根目录下的admin目录下,就写

<result>/admin/listUser.jsp</result>

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏信安之路

Cobalt Strike 初体验

Cobalt Strike 一款以 metasploit 为基础的 GUI 的框架式渗透测试工具,集成了端口转发、服务扫描,自动化溢出,多模式端口监听,win ...

760
来自专栏晨星先生的自留地

提权(1)信息收集

2774
来自专栏知识分享

邪恶改装:TPYBoard制作廉价WIFI干扰器

转载请注明:@小五义http://www.cnblogs.com/xiaowuyi

1167
来自专栏月色的自留地

在龙芯小本上安装Debain8.10

1696
来自专栏SAP梦心的SAP分享

【SAP业务模式】之ICS(七):IDOC配置

     这是ICS业务模式系列的最后一篇了,主要讲解IDOC的配置。      一、指定EDI传输的供应商逻辑地址      事务代码:WEL1 ?     ...

1927
来自专栏FreeBuf

真实网站劫持案例分析

1. 概述 上段时间一直忙于处理大会安全保障与应急,借助公司云悉情报平台,发现并处置几十起网站被劫持的情况。对黑客SEO技术颇有感觉。正好这段时间有时间,把以前...

4035
来自专栏区块链

我们不一样的黑客渗透教程第三课,CVE20177269实战测试

很多人想学黑客知识,却不知如何入门,网上的教程也太繁琐,小白看了也头疼,那还是我来写黑客系列入门教程吧,跟着我做,你能黑客入门的。我已经写了两篇了,第1篇在 《...

2536
来自专栏FreeBuf

用Raspberry Pi Zero打造「即插即用」的Web服务器

*本文原创作者:yfgeek,未经许可禁止转载 虽然Raspberry Pi Zero只有4.5英镑,非常便宜,但确实具有局限性,由于缺少网口、WiFi,功能比...

2729
来自专栏DeveWork

WordPress中借助.htaccess屏蔽某个IP或某个IP段(防垃圾评论)

最近本站DeveWork.com 老是被来自142.4.108.109这个ip的垃圾评论骚扰,看来之前的《代码实现 WordPress 反垃圾评论功能》用处还是...

19410
来自专栏晨星先生的自留地

黑客技能训练:攻破MrRobot

1504

扫码关注云+社区