signal 聊天记录_实时查看车辆位置app

signal 聊天记录_实时查看车辆位置app开发工具与关键技术:js作者:GuanLW撰写时间:2022/3/18第一步:先在vs的NuGet包中下载安装Microsoft.AspNet.SignalR。第二步:右键项目->新建项,选择signalr集线器类,并写入代码,namespace与类名记得改成实际类名如下:usingMicrosoft.AspNet.SignalR;usingMicrosoft.AspNet.SignalR.Hubs;usingSystem;usingSystem.C

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

开发工具与关键技术: js

作者:GuanLW

撰写时间:2022/3/18

第一步:先在vs的NuGet包中下载安装Microsoft.AspNet.SignalR。安装完成后会多以下几个文件

signal 聊天记录_实时查看车辆位置app

 

第二步:右键项目->新建项,选择signalr集线器类,并写入代码,namespace与类名记得改成实际类名

如下:

using Microsoft.AspNet.SignalR;

using Microsoft.AspNet.SignalR.Hubs;

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;



namespace webLoans

{

    [HubName("msgHub")]//客户端调用,首字母要小写

    public class MsgHub : Hub

    {

        //在hub中编写的方法,都是要被客户端调用的方法

        [HubMethodName("sendMsg")]//客户端调用,首字母要小写

        public void SendMsg(string name, string txt)

        {

            //服务器主动调用客户端的方法,即客户端必须有getMsg方法

            Clients.All.getMsg(name, txt);

        }

    }

}

第三步:右键项目,新建普通类Startup.cs

如下:

using Microsoft.Owin;

using Owin;

using System;

using System.Threading.Tasks;



[assembly: OwinStartup(typeof(webLoans.Startup))]



namespace webLoans

{

    public class Startup

    {

        public void Configuration(IAppBuilder app)

        {

            // 有关如何配置应用程序的详细信息,请访问 https://go.microsoft.com/fwlink/?LinkID=316888

            app.MapSignalR();

        }

    }

}

这时可以先测试一下,运行项目,在网页中输入地址https://localhost:44340/signalr/hubs,注意填入实际端口号。网页显示部分内容如下:

signal 聊天记录_实时查看车辆位置app

第四步:编写html页面,代码如下:

@{

    Layout = null;

}



<!DOCTYPE html>



<html>

<head>

    <meta charset="utf-8" />

    <title></title>

    <script src="~/Scripts/jquery-1.6.4.js"></script>//实际的路径

    <script src="~/Scripts/jquery.signalR-2.4.3.js"></script>//实际的路径

    <script src="/signalr/hubs"></script>//动态生成的

    <script>

        //绑定登录按钮的事件

        $(function () {

            $("#btnLogin").click(function () {

                login();

            });



        });



        function login() {

            if ($("#txtName").val().length > 0)

                sessionStorage.setItem("user", $("#txtName").val());

            else {

                alert("登录失败");

                return;

            }

            $("#sendBtn").removeAttr("disabled");

            serverClient();

        }



        //服务器连接操作

        function serverClient() {

            //注册服务器连接

            var msgHub = $.connection.msgHub;

            //2.给客户端注册方法,被服务器调用的方法,

            //服务器主动调用给txt内容,客户端被动接收

            //接收到之后做什么

            msgHub.client.getMsg = function (name, txt) {

                //var txtTemplate = "<div><span>{
  
  {name}}</span>:<span>{
  
  {content}}</span></div> ";

                //var html = txtTemplate.replace('{
  
  {name}}', name).replace('{
  
  {content}}', txt);

                //$("#msgList").append(html);

                var txtHtml = '<li><strong>' + htmlEncode(name)

                    + '</strong>: ' + htmlEncode(txt) + '</li>';

                $("#msgList").append(txtHtml);

                //alert(txt);

            }



            //3.启动连接并绑定处理事件

            $.connection.hub.start().done(function () {



                $("#sendBtn").click(function () {

                    msgHub.server.sendMsg(sessionStorage.getItem("user"), $("#txtMsg").val());

                    $('#txtMsg').val('').focus();

                })

            }).fail(function () {



            });

        }



        // 将发来的信息转化为html标签以便添加到页面

        function htmlEncode(value) {

            var encodedValue = $('<div />').text(value).html();

            return encodedValue;

        }



    </script>

