基于Serverless的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

成都創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),呈貢企業(yè)網(wǎng)站建設(shè),呈貢品牌網(wǎng)站建設(shè),網(wǎng)站定制,呈貢網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,呈貢網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

日常生活中,我們常常會(huì)想要「搜索照片」。每當(dāng)尋找很久遠(yuǎn)的照片時(shí),記憶模糊,檢索照片時(shí)只能想起大致的時(shí)間,然后一張張查看。這樣不僅效率低下,還經(jīng)常會(huì)漏掉我們想找的照片。

近幾年微信小程序發(fā)展迅速,如果有這么一款軟件,我們只需要用文字簡單描述,就能實(shí)現(xiàn)圖片的快速檢索,豈不是很棒!

本項(xiàng)目將以小程序?yàn)槔?Serverless 架構(gòu)上進(jìn)行開發(fā)。該小程序在保留相冊基礎(chǔ)功能(新建相冊、刪除相冊、上傳圖片、查看圖片、刪除圖片)上,增加人工智能搜索 —— 即用戶上傳圖片之后,基于 Image Caption 技術(shù),自動(dòng)對圖片進(jìn)行描述,實(shí)現(xiàn) Image to Text 的過程。這樣,當(dāng)用戶進(jìn)行搜索時(shí),通過文本間的相似度,就可以返回最貼近的圖片。

基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

基礎(chǔ)設(shè)計(jì)

基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

該項(xiàng)目設(shè)計(jì)主要擁有登錄、相冊、圖片上傳和預(yù)覽功能,以及搜索功能。如圖所示:

基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

  • 注冊功能的主要作用是:通過獲取用戶的唯一 id(微信中的 OpenId),來將用戶信息存儲(chǔ)到數(shù)據(jù)庫中,之后的所有操作,都需要以該 id 作為區(qū)分;

  • 相冊功能主要包括相冊的增刪查改等功能;

  • 圖片功能包括圖片上傳、刪除和查看;

  • 搜索功能主要是可以查看指定標(biāo)簽對應(yīng)的圖片列表,以及指定搜索內(nèi)容對應(yīng)的列表。

當(dāng)然這四個(gè)主要功能和模塊是和前端關(guān)系緊密的部分,除此之外還有后端異步操作的兩個(gè)模塊,分別是圖像壓縮和圖像描述功能。

1. 注冊功能:

注冊功能是用戶點(diǎn)擊注冊賬號(hào)之后,執(zhí)行的動(dòng)作。

該動(dòng)作需要注意,注冊之前需先判斷用戶是否已經(jīng)注冊過。如果已注冊則默認(rèn)登陸,否則進(jìn)行注冊并登陸。當(dāng)用戶不想注冊時(shí),可以點(diǎn)擊體驗(yàn)程序,對程序大部分頁面進(jìn)行預(yù)覽。但是不能實(shí)現(xiàn)有關(guān)數(shù)據(jù)庫的增刪改查。登錄功能頁面如圖所示:

基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

2. 相冊功能:

當(dāng)用戶注冊登錄之后,可以在相冊管理頁面進(jìn)行相冊相關(guān)的管理,包括編輯、刪除和新建。在進(jìn)行添加和修改的時(shí)候,需要注意相冊名稱是否已經(jīng)存在;在進(jìn)行刪除、修改相冊等操作時(shí)要判斷用戶是否有操作該相冊的權(quán)限等。相冊功能原型如圖所示:

基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

3. 圖片功能:

圖片功能主要包括圖片列表以及圖片獲取、上傳和刪除。在圖片獲取與刪除的過程中,要對用戶是否有該項(xiàng)操作的權(quán)限進(jìn)行判斷,上傳時(shí)也要判斷是否有上傳到指定相冊的權(quán)限。圖片功能相關(guān)原型圖如所示。

基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

圖片功能部分除了用戶側(cè)可見的功能,還有定時(shí)任務(wù)。當(dāng)用戶上傳圖片之后,系統(tǒng)會(huì)在后臺(tái)異步進(jìn)行圖像壓縮、圖像描述和關(guān)鍵詞提取等。整體流程如圖所示。

基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

4. 搜索功能:

搜索功能指的是通過關(guān)鍵詞或使用者的描述,得到目標(biāo)數(shù)據(jù)的過程。這一功能原型圖如圖所示。

基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

