flutter社區(qū),flutter平臺

android和idea寫一個(gè)社區(qū)服務(wù)

IDEA寫android服務(wù)端,使用IDEA運(yùn)行Android平臺Flutter工程。

創(chuàng)新互聯(lián)專注骨干網(wǎng)絡(luò)服務(wù)器租用10年,服務(wù)更有保障!服務(wù)器租用,簡陽服務(wù)器托管 成都服務(wù)器租用,成都服務(wù)器托管,骨干網(wǎng)絡(luò)帶寬,享受低延遲,高速訪問。靈活、實(shí)現(xiàn)低成本的共享或公網(wǎng)數(shù)據(jù)中心高速帶寬的專屬高性能服務(wù)器。

Android App作為客戶端與idea后臺服務(wù)器通信,操作數(shù)據(jù)庫進(jìn)行查詢,驗(yàn)證,添加數(shù)據(jù)。具體實(shí)例,登錄,注冊,查詢用戶,權(quán)限分級,提交訂單。

小程序有兩個(gè)頁面(index,ding),在第一個(gè)頁面實(shí)現(xiàn)用戶的查詢,登錄,注冊功能,登錄成功后跳轉(zhuǎn)到訂單頁面。

補(bǔ)齊短板-開源IM項(xiàng)目OpenIM關(guān)于初始化/登錄/好友接口文檔介紹

OpenIM文檔方面的建設(shè)一直遠(yuǎn)遠(yuǎn)落后于開發(fā), 也經(jīng)常被開發(fā)者詬病,在接下來一周的時(shí)間里,我們重點(diǎn)補(bǔ)齊文檔,讓開發(fā)者更輕松接入。由于app sdk底層都是go來實(shí)現(xiàn),所以本文先寫一個(gè)模板和框架,在接下來的時(shí)間里,會(huì)有iOS、Android、Flutter、Uniapp、jssdk同事補(bǔ)充具體的細(xì)節(jié),并更新到官網(wǎng)

![0](C:\Users\Administrator\Desktop\OpenIM\官網(wǎng)相關(guān)\技術(shù)文章\6-25\0.png)

## 初始化及登錄

初始化并登錄成功回調(diào),是正常使用OpenIM 服務(wù)的前提

| SDK? ? ? ? ? ? ? | 描述? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| :--------------- | :----------------------------------------------------------- |

| [Login]? ? ? ? ? | 登錄,如果登錄成功,必須退出登錄才能再次執(zhí)行登錄操作? ? ? ? |

| [Logout]? ? ? ? | 退出登錄? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [GetLoginStatus] | 獲取登錄狀態(tài), 101:登錄成功,? 102:登陸中,? 103:登錄失敗,? 201:退出登錄 |

| [GetLoginUser]? | 獲取當(dāng)前登錄用戶UserID,此時(shí)用戶登錄狀態(tài)未知? ? ? ? ? ? ? ? |

| [initSDK]? ? ? ? | 初始化 SDK,整個(gè)生命周期執(zhí)行一次,登錄相關(guān)監(jiān)聽介紹如下:? ? |

OpenIM和調(diào)用方利用監(jiān)聽回調(diào)機(jī)制,和調(diào)用方信息互通,把登錄狀態(tài)通過異步回調(diào)方式即時(shí)傳遞給調(diào)用方,確保信息及時(shí)傳達(dá)而不阻塞其主線程。

## 監(jiān)聽說明

| 登錄相關(guān)監(jiān)聽? ? ? ? | 回調(diào)描述? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| :------------------- | :----------------------------------------------------------- |

| [OnConnecting]? ? ? | 連接中,在連接后臺時(shí)(包括重連)回調(diào)? ? ? ? ? ? ? ? ? ? ? ? |

| [OnConnectSuccess]? | 連接成功? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [OnConnectFailed]? ? | 連接失敗,如果因網(wǎng)絡(luò)連接失敗會(huì)重連,其他情況不重連? ? ? ? ? |

| [OnKickedOffline]? ? | 被踢下線,可能由于多端登錄策略所致,或后臺管理員強(qiáng)制其退出登錄 |

| [OnUserTokenExpired] | 檢測token過期回調(diào)? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

## 調(diào)用流程

OpenIM調(diào)用流程分為如下幾步:

(1)初始化:在整個(gè)生命周期執(zhí)行一次

(2)設(shè)置監(jiān)聽:包括群組監(jiān)聽,好友監(jiān)聽,用戶監(jiān)聽,消息及會(huì)話監(jiān)聽,這些監(jiān)聽會(huì)在其他章節(jié)中描述

