Web前端的服务层

    以下内容转载自《Microsoft .NET企业级应用架构设计》

    在ASP.NET Web应用程序中,表现层被分成了两个物理层------运行JavaScript代码的Web浏览器和运行托管代码语言编写的代码后置文件及表现层逻辑的Web服务器。大多数时候,服务层和表现层的逻辑运行在同一个IIS工作进程中,目前看了这没有问题。

    不过随着AJAX等富Web前端的兴起,情况发生了很大的变化。Web浏览器的功能越来越多,表现层的任务也越来越重。同时,服务层也需要重新设计,以便更好的应对新的挑战,特别是安全方面。

    在经典的,表现层逻辑完全位于服务器的Web场景中,我们通常使用表单验证来实现安全。未经认证的用户不可能访问到需要回送病访问层的页面。服务层的安全性很容易就能使用代码访问安全,角色等。

    不过将服务暴露给基于JavaScript的客户端时,你会允许客户端直接连接吗?理论上这样没问题。不过实际上,暴露给JavaScript客户端的服务也就是暴露给Internet上所有的用户。认证信息不能作为消息的一部分同时发送,因为这需要专门的JavaScript功能。更加重要的是这些功能可能会被攻击者偷走,进而威胁到系统的安全。

    若想发送认证信息,则应该如果ASP.NET表单一样使用加密后的cookie。随后,服务层首先检查cookie,然后再执行逻辑,这个步骤必不可少,不过我们不希望将其直接放在服务层中,这也正是为AJAX服务提供额外的一层。

 


    那么我们如何实现服务层的安全性呢? 

    很简单,我们只需要检查并识别一个合法用户可以提供,而外来者不能提供的信息令牌,最简单也是最有效的令牌就是ASP.NET表单认证所生成的一个认证cookie。


  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值