oss_sts.py 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. from aliyunsdkcore import client
  2. from aliyunsdksts.request.v20150401 import AssumeRoleRequest
  3. import json
  4. import oss2
  5. # Endpoint以杭州为例,其它egion请按实际情况填写。
  6. endpoint = 'oss-cn-shenzhen.aliyuncs.com'
  7. access_key_id = 'LTAIyMkGfEdogyL9'
  8. access_key_secret = '71uIjpsqVOmF7DAITRyRuc259jHOjO'
  9. bucket_name = 'cloudvod1'
  10. # role_arn是角色的资源名称。
  11. role_arn = 'acs:ram::1901342792446414:role/stsoss'
  12. clt = client.AcsClient(access_key_id, access_key_secret, 'cn-shenzhen')
  13. req = AssumeRoleRequest.AssumeRoleRequest()
  14. # 设置返回值格式为JSON。
  15. req.set_accept_format('json')
  16. req.set_RoleArn(role_arn)
  17. req.set_RoleSessionName('uid13241234123')
  18. req.set_DurationSeconds(3600)
  19. policys = {
  20. "Version": "1",
  21. "Statement": [
  22. {
  23. "Action": [
  24. "oss:PutObject",
  25. "oss:DeleteObject",
  26. ],
  27. # "Resource": ["acs:oss:*:*:cloudvod1/*"],
  28. "Resource": ["acs:oss:*:*:cloudvod1/test/*"],
  29. "Effect": "Allow",
  30. "Condition": {
  31. "IpAddress": {
  32. "acs:SourceIp": "120.237.157.184"
  33. }
  34. }
  35. }
  36. ]
  37. }
  38. req.set_Policy(Policy=json.dumps(policys))
  39. body = clt.do_action(req)
  40. # body = clt.do_action_with_exception(req)
  41. # 使用RAM账号的AccessKeyId和AccessKeySecret向STS申请临时token。
  42. token = json.loads(body)
  43. print(token)
  44. # exit()
  45. # tokens = {'RequestId': '2D83A43D-8D6B-44C5-83A4-3530BFB032EC', 'AssumedRoleUser': {'AssumedRoleId': '394329055954717182:chanjunkai', 'Arn': 'acs:ram::1901342792446414:role/stsoss/chanjunkai'}, 'Credentials': {'AccessKeySecret': 'FtPRvMDBRitAX8X7ZGoQ2DohrMWvMjP2EXVVSVqhmdyv', 'AccessKeyId': 'STS.NJHBY1uKvmvy2rRunerymDq7y', 'Expiration': '2018-11-30T07:23:54Z', 'SecurityToken': 'CAIS0wJ1q6Ft5B2yfSjIr4n9CeOFmJRX2rSSMFTjkW4wfvZBq7Scmzz2IHFIf3NhAe0bv/kzm2lX7/YYlqN4S5ZDR1HCbsJxtgf5G/c/J9ivgde8yJBZoljMewHKedGSvqL7Z+H+U6mMGJOEYEzFkSle2KbzcS7YMXWuLZyOj+wuDLEQRRLqVSdaI91UKwB+yrcdLmCDGfupPwLnpWDSAUF0wFce71ly8qOi2MaRxwPDhVnhsI8vqp/2P4KvYrsdXuh2WMzn2/dtJOiTknxb7x9X+LlxgPUDu02D3LC8G3Bd7w+LKPGultRkN11CYbUgEKNltIqF95oh4LSVzd+ojU8QYqcMA3j9PNnxmJKfRLn2Z4xlKeinYij3v4rRZsWvgWQNemkGMQ5GQd0lJ0JrBAYkIjOgcf77owqbOlr+GvXZj/hpiMov1Tvz4cGNPEOf5T4EVOPY4vQagAGFFahWtPsgkWPPJhSOu/bsFZGJFeQvb/Ij5nT5dPNiuEfvECu+ns2GmUB5sAQO9xeMmIBr9y2yteTIwoG8FQx5S4ybj051MK+K53GeRZOSd05iZRU8hpU3+O2mTlQI4FicDjG6C6my1IJpNPYjO+8Y9cWecm+aodAeBJLJS1WP6w=='}}
  46. # 使用临时token中的认证信息初始化StsAuth实例。
  47. auth = oss2.StsAuth(token['Credentials']['AccessKeyId'],
  48. token['Credentials']['AccessKeySecret'],
  49. token['Credentials']['SecurityToken'])
  50. print(auth)
  51. # 使用StsAuth实例初始化存储空间。
  52. bucket = oss2.Bucket(auth, endpoint, bucket_name)
  53. # 上传一个字符串。
  54. # res = bucket.put_object('oss_media_hls.ts', b'hello world')
  55. res = bucket.put_object('test/test-name.txt', b'hello world')
  56. print(res)