(3)登錄:登錄回調(diào)成功后再執(zhí)行其他操作,否則可能出現(xiàn)資源加載未完成的錯(cuò)誤

(4)收發(fā)消息等操作;

## 好友管理相關(guān)接口

OpenIM提供好友關(guān)系托管,比如好友申請,同意,以及好友獲取等,OpenIM在客戶端本地存儲好友關(guān)系,并結(jié)合消息通知機(jī)制,按需調(diào)用后臺接口,確保本地和服務(wù)端數(shù)據(jù)一致。同時(shí)利用監(jiān)聽機(jī)制,把數(shù)據(jù)變化通過異步回調(diào)傳達(dá)調(diào)用方。OpenIM在收發(fā)消息時(shí),默認(rèn)不檢查好友關(guān)系,您可以在配置文件中自行修改。OpenIM好友關(guān)系是雙向關(guān)系,A添加B為好友后,則A在B的好友列表中,B也在A的好友列表中,A刪除B,僅僅只是刪除A的好友列表,而B的好友列表不受影響。同樣,黑名單也類似。

| SDK? ? ? ? ? ? ? ? ? ? ? ? ? ? | 描述? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| :----------------------------- | :------------------------------------------------------- |

| [GetDesignatedFriendsInfo]? ? | 獲取指定好友的信息? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [GetFriendList]? ? ? ? ? ? ? ? | 獲取所有的好友列表? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [SearchFriends]? ? ? ? ? ? ? ? | 通過關(guān)鍵詞搜索好友? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [CheckFriend]? ? ? ? ? ? ? ? ? | 檢查是否好友關(guān)系? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [AddFriend]? ? ? ? ? ? ? ? ? ? | 發(fā)起添加好友請求? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [SetFriendRemark]? ? ? ? ? ? ? | 設(shè)置好友備注? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [DeleteFriend]? ? ? ? ? ? ? ? | 刪除好友(單向刪除)? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [GetRecvFriendApplicationList] | 獲取我收到的添加好友申請列表? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [GetSendFriendApplicationList] | 獲取我發(fā)起的的添加好友申請列表? ? ? ? ? ? ? ? ? ? ? ? ? |

| [AcceptFriendApplication]? ? ? | 同意好友申請? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [RefuseFriendApplication]? ? ? | 拒絕好友申請? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| [SetFriendListener]? ? ? ? ? ? | 設(shè)置好友、黑名單相關(guān)監(jiān)聽,用于UI層實(shí)時(shí)感知數(shù)據(jù)變化并刷新 |

## 監(jiān)聽說明

好友監(jiān)聽器的作用:調(diào)用方設(shè)置好友監(jiān)聽,好友關(guān)系的變化會(huì)通過OpenIM消息機(jī)制實(shí)時(shí)同步到需要感知的在線用戶,包括用戶的其他端,調(diào)用方根據(jù)回調(diào)事件做相關(guān)的數(shù)據(jù)處理。

比如用戶B在Android端添加用戶A為好友,用戶A(所有在線的終端)收到B的好友申請,則A調(diào)用GetRecvFriendApplicationList獲取收到的好友申請列表,刷新界面。同時(shí),用戶B在線其他的終端比如PC端也會(huì)收到通知,B調(diào)用GetSendFriendApplicationList獲取發(fā)起的好友申請列表,刷新B發(fā)出的好友申請列表。

當(dāng)然也可以利用回調(diào)的參數(shù)信息,做增量處理,而不用獲取全量的好友申請列表。

以用戶B申請?zhí)砑佑脩鬉為例

| 好友及黑名單監(jiān)聽? ? ? ? ? ? ? | 描述? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

| :---------------------------- | :--------------------------------------------------- |

| [OnFriendApplicationAdded]? ? | 好友申請列表增加,主動(dòng)發(fā)起者和被動(dòng)添加者會(huì)收到? ? ? |

| [OnFriendApplicationDeleted]? | 好友申請列表刪除,主動(dòng)刪除者會(huì)收到? ? ? ? ? ? ? ? ? |

| [OnFriendApplicationAccepted] | 好友申請被同意,主動(dòng)發(fā)起者和被動(dòng)添加者會(huì)收到? ? ? ? |

| [OnFriendApplicationRejected] | 好友申請被拒絕,主動(dòng)發(fā)起者和被動(dòng)添加者會(huì)收到? ? ? ? |