這一部分的難點(diǎn)在于通過用戶的描述,搜索到目標(biāo)數(shù)據(jù)的過程。這個(gè)過程的基本流程如圖所示。

基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

項(xiàng)目開發(fā)

1. 數(shù)據(jù)庫建立

基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的

數(shù)據(jù)庫部分主要對相關(guān)的表和表之間的關(guān)系進(jìn)行建立。 首先需要?jiǎng)?chuàng)建項(xiàng)目所必須的表:

CREATE DATABASE `album`;
CREATE TABLE `album`.`tags` ( `tid` INT NOT NULL AUTO_INCREMENT , `name` VARCHAR(255) NOT NULL , `remark` TEXT NULL , PRIMARY KEY (`tid`)) ENGINE = InnoDB;
CREATE TABLE `album`.`category` ( `cid` INT NOT NULL AUTO_INCREMENT , `name` VARCHAR(255) NOT NULL , `sorted` INT NOT NULL DEFAULT '1' , `user` INT NOT NULL , `remark` TEXT NULL , `publish` DATE NOT NULL , `area` VARCHAR(255) NULL , PRIMARY KEY (`cid`)) ENGINE = InnoDB;
CREATE TABLE `album`.`users` ( `uid` INT NOT NULL AUTO_INCREMENT , `nickname` TEXT NOT NULL , `wechat` VARCHAR(255) NOT NULL , `remark` TEXT NULL , PRIMARY KEY (`uid`)) ENGINE = InnoDB;
CREATE TABLE `album`.`photo` ( `pid` INT NOT NULL AUTO_INCREMENT , `name` VARCHAR(255) NOT NULL , `small` VARCHAR(255) NOT NULL , `large` VARCHAR(255) NOT NULL , `category` INT NOT NULL , `tags` VARCHAR(255) NULL , `remark` TEXT NULL , `creattime` DATE NOT NULL , `creatarea` VARCHAR(255) NOT NULL , `user` INT NOT NULL ,  PRIMARY KEY (`pid`)) ENGINE = InnoDB;
CREATE TABLE `album`.`photo_tags` ( `ptid` INT NOT NULL AUTO_INCREMENT , `tag` INT NOT NULL , `photo` INT NOT NULL , `remark` INT NULL , PRIMARY KEY (`ptid`)) ENGINE = InnoDB;

創(chuàng)建之后,逐步添加表之間的關(guān)系以及部分限制條件:

ALTER TABLE `photo_tags` ADD CONSTRAINT `photo_tags_tags_alter` FOREIGN KEY (`tag`) REFERENCES `tags`(`tid`) ON DELETE CASCADE ON UPDATE RESTRICT; 
ALTER TABLE `photo_tags` ADD CONSTRAINT `photo_tags_photo_alter` FOREIGN KEY (`photo`) REFERENCES `photo`(`pid`) ON DELETE CASCADE ON UPDATE RESTRICT;
ALTER TABLE `photo` ADD CONSTRAINT `photo_category_alter` FOREIGN KEY (`category`) REFERENCES `category`(`cid`) ON DELETE CASCADE ON UPDATE RESTRICT;
ALTER TABLE `photo` ADD CONSTRAINT `photo_user_alter` FOREIGN KEY (`user`) REFERENCES `users`(`uid`) ON DELETE CASCADE ON UPDATE RESTRICT;
ALTER TABLE `category` ADD CONSTRAINT `category_user_alter` FOREIGN KEY (`user`) REFERENCES `users`(`uid`) ON DELETE CASCADE ON UPDATE RESTRICT;
ALTER TABLE `tags` ADD unique(`name`);

2. 讓 Code 飛起來

  • 在使用之前您需要有一個(gè)騰訊云的賬號(hào),并且開通了 SCF、COS、APIGW 以及 CDB 等相關(guān)產(chǎn)品權(quán)限;

  • 將項(xiàng)目 clone 到本地,配置自己的密鑰信息、數(shù)據(jù)庫信息。配置文件在 cloudFunction 目錄下的 serverless.yaml 中:

# 函數(shù)們的整體配置信息
Conf:
  component: "serverless-global"
  inputs:
    region: ap-shanghai
    runtime: Python3.6
    handler: index.main_handler
    include_common: ./common
    MySQL_host: gz-c************************.com
    mysql_user: root
    mysql_password: S************************!
    mysql_port: 6************************0
    mysql_db: album
    mini_program_app_id: asdsa************************dddd
    mini_program_app_secret: fd340c4************************8744ee
    tencent_secret_id: AKID1y************************l1q0kK
    tencent_secret_key: cCoJ************************FZj5Oa
    tencent_appid: 1256773370
    cos_bucket: 'album-1256773370'
    domain: album.0duzahn.com

