两种方法在JS中使用项目根路径,以及从reques获取各种路径总结

一、在当前JSP中的java代码中获取,再在JS中获取

<%

String path = request.getContextPath();
String basePath = request.getScheme() + "://" + request.getServerName() +  ":"   + request.getServerPort()
         + path + "/";
   %>

再在JS中调用:

       var basePath = '<%=basePath%>';
       alert(basePath); //http://localhost:8080/


二、在跳入当前页面的action中获取根路径,放入request中,再在JS中获取

String path = request.getContextPath();
String basePath = request.getScheme() +  "://"
         + request.getServerName() +  ":"  + request.getServerPort()
         + path +  "/" ;
request.setAttribute( "basePath" , basePath);

再在JS中通过EL表达式调用:
var  basePath = ${ 'basePath' };
alert(basePath);  //http://localhost:8080/


三、从reques获取各种路径总结

equest.getRealPath() 这个方法已经不推荐使用了,代替方法是:

request.getSession().getServletContext().getRealPath()


在servlet里用this.getServletContect().getRealPath()

在struts里用this.getServlet().getServletContext().getRealPath()

在Action里用ServletActionContext.getRequest().getRealPath();

 

以上三个获得都是当前运行文件在服务器上的绝对路径


从request获取各种路径总结 
request.getRealPath("url"); // 虚拟目录映射为实际目录 
request.getRealPath("./");    // 网页所在的目录 
request.getRealPath("../"); // 网页所在目录的上一层目录 
request.getContextPath();    // 应用的web目录的名称 
如http://localhost:7001/bookStore/ 
/bookStore/ => [contextPath] (request.getContextPath()) 
获取Web项目的全路径 
String strDirPath = request.getSession().getServletContext().getRealPath("/"); 
以工程名为TEST为例: 
(1)得到包含工程名的当前页面全路径:request.getRequestURI() 
结果:/TEST/test.jsp 
(2)得到工程名:request.getContextPath() 
结果:/TEST 
(3)得到当前页面所在目录下全名称:request.getServletPath() 
结果:如果页面在jsp目录下 /TEST/jsp/test.jsp 
(4)得到页面所在服务器的全路径:application.getRealPath("页面.jsp") 
结果:D:\resin\webapps\TEST\test.jsp 
(5)得到页面所在服务器的绝对路径:absPath=new java.io.File(application.getRealPath(request.getRequestURI())).getParent(); 
结果:D:\resin\webapps\TEST 
2.在类中取得路径: 
(1)类的绝对路径:Class.class.getClass().getResource("/").getPath() 
结果:/D:/TEST/WebRoot/WEB-INF/classes/pack/ 
(2)得到工程的路径:System.getProperty("user.dir") 
结果:D:\TEST 
3.在Servlet中取得路径: 
(1)得到工程目录:request.getSession().getServletContext().getRealPath("") 参数可具体到包名。 
结果:E:\Tomcat\webapps\TEST 
(2)得到IE地址栏地址:request.getRequestURL() 
结果:http://localhost:8080/TEST/test 
(3)得到相对地址:request.getRequestURI() 
结果:/TEST/test



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
F12是浏览器的调试工具,可以查看网页的源代码和各种监测信息。使用F12的source功能可以查看网页加载的各种文件的路径,如CSS文件、JavaScript文件等等。但是,有时候我们可能希望隐藏这些文件的路径信息,以保护网站的安全性或者其它需要。 禁止F12source功能看到文件路径方法,有以下两种: 一种方法是通过设置web服务器来实现: 在Apache服务器,可以在.htaccess文件添加以下代码,可以禁止查看HTML和PHP文件的源代码: <Files ~ "(\.html|\.php)$"> Order allow,deny Deny from all </Files> 在IIS服务器,可以在web.config文件添加以下代码,可以禁止查看HTML和ASP文件的源代码: <system.webServer> <security> <requestFiltering> <hiddenSegments> <add segment="includes" /> </hiddenSegments> </requestFiltering> </security> </system.webServer> 这些设置将禁止访问所选定的目录或文件夹,即使是通过F12 source也无法查看它们的路径信息。 另外一种方法是通过JavaScript的代码来实现: 可以在JavaScript代码添加以下代码,可以阻止F12 source查看JavaScript文件的路径信息: if(window.console && window.console.log){ console.log('%cThis page is protected by the developer console.","red'); setInterval(function(){ var styles = ["background: red", "color: white", "padding: 1px", "display: block", "text-align: center"].join(";"); console.clear(); console.log('%c ', styles); console.log('%c别想看我的JS源代码!',"font-size:40px;color:white;background-color:pink;"); },1000); } 这个方法在控制台输出警告信息,并限制console.clear()函数。每秒钟清除一次控制台,并不断重复地打印警告信息,保护代码的安全性。 总之,禁止F12 source看到文件路径方法有很多,需要据具体的需求,选择相应的技术来实现。在开发和设计网站时,保护代码和页面的安全非常重要,需要充分考虑安全性问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值