| [OnFriendAdded]? ? ? ? ? ? ? | 好友增加,用戶好友增加時(shí)會(huì)收到? ? ? ? ? ? ? ? ? ? ? |

| [OnFriendDeleted]? ? ? ? ? ? | 好友刪除,用戶好友減少時(shí)會(huì)收到? ? ? ? ? ? ? ? ? ? ? |

| [OnFriendInfoChanged]? ? ? ? | 好友信息改變,用戶好友信息(比如昵稱等)改變時(shí)會(huì)收到 |

| [OnBlackAdded]? ? ? ? ? ? ? ? | 黑名單增加,用戶黑名單增加時(shí)會(huì)收到? ? ? ? ? ? ? ? ? |

| [OnBlackDeleted]? ? ? ? ? ? ? | 黑名單移除,用戶黑名單減少時(shí)會(huì)收到? ? ? ? ? ? ? ? ? |

## 項(xiàng)目介紹

OpenIM繼續(xù)領(lǐng)跑開源IM領(lǐng)域,在廣大開發(fā)者的支持下,目前github star突破9k。在數(shù)據(jù)泄露、信息外泄、隱私濫用的時(shí)代,IM私有化部署需求旺盛。其中,政企協(xié)同辦公對IM需求猛增,隨著信息化技術(shù)的迭代升級以及信創(chuàng)產(chǎn)業(yè)加速落地和實(shí)踐,協(xié)同辦公軟件的發(fā)展?jié)摿⑦M(jìn)一步被釋放?!鞍踩煽亍爸鸩匠蔀榈谝灰?。對于社區(qū)交友領(lǐng)域,暴露出的隱私安全問題越來越多,私有化部署確保用戶數(shù)據(jù)不泄露。

OpenIM從服務(wù)端到客戶端SDK開源即時(shí)通訊(IM)整體解決方案,可以輕松替代第三方IM云服務(wù),打造具備聊天、社交、辦公功能的app。

github地址:

開發(fā)者中心:

## OpenIM團(tuán)隊(duì)

創(chuàng)始團(tuán)隊(duì)來自資深I(lǐng)M技術(shù)團(tuán)隊(duì),我們致力于用開源技術(shù)創(chuàng)造服務(wù)價(jià)值,打造輕量級、高可用的IM架構(gòu),開發(fā)者只需簡單調(diào)用 SDK,即可在應(yīng)用內(nèi)構(gòu)建多種即時(shí)通訊及實(shí)時(shí)音視頻互動(dòng)場景。OpenIM優(yōu)勢:開源,安全,可靠,低成本。對于信息安全重視的電子政務(wù),企業(yè)協(xié)同辦公,OpenIM都是非常好的選擇。

從公司成立之初就將“開源”作為核心戰(zhàn)略來推進(jìn),開源充分體現(xiàn)了自由、平等、分享的互聯(lián)網(wǎng)精神。

OpenIM邀請全球技術(shù)極客參與技術(shù)優(yōu)化,讓開發(fā)者輕松集成,讓每一個(gè)應(yīng)用都具備IM功能,同時(shí)考慮企業(yè)的接入成本、服務(wù)器資源以及最重要的數(shù)據(jù)安全性和私密性。

Flutter開發(fā)環(huán)境配置(MAC版)

(該路徑會(huì)有變化,可以關(guān)注Flutter社區(qū),隨時(shí)更新)

Documents為目錄,fluttersdk為sdk文件夾

cd 到對應(yīng)的項(xiàng)目工程中執(zhí)行命令:

在終端中執(zhí)行 flutter doctor 查看Android和iOS的開發(fā)環(huán)境,監(jiān)測到依賴若有缺失,會(huì)給出缺失的依賴的安裝結(jié)果,依照提示進(jìn)行安裝即可。

在命令終端執(zhí)行相關(guān)命令:

打開Android Studio應(yīng)用,打開菜單項(xiàng)Preferences Plugins中搜索Flutter插件并點(diǎn)擊install進(jìn)行安裝

打開 VS Code,可點(diǎn)擊 View - Command Palette,搜索flutter并點(diǎn)擊install進(jìn)行安裝

FlutterWeb 和 WebView 原生交互調(diào)用

需要?jiǎng)?chuàng)建兩個(gè)工程,一個(gè)是FlutterWeb工程最終打包成Web頁面,一個(gè)是Flutter原生工程承載一個(gè)WebView用來加載Web頁面。這樣做的好處在于只需要一種語言開發(fā)iOS和Android不用對接兩次,可以直接使用社區(qū)Flutter原生工程的插件,只需要封裝給Web調(diào)用。

