带你读《Apache Tomcat的云原生演进》——Secure By Default Web Applications Apache Sling-Robert Munteanu(7)

本文涉及的产品
注册配置 MSE Nacos/ZooKeeper,118元/月
应用实时监控服务-应用监控,每月50GB免费额度
应用实时监控服务-可观测链路OpenTelemetry版,每月50GB免费额度
简介: 带你读《Apache Tomcat的云原生演进》——Secure By Default Web Applications Apache Sling-Robert Munteanu(7)

带你读《Apache Tomcat的云原生演进》——Secure By Default Web Applications Apache Sling-Robert Munteanu(6)https://developer.aliyun.com/article/1377432


6.演示

 

image.png

 

这是我在演讲中提到的一个简单网站的实现,你可以在这里看到一个包含内容、图像、文本以及用户评论的页面。当然,我可以在这里评论一下,然后我的评论就出现了。其他一些功能包括用户个人资料页面,你可以看到用户的头像,全名,用户所属的组,还有一个技术细节,用户的路径。

 

在访问控制设置中,工作正在进行中。现在我已经登录了,我可以在应用程序中做任何事情,所以这个内容子树是所有用户可见内容的位置。

 

我们看一下访问规则,你可以看到每个人都可以阅读/content 下面的内容。而且用户组有能力添加评论,这很重要。我们往下看,可以看到只有那些被允许撰写的人,你可以看到写的东西,特别是在主页子树下的是作者,所以这暗示了一个以团体为基础的组织。

 

在 content 下面还有一个不同的子树,实际上没有人可以撰写。我们有几个读权限,还有用户组的权限,但这只适用于评论。

 

如果我们看用户,可以看到有两组,允许撰写文章的作者和只允许发表评论的用户。进入用户内部,我们可以看到他们有某些属性。

 

现在我导航到内容树,我们看一下访问控制,我们在这里看到只有鲍勃·琼斯拥有全部的特权。还有一种服务叫家庭阅读服务,稍后我们会讲到它可以读取用户主页里的任何东西。

 

另外值得注意的是,在用户的个人资料下面存储了一张图片,这个我们稍后会讲到。

 

现在,让我们试着在这个应用程序上练习几个请求。我们提到这个应用程序是 RESTful 的,Sling 是 RESTful 的,所以我们可以发送一个加载主页的请求,可以看到它以 JSON 格式返回所有属性。此外,如果我们添加一个称为选择器的部件,我们也可以做同样的事情。

 

所以,与其要回家。Json,我们要求回家,Json,其中还包括子资源,第一级子资源。我们当然可以对评论做同样的事情,有趣的是,我们可以用这种方式呈现HTML片段。事实上,这就是注释页面呈现的方式。

 

同样是 RESTful,我们可以发送几个参数,我们可以发送信息,Sling资源类型。我们之前讨论过这个,创建一个空的,Sling将为我们填充,然后我们试着以 John Doe 的身份发表评论,稍后我们将发现如何看到实际的注释。

 

有趣的是,如果我们这样做没有任何身份验证,这将失败。它失败不是因为我们写了一些定义代码,是因为我们设置了正确的访问控制设置,并且不需要检查应用程序代码中的任何内容。

 

总结一下评论,我们可以添加一个特殊的重定向参数,然后我们告诉它重定向到哪里。Apache Sling 在进行更改后,会将我们重定向到正确的页面,实际上是评论页面。这就是应用程序的实现方式,没有自定义代码。

 

现在如果我们想列出用户,这对我们来说是不可用的。我们会得到一个 404 响应,因为我们没有任何的访问权限,甚至没有经过用户列出它们。当然,admin 用户可以这样做,因为 admin 拥有所有权限。

 

但是用户可以做的是阅读自己的主页,这张是我单独拍的,因为它是一条不可不可预测的道路。但通过这种方式,用户可以访问他们自己的主页。

 

有趣的是,不需要任何认证,我们就可以读取头像。嵌套在用户节点下面,严格来说,我们不应该。作为提示,可以看到这些地址并不指向用户的主页。我会给你展示这是怎么做的。

 

我要打开文本编辑器,你可能还记得我说过,讨论了存在于用户主页中的服务用户的权限,所以这些权限,此业务用户非交互用户,不能登录。你不能把它当作一个用户名,提供密码,然后登录并使用它做一些事情。相反,它只可以到应用程序代码。

 

