这个需求怎么搞?指定某链接页面分享给指定人看|Java 开发实战

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: 既然指定的链接需要指定人才可以点击打开,那么就必须知道当前用户是谁,也就是网站必须要求用户登录,否则无法跳转到指定链接或跳转后显示的是空白页。

开篇

在日常工作中,总会遇到各种各样的需求,有些正常合理,有些异想天开,还有些闻所未闻,超乎你的想象。

产品经理来一句:“给我做一个指定某链接页面分享给指定人可以看的功能”,

你问他:“这个你想怎么搞,有啥思路方案?”

他说:“你自己看着办吧!能做出来就行。”

内心PS: 我要是做不出来,你还能把我开了不成。。。。

指定链接页面指定人看

前提:用户必须登录

既然指定的链接需要指定人才可以点击打开,那么就必须知道当前用户是谁,也就是网站必须要求用户登录,否则无法跳转到指定链接或跳转后显示的是空白页。

非法效果

  • 无法跳转到指定链接
  • 一般由前端路由控制,如果访问的是该链接地址,且当前用户未登录,则提示无法跳转,此时浏览器url还是原始url
  • 跳转后显示空白页
  • 一般在页面渲染前调用,如果没有获取到当前用户或不是当前用户,则页面空白,此时浏览器url为已跳转的url

设计要素

既然是指定用户才能访问的链接,就代表每个链接都对应着一个用户或多个用户。这就会存在一对多/多对多的关系;

  • 一对多:一个链接对应多个可访问的用户,表明多个用户可以拥有相同的访问链接。
  • 一对一:一个链接只能有一个可访问的用户,表明每个用户的可访问链接都是不一样的,但最终目标页面都是同一个。

实现的方式

有状态实现

通过数据表的方式,保存链接与指定用户的关系,例如:

可访问链接 用户id 有效期
www.baidu.com 1001, 1002 1h
www.taobao.com 1002 1h

此时前端必须跳转到目标url,然后通过请求后端服务来判断登录用户是否有访问权限。

优点:

  • 简单直接,便于维护。
  • 可提供管理操作,便于动态修改。

缺点:

  • 前端需要和后端进行交互,依赖后端数据源。
  • 占用资源,例如网络,磁盘IO等。

无状态实现

可以采用的方式有:进制互换、混淆加解密、token加解密、非对称加解密等等,总之就是采用加密目标字符串的方式来隐藏真实的目标url

  • 加密url:目标url?salt=salt&userId=用户标识,用户标识...&加密算法 = 指定用户的加密链接
  • 解密url: 指定用户的加密链接&解密算法 = 目标url?salt=salt&userId=用户标识,用户标识...

此时前端接收到加密url,然后采用解密url算法即可得到目标url,同时附带的用户标识可以在跳转前、跳转后提供校验依据, 如果没有salt的话,部分黑客用户可以解析出目标url然后追加用户标识以此来通过页面检查查看目标页面内容,所以为了安全起见附带一个参数salt多做一层访问校验。

优点:

  • 不依赖存储服务
  • 资源占用较少;可以被共享

缺点:

  • 设计实现复杂

有状态实现+无状态实现

基于上述两种方式做实现:

  • 有状态--实现做管理
  • 无状态--实现做分享与校验。

最重要的还是依据业务与场景进行选择,其实这个功能是可以做成一个通用功能模块的,具体怎么设计,大家可以在文章下面评论留言。

相关文章
|
30天前
|
Java
Java开发实现图片URL地址检验,如何编码?
【10月更文挑战第14天】Java开发实现图片URL地址检验,如何编码?
62 4
|
27天前
|
存储 Java 开发者
Java Map实战:用HashMap和TreeMap轻松解决复杂数据结构问题!
【10月更文挑战第17天】本文深入探讨了Java中HashMap和TreeMap两种Map类型的特性和应用场景。HashMap基于哈希表实现,支持高效的数据操作且允许键值为null;TreeMap基于红黑树实现,支持自然排序或自定义排序,确保元素有序。文章通过具体示例展示了两者的实战应用,帮助开发者根据实际需求选择合适的数据结构,提高开发效率。
59 2
|
29天前
|
监控 Java 测试技术
Java开发现在比较缺少什么工具?
【10月更文挑战第15天】Java开发现在比较缺少什么工具?
34 1
|
30天前
|
Java
Java开发实现图片地址检验,如果无法找到资源则使用默认图片,如何编码?
【10月更文挑战第14天】Java开发实现图片地址检验,如果无法找到资源则使用默认图片,如何编码?
56 2
|
10天前
|
SQL 安全 Java
安全问题已经成为软件开发中不可忽视的重要议题。对于使用Java语言开发的应用程序来说,安全性更是至关重要
在当今网络环境下,Java应用的安全性至关重要。本文深入探讨了Java安全编程的最佳实践,包括代码审查、输入验证、输出编码、访问控制和加密技术等,帮助开发者构建安全可靠的应用。通过掌握相关技术和工具,开发者可以有效防范安全威胁,确保应用的安全性。
23 4
|
12天前
|
缓存 监控 Java
如何运用JAVA开发API接口?
本文详细介绍了如何使用Java开发API接口,涵盖创建、实现、测试和部署接口的关键步骤。同时,讨论了接口的安全性设计和设计原则,帮助开发者构建高效、安全、易于维护的API接口。
35 4
|
1月前
|
存储 消息中间件 安全
JUC组件实战:实现RRPC(Java与硬件通过MQTT的同步通信)
【10月更文挑战第9天】本文介绍了如何利用JUC组件实现Java服务与硬件通过MQTT的同步通信(RRPC)。通过模拟MQTT通信流程,使用`LinkedBlockingQueue`作为消息队列,详细讲解了消息发送、接收及响应的同步处理机制,包括任务超时处理和内存泄漏的预防措施。文中还提供了具体的类设计和方法实现,帮助理解同步通信的内部工作原理。
JUC组件实战:实现RRPC(Java与硬件通过MQTT的同步通信)
|
22天前
|
开发框架 JavaScript 前端开发
HarmonyOS UI开发:掌握ArkUI(包括Java UI和JS UI)进行界面开发
【10月更文挑战第22天】随着科技发展,操作系统呈现多元化趋势。华为推出的HarmonyOS以其全场景、多设备特性备受关注。本文介绍HarmonyOS的UI开发框架ArkUI,探讨Java UI和JS UI两种开发方式。Java UI适合复杂界面开发,性能较高;JS UI适合快速开发简单界面,跨平台性好。掌握ArkUI可高效打造符合用户需求的界面。
75 8
|
17天前
|
SQL Java 程序员
倍增 Java 程序员的开发效率
应用计算困境:Java 作为主流开发语言,在数据处理方面存在复杂度高的问题,而 SQL 虽然简洁但受限于数据库架构。SPL(Structured Process Language)是一种纯 Java 开发的数据处理语言,结合了 Java 的架构灵活性和 SQL 的简洁性。SPL 提供简洁的语法、完善的计算能力、高效的 IDE、大数据支持、与 Java 应用无缝集成以及开放性和热切换特性,能够大幅提升开发效率和性能。
|
18天前
|
存储 Java 关系型数据库
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践,包括连接创建、分配、复用和释放等操作,并通过电商应用实例展示了如何选择合适的连接池库(如HikariCP)和配置参数,实现高效、稳定的数据库连接管理。
36 2