【发布时间】:2017-10-30 22:04:12
【问题描述】:
我在https://docs.microsoft.com/en-us/aspnet/signalr/overview/getting-started/tutorial-getting-started-with-signalr 的帮助下建立了一个实时聊天
现在我遇到了无法使用 sessionStorage 保存用户名的问题,因此用户不必在每次进入网站上的聊天站点时都输入用户名。
这是我第一次使用 Web 应用程序和 sessionStorage。
希望有人可以帮助我:)
在线查看:http://chat.kibshede.dk/Chat.aspx
我有一堂课,里面有这个: 命名空间 SignalRChat { 公共类 ChatHub : 集线器 { 公共无效发送(字符串名称,字符串消息) { // 调用broadcastMessage 方法更新客户端。 Clients.All.broadcastMessage(name, message); } } }
和一个 Owin 类:
命名空间 SignalRChat { 公共类启动 { 公共无效配置(IAppBuilder 应用程序) { //任何连接或集线器接线和配置都应该在这里 app.MapSignalR(); } } }
<!--Reference the autogenerated SignalR hub script. -->
<script src="signalr/hubs"></script>
<!--Add script to update the page and send messages.-->
<script type="text/javascript">
$(function () {
// Declare a proxy to reference the hub.
var chat = $.connection.chatHub;
// Create a function that the hub can call to broadcast messages.
chat.client.broadcastMessage = function (name, message) {
// Html encode display name and message.
var encodedName = $('<div />').text(name).html();
var encodedMsg = $('<div />').text(message).html();
// Add the message to the page.
$('#discussion').append('<li><strong>' + encodedName
+ '</strong>: ' + encodedMsg + '</li>');
};
if (sessionStorage.getItem('UserName') != '#ContentPlaceHolder1_displayname') {
// Get the user name and store it to prepend to messages.
var UserName = prompt('Enter your name:', '').toString();
sessionStorage.setItem('UserName', UserName);
}
// Set initial focus to message input box.
$('#ContentPlaceHolder1_message').focus();
// Start the connection.
$.connection.hub.start().done(function () {
$('#sendmessage').click(function () {
// Call the Send method on the hub.
chat.server.send(sessionStorage.getItem('UserName'), $('#ContentPlaceHolder1_message').val());
// Clear text box and reset focus for next comment.
$('#ContentPlaceHolder1_message').val('').focus();
});
});
});
</script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js"></script>
<asp:Panel ID="Panel_ChatContainer" CssClass="container" runat="server">
<asp:Panel ID="Panel_ChatContainer_Chat" runat="server">
<asp:TextBox ID="message" runat="server"></asp:TextBox>
<input type="button" id="sendmessage" value="Send" />
<asp:Label ID="displayname" runat="server"></asp:Label>
<ul id="discussion"></ul>
</asp:Panel>
</asp:Panel>
【问题讨论】:
-
您的用户是否必须登录您的网站?如果是这样,您可以使用他们现有的会话 cookie。
-
我不使用登录:/
标签: jquery signalr sessionstorage