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

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
可观测可视化 Grafana 版,10个用户账号 1个月
简介: 带你读《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


相关文章
|
1月前
|
Java 应用服务中间件 Apache
从零手写实现 apache Tomcat-01-入门介绍
创建简易Tomcat涉及理解其作为Java服务器的角色,建立HTTP服务器,实现Servlet接口处理动态和静态内容,以及启动和关闭服务器。项目mini-cat是一个简化版Tomcat实现,支持Servlet、静态网页和基础功能。可通过maven添加依赖并运行测试类快速体验。开源项目位于[GitHub](https://github.com/houbb/minicat)。
|
1月前
|
Java 应用服务中间件 Apache
简介Nginx,Tomcat和 Apache
简介Nginx,Tomcat和 Apache
简介Nginx,Tomcat和 Apache
|
4天前
|
XML 网络协议 Java
JavaWeb -- HTTP -- WEB服务器TOMCAT
JavaWeb -- HTTP -- WEB服务器TOMCAT
|
21天前
|
运维 Cloud Native Apache
云计算新宠:探索Apache Doris的云原生策略
云计算新宠:探索Apache Doris的云原生策略
|
24天前
|
Java 应用服务中间件 Apache
Tomcat的基本使用,如何用Maven创建Web项目、开发完成部署的Web项目
Tomcat的基本使用,如何用Maven创建Web项目、开发完成部署的Web项目
35 1
|
1月前
|
XML 安全 Java
从零手写实现 apache Tomcat-02-web.xml 入门详细介绍
`web.xml`是Java Web应用的核心配置文件,描述应用工作方式。它包含Servlet、Filter和Listener的定义。例如,示例展示了如何配置名为`my`的Servlet处理`/my`请求,`LoggingFilter`拦截所有请求,以及`MyServletContextAttrListener`监听应用事件。`web.xml`是服务器理解应用结构与行为的指南。迷你版Tomcat实现——mini-cat(开源:https://github.com/houbb/minicat)。
|
1月前
|
负载均衡 Ubuntu 应用服务中间件
Apache(mod_proxy)+Tomcat负载均衡配置
Apache(mod_proxy)+Tomcat负载均衡配置
|
1月前
|
Web App开发 Java 应用服务中间件
【Java Web】在 IDEA 中部署 Tomcat
【Java Web】在 IDEA 中部署 Tomcat
|
1月前
|
Java 应用服务中间件
解决tomcat启动报错:无法在web.xml或使用此应用程序部署的jar文件中解析绝对的url [http:java.sun.com/jsp/jstl/core]
解决tomcat启动报错:无法在web.xml或使用此应用程序部署的jar文件中解析绝对的url [http:java.sun.com/jsp/jstl/core]
717 1
|
1月前
|
运维 Cloud Native Apache
云计算新宠:探索Apache Doris的云原生策略
云计算新宠:探索Apache Doris的云原生策略
53 2

推荐镜像

更多