.net core使用FastHttpApi構(gòu)建web聊天室實例代碼
前言
一般在dotnet core下構(gòu)建使用web服務(wù)應用都使用asp.net core,但通過FastHttpApi組建也可以方便地構(gòu)建web服務(wù)應用,在FastHttpApi功能的支持下構(gòu)建多人聊天室是件非常簡單的事情,通過組件并不需要了解WebSocket知識即可簡單構(gòu)建,以下講解一下通過FastHttpApi如何構(gòu)建一個簡單的多人聊室。
創(chuàng)建項目
使用FastHttpApi構(gòu)建一個WEB服務(wù)只需要創(chuàng)建一個普通ConsoleApp( 控制臺應用)
創(chuàng)建項目后需要在Nuget中添加引用FastHttpApi
只需要簡單地引用Beetlex.FastHttpApi即可構(gòu)建基于Http和Websocket通訊應用。
創(chuàng)建邏輯
FastHttpApi對類和方法沒有太多規(guī)則約束,只需要在類上定義一個Controller標簽即可,接下來實現(xiàn)一個簡單的web聊天室
[Controller] public class Controller { //用戶登陸 public bool Login(string nickName, IHttpContext context) { context.Session.Name = nickName; ActionResult result = new ActionResult(); result.Data = new { name = nickName, message = "login", type = "login", time = DateTime.Now.ToString("T") }; context.SendToWebSocket(result); return true; } //獲取在線用戶 public object ListOnlines(IHttpContext context) { return from r in context.Server.GetWebSockets() where r.Session.Name != null select new { r.Session.Name, IP = r.Session.RemoteEndPoint.ToString() }; } //發(fā)送聊天信息 public bool Talk(string nickName, string message, IHttpContext context) { ActionResult result = new ActionResult(); result.Data = new { name = nickName, message, type = "talk", time = DateTime.Now.ToString("T") }; context.SendToWebSocket(result); return true; } }
以上代碼分別定義登陸,獲取在線用戶和alk方法,方法的定義同樣也是沒有約束性,對于IHttpContext這些參數(shù)都是根據(jù)自己需要定義,如果不需要則不用在方法中定義它。接下來的事情就是要在頁面上調(diào)用它,大家知道在頁面調(diào)用http或websocket 需要定義一些代碼和指定相應的URL。但Beetlex.FastHttpApi提供一個非常便利的方式,通過安裝一個插件可以自動生成這些代碼插件安裝介紹(暫只支持vs2017).當插件安裝完成后只需要設(shè)置類文件的自定義工具即可
插件會在當前類文下生成一個js文件,文件里把調(diào)用方法的URL和參數(shù)都定義完成
var $Login$url='/login'; function $Login(nickName,useHttp) { return api($Login$url,{nickName:nickName},useHttp).sync(); } function $Login$async(nickName,useHttp) { return api($Login$url,{nickName:nickName},useHttp); } var $ListOnlines$url='/listonlines'; function $ListOnlines(useHttp) { return api($ListOnlines$url,{},useHttp).sync(); } function $ListOnlines$async(useHttp) { return api($ListOnlines$url,{},useHttp); } var $Talk$url='/talk'; function $Talk(nickName,message,useHttp) { return api($Talk$url,{nickName:nickName,message:message},useHttp).sync(); } function $Talk$async(nickName,message,useHttp) { return api($Talk$url,{nickName:nickName,message:message},useHttp); }
這個文件非常簡單,主要包括URL,同步方法和異步方法。這個js文件需要依賴FastHttpApi.js才能使用,所以在頁面上必須把這個文件也引用上。接下來就是頁面腳本的使用
<script> function receive(result) { if (result.Data.type == 'login' || result.Data.type == 'quit') { $ListOnlines$async().execute(function (result) { listUserControl.Data = result.Data; }); } messages.push(result.Data); var objDiv = document.getElementById("lstTalk"); objDiv.scrollTop = objDiv.scrollHeight; } async function sendMessage() { var msg = $('#talkMsg').val(); if (!msg) { alert("enter message"); return; } var result = await $Talk(nickName, msg); if (result.Code != 200) alert(result.Error); else $('#talkMsg').val(''); } async function login() { nickName = $('#userName').val(); if (!nickName) { alert("enter you name!") return; } var result = await $Login(nickName); if (result.Code == 200) { $('#loginBar').hide(); $('#talkBar').show(); } else { alert(result.Error); } } </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)文件默認情況是不會被編譯處理,所以我們需要把文件設(shè)置成編譯嵌入模式或復制到輸出目錄中。如果是復制到輸出目錄下,可以在項目生成事件中添加一段復制代碼。
啟動服務(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(); }
組件默認是不需要配置即可啟動HTTP服務(wù),默認端口是9090.不過這些信息也是可以通過配置文件加載,只要程序目錄存在HttpConfig.json文件組件即會加載配置文件中的配置信息來運行服務(wù)。
服務(wù)配置文件
組件提供HttpConfig.json作為組件基礎(chǔ)服務(wù)項設(shè)置,這個文件不是必須,只要目錄下存在這個文件組件就會在初始化服務(wù)的時候加載這個文件的信息作為設(shè)置信息。以下大概的講解一下這個配置文件的配置項。
{ "HttpConfig": { "Host": "", "Port": 9090, "SSL": false, "CertificateFile": "", "CertificatePassword": "", "MaxBodyLength": 2097152, "OutputStackTrace": false, "StaticResurceType": "xml;svg;woff;woff2;jpg;jpeg;gif;png;js;html;htm;css;txt;ico;zip;rar", "DefaultPage": "index.html;index.htm", "NotLoadFolder": "\\Files;\\Images;\\Data", "Manager": "admin", "ManagerPWD": "123456", "NoGzipFiles": "jpg;jpeg;png;gif;png;ico;zip;rar;bmp", "CacheFiles": "html;htm;js;css", "BufferSize": 1024, "WebSocketMaxRPS": 1000, "WriteLog": true, "LogToConsole": true, "LogLevel": "Warring", "FileManager": false } }
Host
服務(wù)監(jiān)聽的IP地址,暫只支持any或一個ip
Port
服務(wù)監(jiān)聽的端口
SSL
是否開啟SSL功能,如果需要開啟必須指定證書和加載證書的密碼;啟動后即可對服務(wù)進行Https訪問
CertificateFile
證書文件
CertificatePassword
證書密碼
MaxBodyLength
Http體最大消息長度,默認是2M
OutputStackTrace
當服務(wù)錯誤的時候是否輸出詳細錯誤代碼信息
StaticResurceType
支持的靜態(tài)資源類型,如果這里沒有描述的文件類型訪問會返回403
DefaultPage
訪問根路徑的情況,默認尋找的文件
Manager
后臺管理員的用戶名
ManagerPWD
后臺管理員的密碼
WriteLog
是否打開日志寫文件
LogLevel
輸出日志級別,主要有以下幾種級別:Debug,None,Info,Warring,Error
這樣一個簡單多人web聊天室就完成,運行效果如下:
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
asp.net fileupload控件上傳文件與多文件上傳
這篇文章主要介紹了asp.net fileupload控件上傳文件的方法,fileupload控件多文件上傳,以及fileupload上傳時實現(xiàn)文件驗證的方法,需要的朋友可以參考下2014-11-11理解ASP.NET?Core?錯誤處理機制(Handle?Errors)
這篇文章主要介紹了理解ASP.NET?Core?錯誤處理(Handle?Errors)?,在這里需要注意的是,與“異常處理”有關(guān)的中間件,一定要盡早添加,這樣,它可以最大限度的捕獲后續(xù)中間件拋出的未處理異常。感興趣的朋友跟隨小編一起看看吧2021-11-11在.NET中掃描局域網(wǎng)服務(wù)的實現(xiàn)方法
下面小編就為大家分享一篇在.NET中掃描局域網(wǎng)服務(wù)的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01