zoukankan      html  css  js  c++  java
  • openstack认证实践

    环境: 客户端:负责发送请求, 服务器:负责接受请求; 认证服务器keystone:负责认证

    具体认证步骤:

    1、客户端首先进行签名计算,将得到的签名字符串作为authorization发给keystone。利用secretkey计算签名,签名中包括:accesskey,时间戳,主机IP、端口,要找keystone进行校验的请求API,由于需要注意,keystone要求时间戳为UTC格式,所以需要转换为UTC,否则导致最后keystone验签失败,返回400 Bad Request,相关代码如下:

        utc_time = datetime.datetime.utcnow().strftime('%Y-%m-%dT%H:%M:%SZ')
        host = "10.0.0.3:8787"  # IP为客户端要访问的服务器的IP
        authorization = {'version': 'auth-v1',
                         'access': accesskey,
                         'timestamp': utc_time,
                         'period': '10800',
                         'signedheaders': '',
                         'signature': 'SIGNATURE_SPACE_HOLDER'}
        request = {
                'method': 'POST',
                'uri': '/data/add',
                'params': {
                    },
                'headers': {
                    'x-date': utc_time,
                    'Host': host,
                    }
                }
    

    之后,用户将计算好的签名插入到API请求头部,访问服务器,计算好的签名示例如下:

    x-date:2017-05-31T05:06:30Z
    Authorization:auth-v1/2d6e969a81384d03848708bbb4fb0bca/2017-05-31T05:06:30Z/1800/host;x-date/128709e9cd3b3ef751cff70028851641cca8ef3262f6e9d06514ac243b839a54
    Content-Type:application/json

     2、服务器收到客户端请求后,首先到keystone申请token,原因是keystone要求服务携带一个表征服务身份的token,放在X-Auth-Token请求头中,token有效期一般为半小时,发送的请求为(具体的参数是keystone要求的,必须严格一致,否则导致token不对)

     params = json.dumps({
              "auth": {
                  "identity": {
                      "methods": [
                          "password"
                      ],
                      "password": {
                          "user": {
                              "domain": {
                                  "id": "default"
                              },
                              "name": username,
                              "password": password
                          }
                      }
                  },
              "scope": {
                 "domain": {
                     "id": "default"
                 }
             }
             },
         })

    请求响应中x-token就是需要的token

    最后,服务器将客户的authorization,申请到的token,以及请求的信息Method(GET), Uri(/data/add); host(服务器IP)提交到keystone来进行验签

    3、keystone基于请求信息进行签名的验算,向服务返回验签过通与否,如果验证通过,服务器执行用户请求的操作

  • 相关阅读:
    POJ2481:Cows(树状数组)
    Go语言用堆排序的方法进行一千万个int随机数排序.
    【一】注入框架RoboGuice使用:(A brief example of what RoboGuice does)
    POJ3067:Japan(树状数组求逆序对)
    Android开发之ListView实现不同品种分类分隔栏的效果(非ExpandableListView实现)
    躁动不安的const
    JAVA实现RSA加密解密 非对称算法
    Cocos2d坐标系具体解释
    leetcode_Product of Array Except Self
    IIS2008配置URlRewriter
  • 原文地址:https://www.cnblogs.com/yanchengwang/p/6940271.html
Copyright © 2011-2022 走看看