带你读《Apache Tomcat的云原生演进》——Secure By Default Web Applications Apache Sling-Robert Munteanu(8)https://developer.aliyun.com/article/1377430


相关文章
|
5月前
|
Java 应用服务中间件 Apache
Maven程序 tomcat插件安装与web工程启动
Maven程序 tomcat插件安装与web工程启动
62 0
|
3月前
|
Java 应用服务中间件 Shell
Nginx+Keepalived+Tomcat 实现Web高可用集群
Nginx+Keepalived+Tomcat 实现Web高可用集群
119 0
|
5月前
|
XML 网络协议 Java
JavaWeb -- HTTP -- WEB服务器TOMCAT
JavaWeb -- HTTP -- WEB服务器TOMCAT
|
1月前
|
Java 应用服务中间件 Apache
浅谈Tomcat和其他WEB容器的区别
Tomcat是一款轻量级的免费开源Web应用服务器,常用于中小型系统及并发访问量适中的场景,尤其适合开发和调试JSP程序。它不仅能处理HTML页面,还充当Servlet和JSP容器。相比之下,物理服务器是指具备处理器、硬盘等硬件设施的服务器,如云服务器,其设计目标是在处理能力、稳定性和安全性等方面提供高标准服务。简言之,Tomcat专注于运行Java应用,而物理服务器则提供基础计算资源。
|
3月前
|
网络协议 Java 应用服务中间件
Tomcat源码分析 (一)----- 手撕Java Web服务器需要准备哪些工作
本文探讨了后端开发中Web服务器的重要性,特别是Tomcat框架的地位与作用。通过解析Tomcat的内部机制,文章引导读者理解其复杂性,并提出了一种实践方式——手工构建简易Web服务器,以此加深对Web服务器运作原理的认识。文章还详细介绍了HTTP协议的工作流程,包括请求与响应的具体格式,并通过Socket编程在Java中的应用实例,展示了客户端与服务器间的数据交换过程。最后,通过一个简单的Java Web服务器实现案例,说明了如何处理HTTP请求及响应,强调虽然构建基本的Web服务器相对直接,但诸如Tomcat这样的成熟框架提供了更为丰富和必要的功能。
|
3月前
|
jenkins 持续交付 开发工具
"引爆效率革命!Docker+Jenkins+GIT+Tomcat:解锁持续集成魔法,一键部署Java Web应用的梦幻之旅!"
【8月更文挑战第9天】随着软件开发复杂度的增加,自动化变得至关重要。本文通过实例展示如何结合Docker、Jenkins、Git与Tomcat建立高效的持续集成(CI)流程。Docker确保应用环境一致性;Jenkins自动化处理构建、测试和部署;Git管理源代码版本;Tomcat部署Web应用。在Jenkins中配置Git插件并设置项目,集成Docker构建Tomcat应用镜像并运行容器。此外,通过自动化测试、代码质量检查、环境隔离和日志监控确保CI流程顺畅,从而显著提高开发效率和软件质量。
78 3
|
3月前
|
应用服务中间件
2022年最新最详细在IDEA中配置Tomcat(含有详细图解过程)、建立使用IEDA建立一个Web项目的案例
这篇文章提供了在IntelliJ IDEA中配置Tomcat服务器的详细步骤,包括添加Tomcat Server、选择安装路径、添加项目Artifact,以及创建和展示Web项目的流程。
|
5月前
|
Java 应用服务中间件 Apache
安装和配置Apache Tomcat是部署Java Web应用程序的常见任务
安装和配置Apache Tomcat是部署Java Web应用程序的常见任务
146 7
|
4月前
|
Java 应用服务中间件 Linux
Tomcat安装部署[单机软件],可以让用户开发的WEB应用程序,变成可以被访问的网页,Tomcat的使用需要jdk环境
Tomcat安装部署[单机软件],可以让用户开发的WEB应用程序,变成可以被访问的网页,Tomcat的使用需要jdk环境
|
6月前
|
Java 应用服务中间件 Apache
Tomcat的基本使用,如何用Maven创建Web项目、开发完成部署的Web项目
Tomcat的基本使用,如何用Maven创建Web项目、开发完成部署的Web项目
85 1

推荐镜像

更多