華為AppGallery Connect提供了一個雲存儲(CloudStorage)的服務,號稱提供了一個便捷的雲端存儲服務,應用開發者使用的時候,可以不用關注服務器的部署,直接使用就行。
這個服務近期上線了Web端的JavaScript的SDK,我搶先體驗試用了一下。也可以下載codelab或者demo自行研究。
1、環境與應用信息
版本名稱 | 集成環境-應用 | 測試設備 |
---|---|---|
"cloudstorage": "1.0.0" | Window-Node-v14.15.0 npm v6.14.8 Intellij + Vue | PC-Chrome |
環境:https://developer.huawei.com/consumer/rn/service/josp/agc/index.html
SDK版本:"@agconnect/cloudstorage": "^1.0.0-beta3"
集成SDK命令:npm install --save @agconnect/cloudstorage
2、在AGC上開通雲存儲:
PS: 雲存儲服務目前還處於beta狀態,使用前應該發郵件去申請開通:
https://developer.huawei.com/consumer/cn/doc/development/AppGallery-connect-Guides/agc-cloudstorage-apply
在我的項目 下選擇你的開發項目,在構建下面,找到雲存儲服務,點擊開通:
沒有Web項目的話,需要先自己創建一個。
開通服務的時候,需要先配置存儲實例,這里按需配置就可以,我就隨便配置一個。
下一步,還需要配置安全策略,這里使用默認的安全策略就好:
PS:默認的情況是,只有經過身份認證的用戶才能進行讀寫。
3、安裝開發環境:
1、安裝Intellij IDEA:
下載地址:https://www.jetbrains.com/idea/download/#section=windows
安裝的時候,記得選for web的 IntelliJ IDEA Ultimate
2、創建vue項目
3、編譯完成后,生成以下文件:
4、SDK集成
1、打開命令行窗口,進入到項目目錄下,在項目目錄下執行以下命令,安裝雲存儲的JS SDK:
npm install --save @agconnect/cloudstorage
安裝雲存儲的JS SDK后,會自動匹配AGC SDK,無需額外安裝。
2、應用級src目錄下創建名為 “agConnectConfig.js” 的文件,並且將AGC界面上“項目設置 > SDK代碼片段”中所有內容復制到“agConnectConfig.js”里
注意添加export 參數
3、在項目路徑下執行npm install命令 安裝 package.json 依賴。
5、功能開發
a) 頁面布局-新建一個
1、新建一個Page.vue文件,在template便簽下添加如下代碼布局
<div class = "hello">
<div v-show="!isLogin">
<el-button type="primary" @click="signInAnonymously">Login</el-button>
</div>
<div v-show="isLogin" style="max-width:1600px;margin:auto;">
<h1>AGCCloudStorageDemo</h1>
<div style="display:flex;margin-bottom:30px;">
<el-button type="primary" size="medium" @click="getFileList('')">Get FileList</el-button>
<el-button type="primary" size="medium" @click="getFileListAll('')">
Get FileList All
</el-button>
<el-button type="primary" size="medium" @click="uploadString">
Upload String
</el-button>
<el-upload action :on-change="uploadFile" :auto-upload="false">
<el-button type="primary" size="medium" style="width: 100%;margin-left:10px;">Upload File</el-button>
</el-upload>
</div>
<el-table
ref="multipleTable"
border
size="medium"
:data="list">
<el-table-column
type="selection"
width="55">
</el-table-column>
<el-table-column width="80px" label="index">
<template v-slot="scope">
{{ scope.$index + 1 }}
</template>
</el-table-column>
<el-table-column width="100px" label="type">
<template v-slot="scope">
{{ scope.row.isFile ? 'file' : 'directory' }}
</template>
</el-table-column>
<el-table-column
width="150px"
label="name"
prop="name"
show-overflow-tooltip>
</el-table-column>
<el-table-column label="operation">
<template v-slot="scope">
<el-button
v-if="!scope.row.isFile"
type="success"
size="medium"
@click="getFileList(scope.row)"
>
Get FileList
</el-button>
<el-button
v-if="!scope.row.isFile"
type="success"
size="medium"
@click="getFileListAll(scope.row)"
>
Get FileList All
</el-button>
<el-button
v-if="scope.row.isFile"
type="success"
size="medium"
@click="downloadFile(scope.row)"
>
Download File
</el-button>
<el-button
v-if="scope.row.isFile"
type="success"
size="medium"
@click="getFileMetadata(scope.row)"
>
Get FileMetadata
</el-button>
<el-button
v-if="scope.row.isFile"
type="success"
size="medium"
@click="updateFileMetadata(scope.row)"
>
Update FileMetadata
</el-button>
<el-button v-if="scope.row.isFile" type="danger" size="medium" @click="deleteFile(scope.row)">
Delete File
</el-button>
<el-button type="success" size="medium" @click="toString(scope.row)">
To String
</el-button>
</template>
</el-table-column>
</el-table>
</div>
</div>
b) 添加配置依賴 & 初始化
1、在script標簽下,添加編譯依賴
import agconnect from "@agconnect/api";
import "@agconnect/instance";
import "@agconnect/auth";
import "@agconnect/cloudstorage";
2、 初始化SDK:
import { agConnectConfig } from "../agConnectConfig";
const config = agConnectConfig
c) 前置方法:數據與匿名登錄
1、在export default對象內,添加data對象,並且配置如下內容:
data(){
return {
list:[],
isLogin:false,
ref:{}
}
},
2、在export default對象內,添加對mounted對象,並且配置如下內容:
mounted(){
agconnect.instance().configInstance(config)
},
3、添加主要方法:在export default對象內添加method對象,並且添加匿名登錄方法:
methods:{
async signInAnonymously () {
agconnect
.auth()
.signInAnonymously()
.then(() => {
alert('login successfully!')
this.isLogin = true
this.ref = agconnect.cloudStorage().storageReference()
})
.catch(() => {
return Promise.reject('sign in anonymously failed')
})
},
d) 上傳文件:
在method對象內,添加如下上傳文件的方法:
uploadFile(file) {
const path = 'jssdk/' + file.name
const metadata = {
cacheControl: 'helloworld',
contentDisposition: 'helloworld',
contentEncoding: 'helloworld',
contentLanguage: 'helloworld',
contentType: 'helloworld',
customMetadata: {
hello: 'kitty'
}
}
var uploadTask = this.ref.child(path).put(file.raw, metadata)
this.printUploadPercent(uploadTask)
},
printUploadPercent (uploadTask) {
uploadTask.on('state_changed', function (snapshot) {
if(!snapshot){
console.log('Upload Result is null')
return;
}
if(snapshot.totalByteCount == 0){
console.log('Upload File is empty')
return;
}
var progress = (snapshot.bytesTransferred / snapshot.totalByteCount) * 100
console.log('Upload is ' + progress.toFixed(1) + '% done')
switch (snapshot.state) {
case 'paused':
console.log('Upload is paused')
break
case 'running':
console.log('Upload is running')
break
case 'success':
console.log('Upload is success')
break
case 'canceled':
console.log('Upload is canceled')
break
case 'error':
console.log('Upload is error')
break
}
}, function (snapshot) {
switch (snapshot.state) {
case 'paused':
console.log('Upload is paused')
break
case 'running':
console.log('Upload is running')
break
case 'success':
console.log('Upload is success')
break
case 'canceled':
console.log('Upload is canceled')
break
case 'error':
console.log('Upload is error')
break
}
}, function () {
console.log('Upload is success')
})
},
e) 下載文件:
在method對象內,添加如下下載文件的方法:
downloadFile(row) {
const child = this.ref.child(row.path)
child.getDownloadURL().then(function (downloadURL) {
alert(downloadURL)
console.log(downloadURL)
})
},
f) 例舉文件,其余功能暫不列舉:
在method對象內,添加如下例舉文件的方法:
getFileList(row) {
var path = row && row.path ? row.path : '';
const child = this.ref.child(path)
child.list({ maxResults: 5 }).then((res) => {
this.list = [...res.dirList.map(item => { item.isFile = false; item.select = false; return item }), ...res.fileList.map(item => { item.isFile = true; item.select = false; return item })]
this.nextMarker = res.pageMarker
console.log(this.list)
}).catch(err => {
console.log(err)
})
},
getFileListAll(row) {
const child = this.ref.child(row && row.path ? row.path : '')
child.listAll()
.then((res) => {
console.log('res', res)
this.list = [...res.dirList.map(item => { item.isFile = false; item.select = false; return item }), ...res.fileList.map(item => { item.isFile = true; item.select = false; return item })]
})
.catch((err) => {
console.log(err)
})
},
6、功能點驗證
1、Web運行前置要求:
1、添加element-ui相關依賴: 在main.js文件內,添加element-ui依賴
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
Vue.use(ElementUI);
2、安裝element-ui依賴,使用命令行,在項目路徑下,執行如下命令安裝element-ui依賴:
npm install element-ui -S
安裝完成后,package.json文件中,將導入如下內容:
3、在app.vue文件中,配置默認啟動的vue:
在template標簽下,修改默認啟動為創建的page.
<template>
<div id="app">
<Page />
</div>
</template>
在script標簽下,導入並且修改默認的啟動vue.
<script>
import Page from './components/Page.vue'
export default {
name: 'App',
components: {
Page
}
}
</script>
修改以后,結果如下:
2、運行項目
在項目目錄下,執行npm run serve命令啟動項目,點擊local超鏈接進入項目。
3、配置跨域請求:
由於我們當前使用的是本地的IP,即http://localhost:8080/的地址,與雲存儲雲端進行通信的時候,存在網絡跨域,需要先通過Server SDK配置網絡跨域的相關參數,否則會出現如下錯誤:
具體NodeJS項目的集成,請參照上一篇文檔:快速集成華為AGConnect雲存儲服務-NodeJS中的描述。
在NodeJS代碼中,通過setCorsConfiguration方法配置跨域參數。代碼如下:
crossIP();
function crossIP() {
const storage = new StorageManagement();
const bucket = storage.bucket(bucketName);
bucket.setCorsConfiguration();
const config = [{
"origins": ["*"],
"methods": ["GET", "POST", "PUT", "DELETE"],
}];
bucket.setCorsConfiguration(config).then(res =>
console.log('bucket.setCors res: ', res)
).catch(err => {
console.log('bucket.setCors err: ', err)
})
}
3、運行界面:需要先登錄:
4、獲取文件列表:
點擊Get FileList,獲取文件列表
5、上傳文件
點擊UpLoad File,選擇相應的文件以后,可以點擊界面上的GetFileList All,可以看到通過JSSDK的路徑,
點擊該路徑后方的,Get FileList,可以看到剛剛上傳的文件:
6、其他功能就不逐一測試了,各位可以自行驗證。
7、總結
僅關注Web端的開發,就可以在web界面上操作項目中的文件。再也不用為了服務器的搭建和運維擔心,省時省力。而且還提供了類似於管理員模式的web控制台,可以簡單直觀的對服務器上的文件進行管理。
這個雲存儲服務,除了最普通的上傳下載和刪除功能,還包括有列舉文件,設置元數據等功能,具體可以看官方文檔:
雲存儲服務開發指南:
雲存儲服務codelab-web:
https://developer.huawei.com/consumer/cn/codelab/CloudStorage-web/index.html#0
原文鏈接:https://developer.huawei.com/consumer/cn/forum/topic/0204411958886860388?fid=0101271690375130218
原作者:Mayism