FlutterWeb工程pubspec.yaml添加依賴

Flutter原生工程pubspec.yaml添加依賴

創(chuàng)建一個(gè) toast_channel.dart,定義一個(gè)類實(shí)現(xiàn) JavascriptChannel 重寫name指定channel名稱和onMessageReceived指定調(diào)用函數(shù)

在WebView的 javascriptChannels 配置上定義的Channel

創(chuàng)建一個(gè) native_channel.dart ,定義一個(gè)外部函數(shù)通過 @JS("調(diào)用的channel和函數(shù)名") 注解指定調(diào)用的原生函數(shù)(JavascriptChannel固定名稱為postMessage)

需要使用的地方直接調(diào)用

創(chuàng)建一個(gè) js_function.dart,存放被原生調(diào)用的函數(shù)名稱

將要提供給原生調(diào)用的函數(shù),通過 js.context[原生調(diào)用名稱] = 函數(shù) 開放給外部調(diào)用

如果在FlutterWeb工程要使用這個(gè)函數(shù)也可以使用@JS注解

WebView 創(chuàng)建時(shí)會(huì)回調(diào) onWebViewCreated 獲得 WebViewController ,WebViewController 調(diào)用 runJavascript 會(huì)執(zhí)行JS函數(shù)無返回值,調(diào)用 runJavascriptReturningResult 會(huì)執(zhí)行JS函數(shù)有返回值。

FutureBuilder獲取WebViewController, 需要使用的地方直接調(diào)用

使用 HTML,CSS,Canvas 和 SVG 元素來渲染。

缺點(diǎn):會(huì)存在不同平臺效果不一樣。

優(yōu)點(diǎn):不加載canvaskit默認(rèn)使用系統(tǒng)字體,加載過程沒有多余開銷。

需要用到wasm,WebAssembly 要求需要瀏覽器支持,WebView Android需要最低需要57,Safari iOS 需要最低需要 11。

缺點(diǎn):canvaskit 有7m大默認(rèn)地址在國外首次加載耗時(shí);中文會(huì)加載字體庫默認(rèn)地址在國外加載慢。

優(yōu)點(diǎn):性能更好,渲染效果一致。

--web-renderer=auto 默認(rèn)移動(dòng)端瀏覽器選擇 HTML,桌面端瀏覽器選擇 CanvasKit。

--web-renderer=html 使用 HTML 渲染器

--web-renderer=canvaskit 使用 CanvasKit 渲染器

綜上所訴推薦移動(dòng)端使用HTML渲染更合適,在編譯和打包時(shí)指定渲染器 --web-renderer=html 。

--debug 模式構(gòu)建的 Web 應(yīng)用沒有被壓縮,且 Tree-shaking 沒有執(zhí)行。

--profile 模式構(gòu)建的 Web 應(yīng)用沒有被壓縮,但 Tree-shaking 執(zhí)行了。

--release 模式構(gòu)建的 Web 應(yīng)用被壓縮了,并且 Tree-shaking 執(zhí)行了

運(yùn)行命令

flutter run web --dart-define=FLUTTER_WEB_CANVASKIT_URL=./canvaskit/ --web-renderer=html

flutter run web --dart-define=FLUTTER_WEB_CANVASKIT_URL=./canvaskit/ --web-renderer=html --profile

打包命令

flutter build web --dart-define=FLUTTER_WEB_CANVASKIT_URL=./canvaskit/ --web-renderer=html --release

Flutter環(huán)境配置備忘(2022)

官方連接:

以上4行作用:

第一行,將flutter的相關(guān)命令添加到環(huán)境中

第二三行,設(shè)置使用flutter社區(qū)的倉庫,這樣在使用flutter get時(shí)就不會(huì)出錯(cuò)了

第四行,配置flutter的git倉庫,用于flutter的版本更新,默認(rèn)使用github上的倉庫速度太慢

將以上4行分別在環(huán)境變量中添加即可

注意:推薦使用本例中的社區(qū)的源,更新更及時(shí),更全面.以前使用 ,在構(gòu)建web是出現(xiàn)錯(cuò)誤,改成社區(qū)源后解決.

錯(cuò)誤:

文章題目:flutter社區(qū),flutter平臺
鏈接地址:http://muchs.cn/article0/phejoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、App開發(fā)、、Google、商城網(wǎng)站、網(wǎng)站建設(shè)

廣告

聲明:本網(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)站