ArcGIS 10.1 for Server Rest服务安全性管理:基于用户和角色权限

转载自http://www.it165.net/admin/html/201402/2412.html

ArcGIS Server权限是赋予给角色对资源的访问能力,权限设置可以对ArcGIS Server服务,也可以对服务文件夹进行设置。如果对文件夹设置权限,则文件夹中的服务自动继承权限;如果是对文件夹中的服务设置权限,则将覆盖从文件夹中继承的权限。

ArcGIS Server Rest服务针对应用程序来说,是基于角色来授权(不能直接给用户授权)。而用户访问该Rest服务时,只需要提供用户名和密码,ArcGIS Server将找到其对应的角色,验证该角色是否对服务资源具备访问权限。

 

1 创建地州数据访问权限的角色

wKiom1MN2KjxCK2AAAD_4z8FSxE463.jpg

wKiom1MN2Yjxq6twAAIFmSbrMlY456.jpg

 

2 创建用户

创建两个用户user1和user2,给user1添加角色XJA和XJC,给用户user2添加角色XJB,如下所示:

 

wKioL1MN2eyAhM6FAAEhriuEFz4281.jpg

 

wKiom1MN2iCAvfnmAAGgHZTS8b4753.jpg

 

3 为角色授予访问权限

给服务JueSe授权角色XJA和XJO才可以访问。

wKioL1MN21jD0_KGAADmSlj0ztA813.jpg

 

4 验证

方法一: 在http://IP:6080/arcgis/rest/login页面查看

匿名用户登录,看不到服务JueSe,以用户user1登录,可以看到JueSe服务,以用户user2登录,看不到JueSe服务。

方法二:采用令牌环

在 Web 浏览器中打开http://IP:6080/arcgis/tokens/或http://IP:6080/arcgis/admin/generateToken申请token,输入如下信息:

 

用户名:访问该资源的授权用户的名字。

密码:用户的密码。

客户端:使用token的客户端,提供三种类型:HTTP Referer、IP、Requeste IP,区别如下:

HTTP Referer:选择此(默认)选项后,只能在指定 URL 涉及的请求中使用发布的令牌。这是发出访问 ArcGIS 资源请求的页面的 URL。如果通过 ArcGIS API for JavaScript 或基于 REST 的其他应用程序来构建应用程序(各客户端在此应用程序中发出通过 ArcGIS Server Web 服务直接访问地图和数据的请求),可使用此方法。

IP:选择此选项后,只能在来自指定 IP 地址的请求中使用发布的令牌。

Request IP:选择此选项后,只能在来自用于获取令牌的 IP 地址的请求中使用发布的令牌。

注:如果在客户端应用程序\浏览器和 ArcGIS Server 之间有代理服务器,则必须将使用 IP 地址或此请求源的 IP 地址选项生成的令牌绑定到代理服务器的 IP 地址。如果在客户端应用程序\浏览器和 ArcGIS Server 之间有多个负载平衡代理服务器,则应使用 HTTP Referer 选项。

  • HTTP referer:如果Client选择了HTTP referer,这里就需要输入应用地址。

    有效期:自令牌发布时间起的持续时间,令牌在此持续时间内有效。

    注:指定的有效期必须小于或等于为长期令牌生命期配置的值。要在管理器中查看当前令牌属性,请单击安全性 > 设置,然后单击令牌设置旁的编辑图标。

    • 格式:此参数指定服务器对此令牌请求所作响应的格式。

      HTML:此选项以字符串格式显示服务器发布的令牌。要使用令牌,请复制字符串并将其附加到对受保护的 ArcGIS Server Web 服务的请求中。

      JSON:此选项返回 JSON 格式的令牌。当通过 Web 应用程序而不是 Web 浏览器请求令牌时,使用该选项。

    • <!DOCTYPE html>
      <html>
      <head>
          <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
          <title>我的第一个地图应用</title>
          <link href="http://localhost/arcgis_js_api/library/3.8/js/esri/css/esri.css" rel="stylesheet" type="text/css">
          <script src="http://localhost/arcgis_js_api/library/3.8/"></script>
          <script type="text/javascript" src="jsapi_vsdoc10_v38.js"></script>
          <style type="text/css">
          html, body, .MapClass{
                  padding: 0;
                  margin: 0;
                  height: 100%;
          }
          </style>
          <script type="text/javascript">
              dojo.require("esri.map");
              //dojo.require("esri.layers.ArcGISTiledMapServiceLayer");
              function init() {
                  var MyMap=new esri.Map("MapDiv");
                  var MyTiledMapServerLayer=new esri.layers.ArcGISDynamicMapServiceLayer("http://IP:6080/arcgis/rest/services/xjuMobile/gsmTS/MapServer?token=tyWeXGA1oFQ-I49ZEQ8qzKNZ7EpPByFI0Fh6-rvXJMnEj1Hwp_cKANFRTlTfTVSR");
                  MyMap.addLayer(MyTiledMapServerLayer);
              }
              dojo.addOnLoad(init);
          </script>
      </head>
      <body>
          <div id="MapDiv" class="MapClass"></div>
      </body>
      </html>
      参考文档:http://resources.arcgis.com/zh-CN/help/main/10.2/#/na/0154000005rp000000/

  • 如果不产生令牌,直接采用js api调用服务则会产生如下弹框

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值