283
阿裏雲
快速搭建移動應用直傳服務__移動應用端直傳實踐_最佳實踐_對象存儲 OSS-阿裏雲
本教程幫助您在30分鍾內搭建一個基於OSS的移動應用數據直傳服務。所謂直傳就是移動應用的數據的上傳和下載直接連接OSS,隻有控製流走用戶自己的服務器。
背景
這是一個移動互聯的時代,手機APP上傳的數據越來越多。把數據存儲的問題交給OSS,能夠讓開發者更加專注於自己的應用邏輯。
優勢
搭建一個基於OSS的移動應用數據直傳服務,具有以下優勢:
- 安全的上傳下載方式(臨時、靈活的賦權鑒權)
- 成本低(用戶不需要準備很多服務器,因為移動應用直聯雲存儲,隻有控製流走用戶自己的應用服務器)
- 高並發,支持海量用戶(OSS有海量的上傳和下載帶寬)
- 彈性(OSS有無限擴容的存儲空間)
- 方便(可以方便的對接到媒體轉碼服務-視頻多端適配,圖片處理服務,CDN加速下載等)
架構圖
詳細可以參考這裏。
角色解析
- Android/iOS 移動應用,即最終用戶手機上的APP。
- OSS,即阿裏雲對象存儲,負責存儲APP上傳的數據,可以參考官網介紹。
- RAM/STS負責生成臨時上傳憑證。
- 用戶應用服務器,即提供該Android/iOS應用的開發者開發的APP後台服務,管理APP上傳和下載的Token,以及用戶在APP上傳數據的元數據信息。
數據流解析
- 應用向用戶的應用服務器申請一個臨時上傳憑證。
Android/iOS應用不可能直接存儲AccessKeyID/AccessKeySecret,這樣會存在泄密的風險。所以應用必須向用戶的應用服務器申請一個臨時上傳憑證(下文將此臨時上傳憑證稱為Token),注意這個Token是有時效性的,如這個Token的過期時間是30分鍾(這個時間可以由應用服務器指定),那麼在這30分鍾裏麵,該Android/iOS應用可以使用這個Token從OSS上傳和下載數據, 30分鍾後再重新獲取。 - 用戶的應用服務器檢測上述請求的合法性,然後返回Token給應用。
- 手機拿到這個Token後就可以將數據上傳到OSS,或者從OSS下載數據了。
本教程主要介紹下述紅色和藍色框的內容。
- 藍色框:應用服務器如何生成這個Token
- 紅色框: Android/iOS應用如何獲取Token
效果
本教程實現了一個APP,如下圖所示。您可以掃描二維碼,安裝示例APP程序。此工具是用Android開發的,但是本教程的應用服務器搭建(即上述圖藍色框的內容)也適用於iOS。
示例程序的體驗
示例程序的最終效果圖如下:
- 應用服務器:該移動應用對應的後台應用服務器。本教程搭建了一個後台應用服務器:https://oss-demo.aliyuncs.com/app-server/sts.php。
上傳Bucket:指的是該移動應用要把數據上傳到哪個Bucket。
區域:指的是上傳Bucket對應的區域。
示例APP的使用
單擊選擇圖片,然後把文件上傳到OSS。上傳的方法支持普通上傳和斷點上傳。注意在一些網絡環境差的環境下,最好用斷點上傳。然後可以利用圖片處理服務,對將要上傳的圖片進行縮略和加水印處理。初始使用請暫時先不要更改應用服務器地址和Bucket名字。
準備工作
搭建這樣一個APP上傳和下載的係統,需要完成以下準備工作:
- 開通OSS,並且創建Bucket,在這個例子裏麵的,對應的Bucket是:sdk-demo。創建Bucket的操作請參見 這裏。
- 開通STS服務。開通STS服務是為了生成上述所描述的Token。具體請參見以下“為帳號開通STS服務”。
- 搭建一個應用服務器。這在個例子裏,搭建的應用服務器的地址是:https://oss-demo.aliyuncs.com/app-server/sts.php 。
注意:這個例子是采用PHP編寫的,用戶也可以選擇自己喜歡的語言進行編寫,如Java 、Python、 Go、Ruby、Node.js、C#等。
為帳號開通STS服務
登錄 OSS管理控製台。
單擊 安全令牌 快捷配置。
進入到 安全令牌快捷配置 頁麵,注意如果沒有開通RAM,會彈出開通的對話框。直接單擊 開通,並進行實名驗證。做完後跳到本頁麵。單擊 開始授權。
係統進行自動授權,請務必保存下圖中三個紅框內的參數。
單擊保存AK信息後,對話框會關閉。保存好下麵紅框中的結果3.
保存這三個參數後,STS的開通已經完成了。
注意如果您之前已經點擊這個頁麵創建了AccessKeyId/AccessKeySecret, 彈出的頁麵如下:
單擊如下圖所示的查看。
單擊如下圖所示的創建AccessKey。
記下如下參數1、2。並記下如下參數3。
保存這三個參數後,STS的開通已經完成了。
應用服務器代碼示例的下載
為了方便開發,本教程提供了三個語言的版本示例程序供您下載。
應用服務器示例的配置
每個語言包下載下來後,都會有一個配置文件config.json如下例:
{
"AccessKeyID" : "",
"AccessKeySecret" : "",
"RoleArn" : "",
"TokenExpireTime" : "900",
"PolicyFile": "policy/all_policy.txt"
}
下麵對配置進行講解:
- AccessKeyID: 填寫上述圖標紅的參數1的內容。
- AccessKeySecret: 填寫上述圖標紅的參數2的內容。
- RoleArn: 填寫上述圖標紅的參數3的內容。
- TokenExpireTime: 指Android/iOS應用取到這個Token的失效時間,注意,最少是900s,默認值可以不修改。
- PolicyFile: 填寫的是該Token所要擁有的權限列表的文件, 默認值可以不修改。
本教程準備了三種最常用token 權限文件,放於policy目錄下麵。分別是:- all_policy.txt:指定了該token擁有對該帳號下創建Bucket、刪除Bucket、上傳文件、下載文件、刪除文件的權限 。
- bucket_read_policy.txt:指定了該token擁有該帳號下對指定Bucket的讀權限。
- bucket_read_write_policy.txt: 指定了該token擁有該帳號下對指定Bucket的讀寫權限。
如果你想要指定這個Token隻能對指定的bucket有讀寫權限, 請把(bucket_read_policy.txt、 bucket_read_write_policy.txt)這個文件裏麵$BUCKET_NAME直接替換成指定的bucket名字。
返回的格式解析:
{
"status":200,
"AccessKeyId":"STS.3pYjsdgdgagdasdg",
"AccessKeySecret":"rpnwO9kvEgetGdrddgsR2YrTtI",
"Security":"CAES+wMIARKAAZhjH0EUOIhJMQBMjRywXq7MQ/cjLYg80Aho1ek0Jm63XMhr9Oc5s˙∂˙∂3qaPer8p1YaX1NTDiCFZWFkvlHf1pQhuxfKBc+mRR9KAbHUefqH+rdjZqjTF7p2m1wJXP8S6k+G2MpHrUe6TYBkJ43GhhTVFMuM3BZajY3VjZWOXBIODRIR1FKZjIiEjMzMzE0MjY0NzM5MTE4NjkxMSoLY2xpZGSSDgSDGAGESGTETqOio6c2RrLWRlbW8vKgoUYWNzOm9zczoqOio6c2RrLWRlbW9KEDExNDg5MzAxMDcyNDY4MThSBTI2ODQyWg9Bc3N1bWVkUm9sZVVzZXJgAGoSMzMzMTQyNjQ3MzkxMTg2OTExcglzZGstZGVtbzI=",
"Expiration":"2015-12-12T07:49:09Z",
}
- status:表示獲取Token的狀態,獲取成功時,返回值是200。
- AccessKeyId: 表示Android/iOS應用初始化OSSClient獲取的 AccessKeyId。
- AccessKeySecret: 表示Android/iOS應用初始化OSSClient獲取AccessKeySecret。
- SecurityToken:表示Android/iOS應用初始化的Token。
- Expiration: 表示該Token失效的時間。主要在Android SDK會自動判斷是否失效,自動獲取Token。注意上述這四個變量將構成了一個Token。
代碼示例的運行方法
- 對於PHP版本,將包下載解壓後,修改config.json這個文件,直接運行php sts.php 即能生成Token,將程序部署到指定的地址。
- 對於JAVA版本 (依賴於java 1.7),將包下載解壓後,運行方法:java -jar oss-token-server.jar (port)。如果不指定port(端口), 直接運行java –jar oss-token-server.jar,程序會監聽7080端口。如果想讓程序執行在9000端口,運行java –jar oss-token-server.jar 9000 , 其他端口也類似。
體驗自己的APP上傳應用服務器
- 把程序部署起來後,記下應用服務器地址如
https://abc.com:8080
將示例程序裏麵的應用服務器修改成上述地址。 - 選擇自己數據要上傳到哪個Bcuket及區域,修改示例APP程序裏麵相應Bucket及區域。
- 單擊設置按鈕,將配置加載。
- 選擇圖片,設置上傳OSS文件名,上傳。然後就可以在Android上體驗OSS服務了。這樣你就能通Android 示例程序將數據直接上傳到OSS了。
- 上傳成功後,可以看一下數據是否在OSS上了。
核心代碼解析:OSS初始化
下麵講解如何利用Android/iOS SDK跟自己的應用服務器,請求Token。
- Android版本
//初始化一個OssService用來上傳
public OssService initOSS(String endpoint, String bucket, UIDisplayer displayer) {
OSSCredentialProvider credentialProvider;
//使用自己的獲取STSToken的類
//從應用服務器控件裏麵讀取應用服務器地址
String stsServer = ((EditText) findViewById(R.id.stsserver)).getText().toString();
//STSGetter類,封裝如何跟從應用服務器取數據,必須繼承於OSSFederationCredentialProvider這個類。 取Token這個取決於你所寫的APP跟應用服務器數據的協議設計。
if (stsServer .equals("")) {
credentialProvider = new STSGetter();
}else {
credentialProvider = new STSGetter(stsServer);
}
//獲取控件上的bucket名字
bucket = ((EditText) findViewById(R.id.bucketname)).getText().toString();
//初始化OSSClient
ClientConfiguration conf = new ClientConfiguration();
conf.setConnectionTimeout(15 * 1000); // 連接超時,默認15秒
conf.setSocketTimeout(15 * 1000); // socket超時,默認15秒
conf.setMaxConcurrentRequest(5); // 最大並發請求書,默認5個
conf.setMaxErrorRetry(2); // 失敗後最大重試次數,默認2次
OSS oss = new OSSClient(getApplicationContext(), endpoint, credentialProvider, conf);
return new OssService(oss, bucket, displayer);
}
- iOS版本
// 初始化一個OSSClient實例
- (void)ossInit {
// 構造一個獲取STSToken的憑證提供器
id<OSSCredentialProvider> credential = [[OSSFederationCredentialProvider alloc] initWithFederationTokenGetter:^OSSFederationToken * {
// 實現一個函數,同步返回從server獲取到的STSToken
return [self getFederationToken];
}];
// 用endpoint、憑證提供器初始化一個OSSClient
client = [[OSSClient alloc] initWithEndpoint:endPoint credentialProvider:credential];
}
核心代碼解析:移動應用從應用服務器取Token
具體APP從應用服務器取Token的方法,必須寫到public OSSFederationToken getFederationToken() { }
這個函數裏麵。注意這個函數的邏輯依賴於可以自己設定,但是最終結果必須返回這樣一個變量 return new OSSFederationToken(ak, sk, token, expiration)
,其中ak, sk, token, expiration 必須是從應用服務器返回的Body獲取的。
在本例子裏,示例如下。注意用戶可以自定義自己的移動應用跟自己應用服務器之前的協議。
- Android版本
public OSSFederationToken getFederationToken() {
String stsJson;
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder().url(stsServer).build();
try {
Response response = client.newCall(request).execute();
if (response.isSuccessful()) {
stsJson = response.body().string();
} else {
throw new IOException("Unexpected code " + response);
}
}
catch (IOException e) {
e.printStackTrace();
Log.e("GetSTSTokenFail", e.toString());
return null;
}
try {
JSONObject jsonObjs = new JSONObject(stsJson);
String ak = jsonObjs.getString("AccessKeyId");
String sk = jsonObjs.getString("AccessKeySecret");
String token = jsonObjs.getString("SecurityToken");
String expiration = jsonObjs.getString("Expiration");
return new OSSFederationToken(ak, sk, token, expiration);
}
catch (JSONException e) {
Log.e("GetSTSTokenFail", e.toString());
e.printStackTrace();
return null;
}}
- iOS版本
NSURL * url = [NSURL URLWithString:STSServer];
NSURLRequest * request = [NSURLRequest requestWithURL:url];
OSSTaskCompletionSource * tcs = [OSSTaskCompletionSource taskCompletionSource];
NSURLSession * session = [NSURLSession sharedSession];
NSURLSessionTask * sessionTask = [session dataTaskWithRequest:request
completionHandler:^(NSData *data, NSURLResponse *response, NSError *error) {
if (error) {
[tcs setError:error];
return;
}
[tcs setResult:data];
}];
[sessionTask resume];
// 實現這個回調需要同步返回Token,所以要waitUntilFinished
[tcs.task waitUntilFinished];
if (tcs.task.error) {
// 如果網絡請求出錯,返回nil表示無法獲取到Token。該次請求OSS會失敗。
return nil;
} else {
// 從網絡請求返回的內容中解析JSON串拿到Token的各個字段,組成STSToken返回
NSDictionary * object = [NSJSONSerialization JSONObjectWithData:tcs.task.result
options:kNilOptions
error:nil];
OSSFederationToken * token = [OSSFederationToken new];ni
token.tAccessKey = [object objectForKey:@"AccessKeyId"];
token.tSecretKey = [object objectForKey:@"AccessKeySecret"];
token.tToken = [object objectForKey:@"SecurityToken"];
token.expirationTimeInGMTFormat = [object objectForKey:@"Expiration"];
return token;
}
示例程序的實現
應用服務器代碼示例的下載
最後更新:2016-11-23 16:04:09
上一篇:
雲端數據處理__開發人員指南_對象存儲 OSS-阿裏雲
下一篇:
權限控製__移動應用端直傳實踐_最佳實踐_對象存儲 OSS-阿裏雲
LoginProfile__數據類型_RAM API文檔_訪問控製-阿裏雲
修改查詢刪除伸縮規則__伸縮規則_用戶指南_彈性伸縮-阿裏雲
修改期望虛擬機數量__SDK接口說明_Java版SDK_批量計算-阿裏雲
充儲值卡返券規則是什麼?___儲值卡_代金券及推薦碼_財務-阿裏雲
智能客服__阿裏雲ET介紹-阿裏雲
容器服務監控__雲服務監控_用戶指南_雲監控-阿裏雲
SecurityGroupIdSetType__數據類型_API 參考_雲服務器 ECS-阿裏雲
測試報告階段__性能測試流程體係_性能測試體係_性能測試-阿裏雲
NAT網關__網關_用戶指南_專有網絡 VPC-阿裏雲
執行伸縮規則__觸發任務_用戶指南_彈性伸縮-阿裏雲
相關內容
常見錯誤說明__附錄_大數據計算服務-阿裏雲
發送短信接口__API使用手冊_短信服務-阿裏雲
接口文檔__Android_安全組件教程_移動安全-阿裏雲
運營商錯誤碼(聯通)__常見問題_短信服務-阿裏雲
設置短信模板__使用手冊_短信服務-阿裏雲
OSS 權限問題及排查__常見錯誤及排除_最佳實踐_對象存儲 OSS-阿裏雲
消息通知__操作指南_批量計算-阿裏雲
設備端快速接入(MQTT)__快速開始_阿裏雲物聯網套件-阿裏雲
查詢API調用流量數據__API管理相關接口_API_API 網關-阿裏雲
使用STS訪問__JavaScript-SDK_SDK 參考_對象存儲 OSS-阿裏雲