使用FastHttpApi构建多人Web聊天室
為什么80%的碼農(nóng)都做不了架構(gòu)師?>>> ??
一般在dotnet core下構(gòu)建使用web服務(wù)應(yīng)用都使用asp.net core,但通過FastHttpApi組建也可以方便地構(gòu)建web服務(wù)應(yīng)用,在FastHttpApi功能的支持下構(gòu)建多人聊天室是件非常簡單的事情,通過組件并不需要了解WebSocket知識即可簡單構(gòu)建,以下講解一下通過FastHttpApi如何構(gòu)建一個簡單的多人聊室。
創(chuàng)建項目
使用FastHttpApi構(gòu)建一個WEB服務(wù)只需要創(chuàng)建一個普通ConsoleApp( 控制臺應(yīng)用)
創(chuàng)建項目后需要在Nuget中添加引用FastHttpApi
只需要簡單地引用Beetlex.FastHttpApi即可構(gòu)建基于Http和Websocket通訊應(yīng)用。
創(chuàng)建邏輯
FastHttpApi對類和方法沒有太多規(guī)則約束,只需要在類上定義一個Controller標(biāo)簽即可,接下來實現(xiàn)一個簡單的發(fā)送消息方法
[Controller]public class Controller{public bool Talk(string name, string messge, IHttpContext context){ActionResult result = new ActionResult();result.Data = new { name, messge };context.SendToWebSocket(result);return true;}}以上代碼定義一個Talk方法,方法把發(fā)信息的昵稱和消息發(fā)送當(dāng)前服務(wù)上下文中的所有websocket連接。直接下來的事情就是要在頁面上調(diào)用它,大家知道在頁面調(diào)用http或websocket 需要定義一些代碼和指定相應(yīng)的URL。但Beetlex.FastHttpApi提供一個非常便利的方式,通過安裝一個插件可以自動生成這些代碼插件安裝介紹(暫只支持vs2017).當(dāng)插件安裝完成后只需要設(shè)置類文件的自定義工具即可
插件會在當(dāng)前類文下生成一個js文件,文件里把調(diào)用方法的URL和參數(shù)都定義完成
var $Talk$url='/talk'; function $Talk(name,messge,useHttp) {return api($Talk$url,{name:name,messge:messge},useHttp).sync(); } function $Talk$async(name,messge,useHttp) {return api($Talk$url,{name:name,messge:messge},useHttp); }這個文件非常簡單,主要包括URL,同步方法和異步方法。這個js文件需要依賴FastHttpApi.js才能使用,所以在頁面上必須把這個文件也引用上。接下來就是頁面腳本的使用
<script>function onreceive(result) {$('<p><span class="label label-default">' + result.Data.name+'</span>:' + result.Data.messge + '</p>').appendTo('#lstTalk')}async function sendMessage() {var name = $('#name').val();var message = $('#msg').val();if (!name) {alert("enter name!");return;}if (!message) {alert('enter messgae');return;}var result = await $Talk(name, message);if (result.Code != 200) {alert(result.Error);}else$('#msg').val('');}$(document).ready(function () {api_receive(onreceive);//綁定消息接收事件});</script>引用腳本后,直接通過方法調(diào)用即可,這種明確的方法調(diào)用比傳統(tǒng)的jquery.post有著調(diào)用的明確性和便利性,讓使用者不需要查看接口文檔即可以知道方法的調(diào)用參數(shù)。如果控制器定了XML幫助注釋,插件同樣也會把注釋生成到腳本中。
靜態(tài)文件存儲
組件通過固定的目錄來存放靜太資源,因此項目需要創(chuàng)建一個views目錄來存儲靜態(tài)資源,views目錄是web服務(wù)的根目錄。
由于靜態(tài)文件默認(rèn)情況是不會被編譯處理,所以我們需要把文件設(shè)置成編譯嵌入模式或復(fù)制到輸出目錄中。如果是復(fù)制到輸出目錄下,可以在項目生成事件中添加一段復(fù)制代碼。
啟動服務(wù)
組件啟動服務(wù)很簡單,不過在啟動前需要注冊一下程序集,把控制器注冊到HTTP服務(wù)中。
static void Main(string[] args){mApiServer = new BeetleX.FastHttpApi.HttpApiServer();mApiServer.Debug();//只有在Debug模式下生產(chǎn),把靜態(tài)資源加載目錄指向項目的views目錄mApiServer.Register(typeof(Program).Assembly);//加載程序集中所有控制器信息和靜態(tài)資源信息mApiServer.Open();Console.Write(mApiServer.BaseServer);Console.Read();}組件默認(rèn)是不需要配置即可啟動HTTP服務(wù),默認(rèn)端口是9090.不過這些信息也是可以通過配置文件加載,只要程序目錄存在HttpConfig.json文件組件即會加載配置文件中的配置信息來運行服務(wù)。配置文件詳解
這樣一個簡單多人web聊天室就完成,運行效果如下:
詳細(xì)代碼
轉(zhuǎn)載于:https://my.oschina.net/ikende/blog/2249071
與50位技術(shù)專家面對面20年技術(shù)見證,附贈技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的使用FastHttpApi构建多人Web聊天室的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【从前端到全栈】- koa快速入门指南
- 下一篇: 如何使用Java代码给图片增加倒影效果