草庐IT

php - 验证多级关系依赖关系的最佳方法

coder 2023-10-11 原文

假设你有实体A,B,C和D。
D与C有关
C与B有关
B与A有关
此外,只有当用户拥有d时,才允许用户对d进行操作。
在应用程序的某个状态下,您包含一个指向访问d的页的链接。因此,您包含d的id作为get或post参数。
如果用户单击链接,应用程序将检索d的id并开始对d进行操作。
简单的应用程序使用这样的url[模块url重写]:

http://www.myServer.com/?action=1234&entity=D&ID=23

如何验证是否允许用户在d上操作?
a)显而易见的解决方案是:给定d,找到c,然后找到b,最后找到a。如果链在某个地方断了,访问d的权限将被拒绝。不幸的是,这需要4个数据库访问,而不仅仅是一个。
b)另一种解决方案是将d的id保存在当前会话中的一组可访问实体中,供下一个要呈现的页面使用。
c)作为替代方案,可以对get和post参数进行加密。在每个页面请求上,第一个操作将是解密请求的参数。如果解密操作失败,访问将被拒绝。
或者,在无穷远处,散列所有页面中的所有链接,在会话中保留一个将散列与url关联起来的映射,并只将散列写入网页。
e)最后,您可以在D中保留对A、B和C的引用,在C中保留对A和B的引用,在B中保留对A的引用。因此,在每个级别上,都可以立即找到根实体。
在这种情况下你有什么办法?为什么呢?
虽然我包含了php标记,但我不想把这个问题集中在语言上。我很乐意得到总的建议。或解决方案,这些解决方案已经在例如ORM层中实现。
更新-1
最后,我选择了d)。
一般原则:
确保以某种方式下级实体的id总是以安全/可信的方式传递。这样,第三方就无法改变他们的价值观。
细节:
此选项按设计提供了许多好处:
首先,链接页面的id或其他参数永远无法到达浏览器。而不是
http://www.myServer.com/?action=1234&entity=D&ID=23

大多数页面都是这样链接的
http://www.myServer.com/?forwardHash=78sd7sdf98asd7ad5aa76asa4a465

要执行的下一页的所有参数都完全保存在用户会话中。
由于页面的所有参数都保存在用户会话中,因此需要进行的检查要少得多。尤其是,上面提到的关系依赖性检查不再有用了。如果某个东西在用户的会话中,则它是从以前受信任的对话框步骤中放置的。
此外,还可以强制用户只调用当前呈现页面上可用的链接。每次他们调用链接时,应用程序可能会使页面的所有其他链接失效。因此,用户将无法在多个窗口中打开页面,并认为他们看到了应用程序的两种不同“状态”。如果他们两次调用链接,应用程序可能会显示错误消息。
最后,可以直接建立一些我称之为子工作流对话框的东西:您可以通过在会话中的连续堆栈上推送当前页面的url并打开编辑对话框步骤来启动对话框。用户可以有序结束或有意取消对话框工作流。如果连续堆栈不为空,则取消工作流链接可能自动显示为用户选项。
通过保持会话中堆栈上的continuation,它与当前运行的对话框步骤完全隔离。对话步骤甚至不知道调用方的任何信息。
通过将功能包装在一个小的管理器调用中,子进程最终调用flowmanager::finishflow()。此调用从堆栈中弹出一个延续,并将浏览器重定向到此页-有效地返回到工作流开始的位置。
由于我们使用了一堆连续性,因此甚至可以运行从属于其他子工作流的子工作流。

最佳答案

显而易见的解决方案是:给定d,找到c,然后找到b和
最终找到A。如果链子在某个地方断了,就可以进入D
拒绝。不幸的是,这需要-如果实现很简单的话-4
数据库访问,而不仅仅是对a的访问。
我想那是可能的。这在一定程度上取决于“related to”是什么意思,但是假设一个相对简单的模式,我希望您能够在一个sql语句中连接所有四个表。如果缺少链的一部分,查询将不返回行。
还是我遗漏了什么?

关于php - 验证多级关系依赖关系的最佳方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6783575/

有关php - 验证多级关系依赖关系的最佳方法的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

    很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

  5. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  6. ruby-on-rails - 如何验证 update_all 是否实际在 Rails 中更新 - 2

    给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru

  7. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  8. Ruby 方法() 方法 - 2

    我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby​​-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco

  9. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  10. ruby-on-rails - 如果为空或不验证数值,则使属性默认为 0 - 2

    我希望我的UserPrice模型的属性在它们为空或不验证数值时默认为0。这些属性是tax_rate、shipping_cost和price。classCreateUserPrices8,:scale=>2t.decimal:tax_rate,:precision=>8,:scale=>2t.decimal:shipping_cost,:precision=>8,:scale=>2endendend起初,我将所有3列的:default=>0放在表格中,但我不想要这样,因为它已经填充了字段,我想使用占位符。这是我的UserPrice模型:classUserPrice回答before_val

随机推荐