项目基础结构(项目地址 : 项目地址:https://github.com/luocaca/models.git )
--
现在我们讲一讲 jsp 引入过程中404搞得你措手不及
本次排查解决的几个问题:
1. 引入jsp出现404 去源码中排查
2. thymeleaf 与 jsp 共存问题
--前排申明-- (不然怕你们项目跑起来不会登陆)
username:root
password:root
data:image/s3,"s3://crabby-images/77bca/77bca4ddfcb0272f3538585edefe353626f5da49" alt=""
一.(jsp引入前准备)
web项目引入,本文以 model-web 模块进行展开
data:image/s3,"s3://crabby-images/030f3/030f3909cdc88685e6da82f29a24554d80431523" alt=""
- 新建一个model-web ,这个就不说了,右键models,命名 model-web,本model就是这么来的 ,O(∩_∩)O哈哈~
data:image/s3,"s3://crabby-images/8b6da/8b6dadb22a5ee15c82279097987aece46363b583" alt=""
- 手动建一个 webapp.WEB-INF.jsp.index.jsp 文件
data:image/s3,"s3://crabby-images/a2b0a/a2b0a5695ee1969ece4b76f078a26e1377f577fd" alt=""
- 配置model的 project Structure (译文:项目结构)
data:image/s3,"s3://crabby-images/a2534/a25346517570aedf7785cd786ccd04037532d030" alt=""
-或者
data:image/s3,"s3://crabby-images/9bfd0/9bfd0820908a788b68221ecf4fefafd5ba39f139" alt=""
-
data:image/s3,"s3://crabby-images/1ecfc/1ecfc85a715de178df8d3ad37512cdf249395501" alt=""
- 配置完webapp 目录与 web.xml 就能够让项目顺利找到 webapp 下边的文件了
二 (jsp 引入相关包 maven 包)
--
data:image/s3,"s3://crabby-images/9cdef/9cdef73031b74c01debdbe2b7de4c2391bb51873" alt=""
-- jsp 配置文件,设置前缀,后缀,源目录在webapp ,刚刚已经设置过一次了
data:image/s3,"s3://crabby-images/cdbb4/cdbb408cd6431c0d55cb5c5a72c989e95ed7e907" alt=""
三(配置完毕,开跑.... run 起来 8082端口 )
data:image/s3,"s3://crabby-images/334a9/334a93eca71f0ee34ac88ce0c9079faaa037eaf3" alt=""
接下来 open in brower
访问 toIndexJsp
data:image/s3,"s3://crabby-images/d3e4f/d3e4f0cdc34e3c7e62db57a296b7c7fc77bb5b6a" alt=""
进入断点,继续跑一下
data:image/s3,"s3://crabby-images/5b3ea/5b3ea8842204801f734bff7c42f180f1d2c7ab0d" alt=""
搜嘎,咋回事,404白板,看看文件目录,
data:image/s3,"s3://crabby-images/bf402/bf402c0f3ea17abc47c8389f8992d7141f394fe3" alt=""
/WEB-INF/jsp/index.jsp
没毛病啊,对应的位置也是有的啊。什么鬼,没辙,找原因呗。
咋办,想不出哪里有问题 ,问问度娘吧。
data:image/s3,"s3://crabby-images/1a48c/1a48cefef35734ecc44b81ed620a6c7fb63ea37c" alt=""
看了几篇,大概可以定位到问题所在,
1.修改一下运行配置
data:image/s3,"s3://crabby-images/54c65/54c65eb41db239fc3b0fde3dbb76fe9816fc7e8d" alt=""
新增一个配置 ,这个是我的 项目位置,你们要改成你们项目所在位置(D:\android_luocaca\idea_workpase\models\model-web)model的绝对路径
data:image/s3,"s3://crabby-images/21b55/21b558ef6fb568cfb0bab1694644e22dcac159de" alt=""
data:image/s3,"s3://crabby-images/eaede/eaede8e3f6c0c60cd6bdff148ac09f0f916e9b7a" alt=""
- re run 重新跑一个
data:image/s3,"s3://crabby-images/23e44/23e449eaac2df6856bee5968b1afa14d057aaaee" alt=""
ok 跑起来了,大吉大利,百度老铁,一个字,稳妥。,,,哈哈哈
四 (为啥配置了个路径就没事了,刚才还有问题的。想想,还是想不通,估计是绝对路径跟相对路径的问题吧)
但是我还想找找具体原因 404 哪里产生的?
- 404 产生的原因
(*^▽^*),我问问百度,
data:image/s3,"s3://crabby-images/efb87/efb87e9340326523cc5e89656297667460eb5100" alt=""
好多啊,一两天看不完,
-- 我们知道spring boot 嵌入内置的tomcat 然后通过tomcat 的初始化,将jsp 放到tomcat 容器里面,最后通过spring boot 动态代理去 根据
data:image/s3,"s3://crabby-images/e6505/e65058c68f9fe069d5b2e7e7525505c8ba63fc26" alt=""
data:image/s3,"s3://crabby-images/0bbf7/0bbf703048cf3b2c479a3de604db64a08748d818" alt=""
再插入中间 index 组合成 /WEB-INF/JSP/index.jsp
然后通过这个路径去找到 这个图中的位置
data:image/s3,"s3://crabby-images/d3f37/d3f3754759d6096194d7ac7885e7aed572293086" alt=""
本应该没问题的,但是就是404 白板了,擦 ,咋们现在去tomcat 里面看看到底为什么 找不到了,,,,
五 (找到启动类,断点打一个,咋们看看)
org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory
data:image/s3,"s3://crabby-images/77be9/77be917cab57f0ea49262e5709a29c84f55b3c68" alt=""
tomcat 创建类 ,一个生产者, 提供
data:image/s3,"s3://crabby-images/c6e28/c6e287dad85d232cc1074b7068ee357528326077" alt=""
看到一个prepareContext(tomcat.getHost(), initializers);
准备上下文,打个断点,咋们跟踪一下,里面代码到底怎么写的。嘿嘿。有点多。看得很懵逼。。。。。
data:image/s3,"s3://crabby-images/3454a/3454a3f931becd3ec0f0a2456b871586ff7389fa" alt=""
.耐
.心
.等
.待
runing ....
data:image/s3,"s3://crabby-images/96a0f/96a0fa9bb9410e525b4826a881cc3544f03f044e" alt=""
看到没。汤姆猫 内置spring以后,没处安放,只能偷偷在c盘user下边偷偷建一个临时路径,在里面偷偷跑起来,...嘿嘿嘿
data:image/s3,"s3://crabby-images/cfbad/cfbad08b407eba88283d7d604f4f44dc45bfcfc1" alt=""
继续走起。
data:image/s3,"s3://crabby-images/6e97f/6e97f904e8bfefff2d25be6eb68f3a67ab6c08fb" alt=""
找到了prepareContext 看看上下文环境都做了些什么
data:image/s3,"s3://crabby-images/e64dc/e64dc1aac3a0531fae4322490474d18686d16228" alt=""
f7 继续跟进去看看
data:image/s3,"s3://crabby-images/ab608/ab6087fc9e981282bc7329cfe1aa1ca6dc71f6fe" alt=""
data:image/s3,"s3://crabby-images/d7471/d7471401358df86201352aac80835251c01f3b2e" alt=""
data:image/s3,"s3://crabby-images/9ca72/9ca72b2a2b92276ce3180449a5438b77f1f0101c" alt=""
data:image/s3,"s3://crabby-images/0bc8e/0bc8e303e3e878a99df8b11c1724cb640c49ace0" alt=""
data:image/s3,"s3://crabby-images/f38ff/f38ffe2119b152e8cf096faa81d797b8a9a40e26" alt=""
data:image/s3,"s3://crabby-images/5f2d7/5f2d794389274ef8c5e07214eeb35a12cae8a77c" alt=""
说明当前路径有效,也就是我们刚才设置了
data:image/s3,"s3://crabby-images/1f8b6/1f8b65bfaa4be4b32f155149edced751c0f64995" alt=""
现在能够找到路径位置
现在让我们看看 root 的绝对位置是什么
alt + F8
data:image/s3,"s3://crabby-images/a8581/a8581db449185bd76abdb86c7491d74126d0e97e" alt=""
没毛病,跟我们working dir 设置的位置一样,搜嘎,百度给的答案真的挺准
继续走起,走完断点,后边没什么可看的了,
跑一个
data:image/s3,"s3://crabby-images/fa8b0/fa8b0f261fb2ab0f2cd39781027dfedd4ea98abb" alt=""
data:image/s3,"s3://crabby-images/31c74/31c74bfc33e7ddb8d693f45cbe5b2b1250eadb9b" alt=""
- 回头想想,那刚才怎么不行,那我把working dir 清掉,再看一看这个方法,
来来来,让我们重蹈覆辙
data:image/s3,"s3://crabby-images/ee55d/ee55de79f33df885517e7c3f49a5a7cec52f44a6" alt=""
data:image/s3,"s3://crabby-images/297a6/297a6051a598923db94ee77d5ddd0f15a5b64466" alt=""
data:image/s3,"s3://crabby-images/a40ef/a40ef2deb5310cff02d23fd7aaaac800a1f0a439" alt=""
重debug run
嘿嘿嘿,猫哥。我又来抓你了
data:image/s3,"s3://crabby-images/e48c1/e48c16057ee0574736e1ae82d1761eeb0859f9a3" alt=""
data:image/s3,"s3://crabby-images/69ecb/69ecb56ea7d9ed13ed591b364b99f917cf79aafd" alt=""
data:image/s3,"s3://crabby-images/7ef7f/7ef7fa36c23a802173dd6c04ad190bdecd611a7f" alt=""
正常情况下,应该跟刚才一样 走 root.exists() 就是文件存在
data:image/s3,"s3://crabby-images/24818/248182ebd557c48e4a0b40f6cb0573dcf7b9bea9" alt=""
文件不存在啊,咋们看看root 是 哪来的妖怪,
Alt + F8 root 参数
root.getAbsolutePath()
D:\android_luocaca\idea_workpase\models\public
data:image/s3,"s3://crabby-images/b2276/b2276df4d502ca210af7c290658ba78a410d010c" alt=""
我的天,我是model-web模块,你咋去models里面找了捏
data:image/s3,"s3://crabby-images/5dcfb/5dcfb86c5f5f450651a2d5665276c2174199a464" alt=""
继续走完断点
data:image/s3,"s3://crabby-images/54e79/54e7961c6557b6f521bf7a58d57de44d121d5a82" alt=""
我在想一想,你是不是傻,难道要我把 src/webapp/WEB-INF/jsp/index.jsp
拷到models 下边嘛。你当我傻嘛 。我能那样干嘛。
诶。这想法好。我试试看。把 src/webapp/WEB-INF/jsp/index.jsp 复制到 models 对应的路径下。在试试。
data:image/s3,"s3://crabby-images/86991/8699129b6096165bba53512737c86aabc7c356cc" alt=""
现在我要把 src.main.webapp.web-inf.jsp.index.jsp
复制到models 的目录底下。
data:image/s3,"s3://crabby-images/d4c55/d4c55cf7315a6aafab34ec9da044be13b4d7e2c1" alt=""
应该就有 需要的文件了。
咋们重新跑一个。
抓到汤姆猫以后
直接走到这里
data:image/s3,"s3://crabby-images/91617/916173ca03504fe66bb26281f792cdff91acf5e8" alt=""
data:image/s3,"s3://crabby-images/70da8/70da8167b6e24be056875cb6f32314c3b7716a75" alt=""
那我怎么知道是 model-web还是models 父类的。
哈哈。还是看看绝对路径把。
data:image/s3,"s3://crabby-images/daced/dacedd81e34af987f79da9c6cf64f80577c3fac7" alt=""
用文件打开看看
data:image/s3,"s3://crabby-images/6db52/6db52491d1d9db3e20e37106f5de358134f940eb" alt=""
过了断点,看看
data:image/s3,"s3://crabby-images/067dc/067dcb792042d66ab99f28b41ce20cb3288562df" alt=""
我居然听了tomcat 的鬼话。把model-web的文件复制到models下边去,被别人看到。一定会笑话我的。
现在我把working dir 改回原来项目路径
D:\android_luocaca\idea_workpase\models\model-web
data:image/s3,"s3://crabby-images/adf1d/adf1df288929515d9097468d0ec0565c2c22af2d" alt=""
rerun ing
.稍
.等
.一
.下
data:image/s3,"s3://crabby-images/9e2ad/9e2ad724e5ea680f96283ea5513f66ba0494a8e5" alt=""
.没毛病,现在可以愉快的玩耍jsp了
分割线
后面还有一点 thymeleaf 和jsp 要公用的
,下次补充了。已经写在demo里面,,也可以自己去看。
项目地址:https://github.com/luocaca/models.git
data:image/s3,"s3://crabby-images/95a38/95a3840d40d7f75a27a4f51780157c3d3e499410" alt=""
就能共存了
happy。
参考网站:www.baidu.com
参考文章:https://www.iflym.com/index.php/java-programe/201706060001.html
网友评论