由于我目前使用的是 Serverless Components,沒有全局變量等。所以在此處增加了全局變量組件,在這里設(shè)置好全局變量,在之后的 Components 中可以直接引用,例如:

# 創(chuàng)建存儲(chǔ)桶
CosBucket:
  component: '@serverless/tencent-website'
  inputs:
    code:
      src: ./cos
    region:  ${Conf.region}
    bucketName: ${Conf.cos_bucket}
  • 安裝必備工具: Serverless Framework、小程序云開發(fā) IDE。由于本項(xiàng)目后臺(tái)開發(fā)語言是 Python,您也需要一些 Python 的開發(fā)工具以及包管理工具(Python 版本不低于 3.6)

  • 在部分文件夾下安裝相對應(yīng)的依賴:

    • cloudFunction/album/prdiction 需要安裝 Pillow, opencv, tensorflow, jieba

    • cloudFunction/album/getPhotoSearch 需要安裝 gensim, jieba 以及 collections

    • cloudFunction/album/compression 需要安裝 Pillow

      (注意,在安裝的時(shí)候一定要用 CentOS 操作系統(tǒng)。如果沒相對應(yīng)系統(tǒng),可以在這里打包對應(yīng)的依賴:http://serverless.0duzhan.com/app/scf_python_package_download/)

  • 將項(xiàng)目部署到云端,只需要通過指令 serverless --debug 即可:

DEBUG ─ Resolving the template's static variables.
  DEBUG ─ Collecting components from the template.
  DEBUG ─ Downloading any NPM components found in the template.
  DEBUG ─ Analyzing the template's components dependencies.
  DEBUG ─ Creating the template's components graph.
  DEBUG ─ Syncing template state.
  DEBUG ─ Executing the template's components graph.
  DEBUG ─ Starting API-Gateway deployment with name APIService in the ap-shanghai region
 
    ... ...
 
  DEBUG ─ Updating configure... 
  DEBUG ─ Created function Album_Get_Photo_Search successful
  DEBUG ─ Setting tags for function Album_Get_Photo_Search
  DEBUG ─ Creating trigger for function Album_Get_Photo_Search
  DEBUG ─ Deployed function Album_Get_Photo_Search successful
  DEBUG ─ Uploaded package successful /Users/dfounderliu/Documents/code/AIAlbum/.serverless/Album_Prediction.zip
  DEBUG ─ Creating function Album_Prediction
  DEBUG ─ Updating code... 
  DEBUG ─ Updating configure... 
  DEBUG ─ Created function Album_Prediction successful
  DEBUG ─ Setting tags for function Album_Prediction
  DEBUG ─ Creating trigger for function Album_Prediction
  DEBUG ─ Trigger timer: timer not changed
  DEBUG ─ Deployed function Album_Prediction successful

  Conf: 
    region:                  ap-shanghai
      
      ... ...
      
      - 
        path:   /photo/delete
        method: ANY
        apiId:  api-g9u6r9wq
      - 
        path:   /album/delete
        method: ANY
        apiId:  api-b4c4xrq8
      - 
        path:   /album/add
        method: ANY
        apiId:  api-ml6q5koy

  156s ? APIService ? done

這個(gè)過程,只用了 156s 便部署了所有函數(shù)。然后打開小程序的 id 帶入 miniProgram 目錄,并且填寫自己的 appid 在文件 project.config.json 的第 17 行,同時(shí)也要配置自己項(xiàng)目的基礎(chǔ)目錄,就是 API 網(wǎng)關(guān)給我們返回的地址,寫在 app.js 的第 10 行,此時(shí)項(xiàng)目就可以運(yùn)行起來了。

上述就是小編為大家分享的基于 Serverless 的人工智能相冊小程序是怎樣實(shí)現(xiàn)的了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

本文名稱:基于Serverless的人工智能相冊小程序是怎樣實(shí)現(xiàn)的
鏈接URL:http://muchs.cn/article38/gedosp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、域名注冊標(biāo)簽優(yōu)化、企業(yè)建站、網(wǎng)站內(nèi)鏈、網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營