</head>

<body>

    <div id="msgList">



    </div>

    <input type="text" id="txtName" name="name" value="" />

    <button id="btnLogin">登录</button>

    <input type="text" id="txtMsg" name="name" value="" />

    <button id="sendBtn" disabled="disabled">发送消息</button>



</body>

</html>

注意头部引用的脚本,前两个是你的项目中的实际脚本文件,最后一个是在运行时动态生成的,实际使用时需要修改前两个。

第五步:打开两个网页进行测试,效果如下:

先输入登录名,然后发送信息即可。可以实时聊天。

signal 聊天记录_实时查看车辆位置app

这是我所学到的一些知识,在此分享给大家,希望可以帮助到你们。

以上就是我的分享,新手上道,请多多指教。如果有更好的方法或不懂得地方欢迎在评论区教导和提问喔!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/180104.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Codeforces Round #275 (Div. 2) C – Diverse Permutation (构造)[通俗易懂]

    Codeforces Round #275 (Div. 2) C – Diverse Permutation (构造)

    2022年1月23日
    58
  • 数据结构–最小生成树详解[通俗易懂]

    数据结构–最小生成树详解[通俗易懂]前言Awisemanchangeshismind,afoolnever.Name:WillamTime:2017/3/11、什么是最小生成树现在假设有一个很实际的问题:我们要在n个城市中建立一个通信网络,则连通这n个城市需要布置n-1一条通信线路,这个时候我们需要考虑如何在成本最低的情况下建立这个通信网?于是我们就可以引入连通图来解决我们遇到的问题,n个城市就是图上的n

    2025年7月2日
    3
  • Linux vi命令编辑文件「建议收藏」

    Linux vi命令编辑文件「建议收藏」进入vi编辑模式:vi文件名进入编辑:按i键编辑完按Esc退出编辑模式此时输入::wq保存后退出:wq!强制保存后退出:w保存但不退出:q不保存并退出:q!不保存并强制退出(比如报错时E212:Can’topenfileforwriting)…

    2022年9月22日
    2
  • ipad越狱有什么坏处吗?_平板越狱有什么好处

    ipad越狱有什么坏处吗?_平板越狱有什么好处1. iPad越狱是什么?iPad越狱有什么好处和坏处?不越狱又有啥缺点?越狱就是解除一些原版固件的限制。最大的好处是可以安装激活成功教程的软件和游戏,这些软件和游戏本来都是收费的。而且,有些功能很强大的软件,并不是花钱能在官方的App Store里能买到的(某些有米之人或许会说“我就不越狱,我都花钱买正版”,我只能客气地说他只知其一不知其二),比如SBSettings, OpenSSH, Lockd

    2025年11月19日
    4
  • 如何解决eclipse中的中文乱码问题[通俗易懂]

    eclipse中文乱码都是因为字符编码与默认的编码不符合导致的,有很多的方法可以解决,不需要安装任何插件就可以搞定。针对不同的情况,需要使用不同的方案,下面就针对一些案例讲解如何解决乱码问题。解决乱码问题的主要思路是设置正确合适的编码,如果不知道目标文件原本的编码,可以进行一定的尝试,通常尝试下GBK和UTF-8这两个编码即可。方法1设置单个文件的字符编码,解决单个文件的乱码问题有时候不小心cop…

    2022年4月3日
    44
  • vscode打个感叹号就出现html_为什么vscode输入叹号没反应

    vscode打个感叹号就出现html_为什么vscode输入叹号没反应关于Vscode自动更新后按!或按!+tab键不能自动生成html模板的问题和解决方法

    2022年8月22日
    93

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号