javaweb后端 web项目后端与页面交互的原理 谁能通俗易懂的教下呢

博客分类:
1、获取类文件下的绝对路径
youClass.class.getResource("/").toString().replaceAll("file:/", "")
2、获取项目路径
getServletContext().getRealPath("/");
3、获取类文件路径
this.getClass().getClassLoader().getResource("/").getPath();
4、获取项目路径
request.getContextPath();
5、获取项目路径
System.getProperty("user.dir")
6、获取顶级路径
new File("/").getAbsolutePath()
7、获取当前类路径
ClassLoader.getSystemResource("")
8、获取当前类路径
Thread.currentThread().getContextClassLoader().getResource("")
转:http://paper.iteye.com/blog/1462614
浏览: 611 次
来自: 成都
(window.slotbydup=window.slotbydup || []).push({
id: '4773203',
container: s,
size: '200,200',
display: 'inlay-fix'为什么JavaWeb放弃jsp,去做前后端分离
前后端分离已成为互联网项目开发的业界标准使用方式,通过nginx+tomcat的方式(也可以中间加一个nodejs)有效的进行解耦,并且前后端分离会为以后的大型分布式架构、弹性计算架构、微服务架构、多端化服务(多种客户端,例如:浏览器,车载终端,安卓,IOS等等)打下坚实的基础。这个步骤是系统架构从猿进化成人的必经之路。核心思想:前端html页面通过ajax调用后端的restuful api接口并使用json数据进行交互。在互联网架构中,web服务器:一般指像nginx,apache这类的服务器,他们一般只能解析静态资源。应用服务器:一般指像tomcat,jetty,resin这类的服务器可以解析动态资源也可以解析静态资源,但解析静态资源的能力没有web服务器好。一般都是只有web服务器才能被外网访问,应用服务器只能内网访问。以前的JavaWeb项目大多数都是java程序员又当爹又当妈,又搞前端(ajax/jquery/js/html/css等等),又搞后端(java/mysql/oracle等等)。随着时代的发展,渐渐的许多大中小公司开始把前后端的界限分的越来越明确,前端工程师只管前端的事情,后端工程师只管后端的事情。正所谓术业有专攻。对于后端java工程师:把精力放在java基础,设计模式,jvm原理,spring+springmvc原理及源码,linux,mysql事务隔离与锁机制,mongodb,http/tcp,多线程,分布式架构(dubbo,dubbox,spring cloud),弹性计算架构,微服务架构(springboot+zookeeper+docker+jenkins),java性能优化,以及相关的项目管理等等。后端追求的是:三高(高并发,高可用,高性能),安全,存储,业务等等。对于前端工程师:把精力放在html5,css3,jquery,angularjs,bootstrap,reactjs,vuejs,webpack,less/sass,gulp,nodejs,Google V8引擎,javascript多线程,模块化,面向切面编程,设计模式,浏览器兼容性,性能优化等等。前端追求的是:页面表现,速度流畅,兼容性,用户体验等等。通常我们的JavaWeb项目都是使用了若干后台框架,springmvc/struts + spring + spring jdbc/hibernate/mybatis 等等。大多数项目在java后端都是分了三层,控制层(controller/action),业务层(service/manage),持久层(dao)。控制层负责接收参数,调用相关业务层,封装数据,以及路由&渲染到jsp页面。然后jsp页面上使用各种标签(jstl/el/struts标签等)或者手写java表达式(&%=%&)将后台的数据展现出来,玩的是MVC那套思路。紧接着系统发布,你需要用maven或者eclipse等工具把你的代码打成一个war包,然后把这个war包发布到你的生产环境下的web容器(tomcat/jboss/weblogic/websphere/jetty/resin)里,对吧?发布完了之后,你要启动你的web容器,开始提供服务,这时候你通过配置域名,dns等等相关,你的网站就可以访问了。这样一来,你的前后端代码全都在那个war包里了,包括你的js,css,图片,各种第三方的库。&在浏览器中输入你的网站域名(www.xxx.com),之后发生了什么?浏览器通过域名,再通过dns服务器找到你的服务器外网ip,将http请求发送到你的服务器,在tcp3次握手之后(http下面是tcp/ip),通过tcp协议开始传输数据,你的服务器得到请求后,开始提供服务,接收参数,之后返回你的应答给浏览器,浏览器再通过content-type来解析你返回的内容,呈现给用户。&我们先假设你的首页中有100张图片,此时,用户的看似一次http请求,其实并不是一次,用户在第一次访问的时候,浏览器中不会有缓存,你的100张图片,浏览器要连着请求100次http请求(有人会跟我说http长连短连的问题,不在这里讨论),你的服务器接收这些请求,都需要耗费内存去创建socket来玩tcp传输(消耗你服务器上的计算资源)。这样的话,你的服务器的压力会非常大,因为页面中的所有请求都是只请求到你这台服务器上,如果1个人还好,如果10000个人并发访问呢(先不聊服务器集群,这里就说是单实例服务器),那你的服务器能扛住多少个tcp连接?你的带宽有多大?你的服务器的内存有多大?你的硬盘是高性能的吗?你能抗住多少IO?你给web服务器分的内存有多大?会不会宕机?这就是为什么,越是大中型的web应用,他们越是要解耦。理论上你可以把你的数据库+应用服务+消息队列+缓存+用户上传的文件+日志+等等都扔在一台服务器上,你也不用玩什么服务治理,也不用做什么性能监控,什么报警机制等等。但是这样把鸡蛋都放在一个篮子里,隐患非常大。如果因为一个子应用的内存不稳定导致整个服务器内存溢出而hung住,那你的整个网站就挂掉了。JSP的痛点:以前的javaWeb项目大多数使用jsp作为页面层展示数据给用户,因为流量不高,因此也没有那么苛刻的性能要求,但现在是大数据时代,对于互联网项目的性能要求是越来越高。1.动态资源和静态资源全部耦合在一起,服务器压力大,因为服务器会收到各种http请求,例如css的http请求,js的,图片的等等。一旦服务器出现状况,前后台一起玩完,用户体验极差。2.UI出好设计图后,前端工程师只负责将设计图切成html,需要由java工程师来将html套成jsp页面,出错率较高,修改问题时需要双方协同开发,效率低下。3.jsp必须要在支持java的web服务器里运行(例如tomcat,jetty,resin等),无法使用nginx等(nginx据说单实例http并发高达5w,这个优势要用上),性能提不上来。4.第一次请求jsp,必须要在web服务器中编译成servlet,第一次运行会较慢。5.每次请求jsp都是访问servlet再用输出流输出的html页面,效率没有直接使用html高。6.jsp内有较多标签和表达式,前端工程师在修改页面时会遇到很多痛点。7.如果jsp中的内容很多,页面响应会很慢,因为是同步加载。8.需要前端工程师使用java的ide(例如eclipse),以及需要配置各种后端的开发环境,你们有考虑过前端工程师的感受吗。基于上述的一些痛点,我们应该把整个项目实现前后端真正的解耦!前后分离的优势:1.可以实现真正的前后端解耦,前端服务器使用nginx。前端/WEB服务器放的是css,js,图片等等一系列静态资源(甚至你还可以css,js,图片等资源放到特定的文件服务器,例如阿里云的oss,并使用cdn加速),前端服务器负责控制页面引用&跳转&路由,前端页面异步调用后端的接口,后端/应用服务器使用tomcat(把tomcat想象成一个数据提供者),加快整体响应速度。(这里需要使用一些前端工程化的框架比如nodejs,react,router,react,redux,webpack)2.发现bug,可以快速定位是谁的问题,不会出现互相踢皮球的现象。页面逻辑,跳转错误,浏览器兼容性问题,脚本错误,页面样式等问题,全部由前端工程师来负责。接口数据出错,数据没有提交成功,应答超时等问题,全部由后端工程师来解决。双方互不干扰,前端与后端是相亲相爱的一家人。3.在大并发情况下,可以同时水平扩展前后端服务器,比如淘宝的一个首页就需要2000+台前端服务器做集群来抗住日均多少亿+的日均pv。4.减少后端服务器的并发/负载压力除了接口以外的其他所有http请求全部转移到前端nginx上,接口的请求调用tomcat,参考nginx反向代理tomcat。且除了第一次页面请求外,浏览器会大量调用本地缓存。5.即使后端服务暂时超时或者宕机了,前端页面也会正常访问,只不过数据刷不出来而已。6.也许你也需要有微信相关的轻应用,那样你的接口完全可以共用,如果也有app相关的服务,那么只要通过一些代码重构,也可以大量复用接口,提升效率。(多端应用)7.页面显示的东西再多也不怕,因为是异步加载。8.nginx支持页面热部署,不用重启服务器,前端升级更无缝。9.增加代码的维护性&易读性(前后端耦在一起的代码读起来相当费劲)。10.提升开发效率,因为可以前后端并行开发,而不是像以前的强依赖。11.在nginx中部署证书,外网使用https访问,并且只开放443和80端口,其他端口一律关闭(防止黑客端口扫描),内网使用http,性能和安全都有保障。12.前端大量的组件代码得以复用,组件化,提升开发效率,抽出来!总结一下新的方式的请求步骤:大量并发浏览器请求---&web服务器集群(nginx)---&应用服务器集群(tomcat)---&文件/数据库/缓存/消息队列服务器集群同时又可以玩分模块,还可以按业务拆成一个个的小集群,为后面的架构升级做准备。
随时随地看视频&>&Rest风格前后端分离 web项目demo
Rest风格前后端分离 web项目demo
上传大小:34KB
非常好的rest前后端分离项目 企业开发目前主流所选的模式 如果能看懂并整合自己的项目会有巨大的收获
综合评分:0
{%username%}回复{%com_username%}{%time%}\
/*点击出现回复框*/
$(".respond_btn").on("click", function (e) {
$(this).parents(".rightLi").children(".respond_box").show();
e.stopPropagation();
$(".cancel_res").on("click", function (e) {
$(this).parents(".res_b").siblings(".res_area").val("");
$(this).parents(".respond_box").hide();
e.stopPropagation();
/*删除评论*/
$(".del_comment_c").on("click", function (e) {
var id = $(e.target).attr("id");
$.getJSON('/index.php/comment/do_invalid/' + id,
function (data) {
if (data.succ == 1) {
$(e.target).parents(".conLi").remove();
alert(data.msg);
$(".res_btn").click(function (e) {
var parentWrap = $(this).parents(".respond_box"),
q = parentWrap.find(".form1").serializeArray(),
resStr = $.trim(parentWrap.find(".res_area_r").val());
console.log(q);
//var res_area_r = $.trim($(".res_area_r").val());
if (resStr == '') {
$(".res_text").css({color: "red"});
$.post("/index.php/comment/do_comment_reply/", q,
function (data) {
if (data.succ == 1) {
var $target,
evt = e || window.
$target = $(evt.target || evt.srcElement);
var $dd = $target.parents('dd');
var $wrapReply = $dd.find('.respond_box');
console.log($wrapReply);
//var mess = $(".res_area_r").val();
var mess = resS
var str = str.replace(/{%header%}/g, data.header)
.replace(/{%href%}/g, 'http://' + window.location.host + '/user/' + data.username)
.replace(/{%username%}/g, data.username)
.replace(/{%com_username%}/g, data.com_username)
.replace(/{%time%}/g, data.time)
.replace(/{%id%}/g, data.id)
.replace(/{%mess%}/g, mess);
$dd.after(str);
$(".respond_box").hide();
$(".res_area_r").val("");
$(".res_area").val("");
$wrapReply.hide();
alert(data.msg);
}, "json");
/*删除回复*/
$(".rightLi").on("click", '.del_comment_r', function (e) {
var id = $(e.target).attr("id");
$.getJSON('/index.php/comment/do_comment_del/' + id,
function (data) {
if (data.succ == 1) {
$(e.target).parent().parent().parent().parent().parent().remove();
$(e.target).parents('.res_list').remove()
alert(data.msg);
//填充回复
function KeyP(v) {
var parentWrap = $(v).parents(".respond_box");
parentWrap.find(".res_area_r").val($.trim(parentWrap.find(".res_area").val()));
评论共有0条
VIP会员动态
热门资源标签
CSDN下载频道资源及相关规则调整公告V11.10
下载频道用户反馈专区
下载频道积分规则调整V1710.18
spring mvc+mybatis+mysql+maven+bootstrap 整合实现增删查改简单实例.zip
资源所需积分/C币
当前拥有积分
当前拥有C币
输入下载码
为了良好体验,不建议使用迅雷下载
Rest风格前后端分离 web项目demo
会员到期时间:
剩余下载个数:
剩余积分:0
为了良好体验,不建议使用迅雷下载
积分不足!
资源所需积分/C币
当前拥有积分
您可以选择
程序员的必选
绿色安全资源
资源所需积分/C币
当前拥有积分
当前拥有C币
为了良好体验,不建议使用迅雷下载
资源所需积分/C币
当前拥有积分
当前拥有C币
为了良好体验,不建议使用迅雷下载
资源所需积分/C币
当前拥有积分
当前拥有C币
您的积分不足,将扣除 10 C币
为了良好体验,不建议使用迅雷下载
无法举报自己的资源
你当前的下载分为234。
你还不是VIP会员
开通VIP会员权限,免积分下载
你下载资源过于频繁,请输入验证码
您因违反CSDN下载频道规则而被锁定帐户,如有疑问,请联络:!
若举报审核通过,可返还被扣除的积分
被举报人:
请选择类型
资源无法下载 ( 404页面、下载失败、资源本身问题)
资源无法使用 (文件损坏、内容缺失、题文不符)
侵犯版权资源 (侵犯公司或个人版权)
虚假资源 (恶意欺诈、刷分资源)
含色情、危害国家安全内容
含广告、木马病毒资源
*投诉人姓名:
*投诉人联系方式:
*版权证明:
*详细原因:
Rest风格前后端分离 web项目demowebpack 和后台结合的问题 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
已注册用户请 &
PPA for Ubuntu
> ppa:chris-lea/node.js
webpack 和后台结合的问题
09:28:08 +08:00 · 9220 次点击
后台是 java/tomcat
那整个项目部署时 webpack 打包好的项目应该如何和后台结合?
起一个 webpack-dev-server 跑 webpack 的项目再起一个 tomcat 跑后台?
(不一定是webpack-dev-server,意思就是同时起两个端口的两个服务,然后再通过webpack.config.js配置解决跨域问题?)
新手小白求大大们解答
18 回复 &| &直到
14:34:16 +08:00
& & 09:35:25 +08:00
webpack 生成 jsp 么?
& & 10:04:55 +08:00
前后端分离的,服务器也分离好了,部署的时候用 Nginx 区分两个不同的服务
& & 10:17:36 +08:00
webpack dev serverdev server 开发啊 ... 完成之后, 只要不做 server side render. 前端开发结果不都是静态文件么...结合呗...
& & 10:21:58 +08:00
生产环境部署的时候直接打包成一个 js 文件了吧, 直接放到站点的 public 目录或者 cdn 上开发的时候, 官方的建议就是你想的那样, webpack-dev-server 和本来的后端 server 各起一个You may want to run a backend server or a mock of it in development. You should not use the webpack-dev-server as a backend. Its only purpose is to serve static (webpacked) assets.You can run two servers side-by-side: The webpack-dev-server and your backend server.ref:
& & 10:26:30 +08:00
你是说前端代码怎么在开发时请求后端的 API 么?这种情况我一般是用 webpack-dev-middleware 新建了一个 express 应用,前端发到 webpack 所在 express 应用的请求会被转发到后端所在的端口。简单的说就是: localhost:3001/api/users 会被转到 localhost:3002/api/users 。webpack-dev-server 也可以通过配置达到转发的目的,另外写的目的是为了更灵活一些,我可以自定义一些转发方案, webpack-dev-server 的 proxy 配置还蛮 tricky 的。。
& & 10:33:48 +08:00
如果做好分布式部署的打算一开始就做 jsonp 或者设置 cross-region 么 干嘛要转发呢...lz 消失了?你这个项目什么架构的, java 只提供 json 数据前端纯静态?
& & 10:50:43 +08:00
@ 没有消失,看了上面各层回复,在理解尝试中,java 提供 json ,没打算分布式,
& & 10:51:21 +08:00
@ @ @ @ 感谢各位
& & 11:02:47 +08:00
html 仍然由 express 输出,只引 dev-server 上的 js 资源(部署时换成 CDN 的),可以避免跨域。
& & 11:03:28 +08:00
html 仍然由 java 输出。。。
& & 12:04:22 +08:00 via iPhone
刚好也有类似的问题
& & 12:41:36 +08:00
dev 的话 试试 dora 的 proxy
& & 13:58:26 +08:00
@ 可以理解为把 bundle.js 放到 cdn 上?
& & 14:42:51 +08:00
可以压根就不用 webpack-dev-server 吧,感觉没什么关联两者, webpack 做点 build 的工作就好了,不比一定用那个 web server 啊
& & 16:50:30 +08:00
bundle 放在哪里不影响跨域啊 @
& & 00:05:07 +08:00
@ 直接放到站点的 public 路径下呗
& & 13:33:51 +08:00
那就别用 webpack 了啊 ,传统页面用这个感觉是自己找事
& & 14:34:16 +08:00
@ 嗯, html , css , js 就够了哦
& · & 1734 人在线 & 最高记录 3762 & · &
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.1 · 28ms · UTC 16:03 · PVG 00:03 · LAX 09:03 · JFK 12:03? Do have faith in what you're doing.是不是前端后端都要学的?【java吧】_百度贴吧
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&签到排名:今日本吧第个签到,本吧因你更精彩,明天继续来努力!
本吧签到人数:0成为超级会员,使用一键签到本月漏签0次!成为超级会员,赠送8张补签卡连续签到:天&&累计签到:天超级会员单次开通12个月以上,赠送连续签到卡3张
关注:726,197贴子:
是不是前端后端都要学的?收藏
我按照javase,html,css,js,javaweb这条路走下去,但是我怎么看到有人说学好一个方向就好了?
前端不求精,但肯定要会啊
写个项目大多数时间在写前台
你应该学的是java
java着重后端
也会学前端
你把其中一个放向学好确实就行了
两个都学好
就看个人能力了
你这个走的是javaweb方向,不是javaee
要有一颗不断学习的心
三大框架,然后springmvc还有mybatis,还要懂点linux命令,经常被问到
半栈屌还是全栈屌?
我是java se,html+css+js,数据库,jsp+servlet+java bean,ssh框架,ssm框架,jQuery。
js写俄罗斯方块,贪吃蛇锻炼了我对js的认识
我后端+前端,前端强,后端更强
这么和你说吧。单拿一个js举例子,如果你只会一个document.getElementById,那等同于你不会js。js的面向对象,继承,原型链,闭包,defer-promise,以及各种基于http的交互技术,以及几大前端框架。对于一个后端程序员来说都是要掌握的。不要以为这些都应该是前端的活,现在的前端不仅还得会各种事件动画处理,还得会less,sass至少之一,css3h5各种特性尤其是要有css3绘图功底。还有各种es6的新特性和语法和类似ts这种扩展语言。相比真正前端需要会的东西,后端需要掌握的前端知识简直不能再基础了。
登录百度帐号

我要回帖

更多关于 javaweb前后端分离 的文章

 

随机推荐