一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - .net core使用FastHttpApi構建web聊天室實例代碼

.net core使用FastHttpApi構建web聊天室實例代碼

2020-06-03 14:49smark ASP.NET教程

這篇文章主要給大家介紹了關于.net core使用FastHttpApi構建web聊天室的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

一般在dotnet core下構建使用web服務應用都使用asp.net core,但通過FastHttpApi組建也可以方便地構建web服務應用,在FastHttpApi功能的支持下構建多人聊天室是件非常簡單的事情,通過組件并不需要了解WebSocket知識即可簡單構建,以下講解一下通過FastHttpApi如何構建一個簡單的多人聊室。

創建項目

使用FastHttpApi構建一個WEB服務只需要創建一個普通ConsoleApp( 控制臺應用)

.net core使用FastHttpApi構建web聊天室實例代碼

創建項目后需要在Nuget中添加引用FastHttpApi

.net core使用FastHttpApi構建web聊天室實例代碼

只需要簡單地引用Beetlex.FastHttpApi即可構建基于Http和Websocket通訊應用。

創建邏輯

FastHttpApi對類和方法沒有太多規則約束,只需要在類上定義一個Controller標簽即可,接下來實現一個簡單的web聊天室

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
[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() };
 }
 
 //發送聊天信息
 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這些參數都是根據自己需要定義,如果不需要則不用在方法中定義它。接下來的事情就是要在頁面上調用它,大家知道在頁面調用http或websocket 需要定義一些代碼和指定相應的URL。但Beetlex.FastHttpApi提供一個非常便利的方式,通過安裝一個插件可以自動生成這些代碼插件安裝介紹(暫只支持vs2017).當插件安裝完成后只需要設置類文件的自定義工具即可

.net core使用FastHttpApi構建web聊天室實例代碼

插件會在當前類文下生成一個js文件,文件里把調用方法的URL和參數都定義完成

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
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才能使用,所以在頁面上必須把這個文件也引用上。接下來就是頁面腳本的使用

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
<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>

引用腳本后,直接通過方法調用即可,這種明確的方法調用比傳統的jquery.post有著調用的明確性和便利性,讓使用者不需要查看接口文檔即可以知道方法的調用參數。如果控制器定了XML幫助注釋,插件同樣也會把注釋生成到腳本中。

靜態文件存儲

組件通過固定的目錄來存放靜太資源,因此項目需要創建一個views目錄來存儲靜態資源,views目錄是web服務的根目錄。

.net core使用FastHttpApi構建web聊天室實例代碼

由于靜態文件默認情況是不會被編譯處理,所以我們需要把文件設置成編譯嵌入模式或復制到輸出目錄中。如果是復制到輸出目錄下,可以在項目生成事件中添加一段復制代碼。

.net core使用FastHttpApi構建web聊天室實例代碼

啟動服務

組件啟動服務很簡單,不過在啟動前需要注冊一下程序集,把控制器注冊到HTTP服務中。

?
1
2
3
4
5
6
7
8
9
static void Main(string[] args)
 {
 mApiServer = new BeetleX.FastHttpApi.HttpApiServer();
 mApiServer.Debug();//只有在Debug模式下生產,把靜態資源加載目錄指向項目的views目錄
 mApiServer.Register(typeof(Program).Assembly);//加載程序集中所有控制器信息和靜態資源信息
 mApiServer.Open();
 Console.Write(mApiServer.BaseServer);
 Console.Read();
 }

組件默認是不需要配置即可啟動HTTP服務,默認端口是9090.不過這些信息也是可以通過配置文件加載,只要程序目錄存在HttpConfig.json文件組件即會加載配置文件中的配置信息來運行服務。

服務配置文件

組件提供HttpConfig.json作為組件基礎服務項設置,這個文件不是必須,只要目錄下存在這個文件組件就會在初始化服務的時候加載這個文件的信息作為設置信息。以下大概的講解一下這個配置文件的配置項。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
{
"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

服務監聽的IP地址,暫只支持any或一個ip

Port

服務監聽的端口

SSL
是否開啟SSL功能,如果需要開啟必須指定證書和加載證書的密碼;啟動后即可對服務進行Https訪問

CertificateFile

證書文件

CertificatePassword

證書密碼

MaxBodyLength

Http體最大消息長度,默認是2M

OutputStackTrace

當服務錯誤的時候是否輸出詳細錯誤代碼信息

StaticResurceType

支持的靜態資源類型,如果這里沒有描述的文件類型訪問會返回403

DefaultPage

訪問根路徑的情況,默認尋找的文件

Manager

后臺管理員的用戶名

ManagerPWD

后臺管理員的密碼

WriteLog

是否打開日志寫文件

LogLevel

輸出日志級別,主要有以下幾種級別:Debug,None,Info,Warring,Error

這樣一個簡單多人web聊天室就完成,運行效果如下:

.net core使用FastHttpApi構建web聊天室實例代碼

在線演示

詳細代碼

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:https://www.cnblogs.com/smark/p/9817205.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 成人午夜视频一区二区国语 | 狠狠色伊人亚洲综合网站色 | 色综合天天网 | 欧美日本一道高清免费3区 欧美人做人爱a全程免费 | 百合文高h | xxoo做爰猛烈动态 | 日韩成人小视频 | 亚拍一区 | gangbang日本 | 欧美精品综合一区二区三区 | 亚洲福利视频在线观看 | 800精品国产导航 | 午夜国产在线观看 | 国产经典一区二区三区蜜芽 | 青青草在线观看 | 成人精品一区二区三区中文字幕 | 无遮掩60分钟从头啪到尾 | 亚洲福利一区二区三区 | 精品久久久久久影院免费 | 99热这里只精品99re66 | 99午夜高清在线视频在观看 | 国产福利片在线 | 欧洲男同直粗无套播放视频 | 午夜国产精品视频 | 国产成人在线播放视频 | 手机能看的黄色网站 | 久久精品国产亚洲AV麻豆欧美玲 | 好骚好紧 | 欧美精选欧美极品 | 40分钟在线观看免费 | 日本黄色网页 | 国产高清免费午夜在线视频 | 5x社区发源地最新地址 | 国产成人精品日本亚洲网站 | 国产精品亚洲片在线va | blacked在线播放| 婷婷伊人综合亚洲综合网 | 给我免费观看的视频在线播放 | 亚洲天堂激情 | 日本激情小说 | 国产福利不卡视频在免费 |