Windows Phone 十七、Socket
StreamSocket:Socket对象
StreamSocketListener:Socket监听对象,适用于服务端
服务端代码
<Grid x:Name="LayoutRoot"> <Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions> <!-- 标题面板 -->
<StackPanel Grid.Row="0" Margin="19,0,0,0">
<TextBlock Text="Socket Chat" Style="{ThemeResource TitleTextBlockStyle}" Margin="0,12,0,0"/>
<TextBlock Text="Server" Margin="0,-6.5,0,26.5" Style="{ThemeResource HeaderTextBlockStyle}" CharacterSpacing="{ThemeResource PivotHeaderItemCharacterSpacing}"/>
</StackPanel> <!--TODO: 应将内容放入以下网格-->
<Grid Grid.Row="1" x:Name="ContentRoot" Margin="19,9.5,19,0"> <Grid.RowDefinitions>
<RowDefinition/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions> <ListView x:Name="messageList" Grid.Row="0"/> <Grid Grid.Row="1">
<Grid.ColumnDefinitions>
<ColumnDefinition/>
<ColumnDefinition Width="auto"/>
</Grid.ColumnDefinitions> <TextBox x:Name="txtMessage" Grid.Column="0"/>
<Button
x:Name="btnSend"
Grid.Column="1"
Content="Send"
Click="btnSend_Click"/> </Grid>
</Grid> </Grid> <!--<Page.BottomAppBar>
<CommandBar>
<AppBarButton Icon="Send" Label="Send"/>
</CommandBar>
</Page.BottomAppBar>-->
protected async override void OnNavigatedTo(NavigationEventArgs e)
{
// 建立服务端监听
StreamSocketListener listener = new StreamSocketListener();
listener.ConnectionReceived += listener_ConnectionReceived;
try
{
await listener.BindServiceNameAsync("");
System.Diagnostics.Debug.WriteLine("服务端启动监听。。。");
}
catch (Exception ex)
{
var status = SocketError.GetStatus(ex.HResult);
System.Diagnostics.Debug.WriteLine("服务端监听失败。。。");
// 退出应用程序(NotRunning)
App.Current.Exit();
}
}
private List<StreamSocket> clients = new List<StreamSocket>();
async void listener_ConnectionReceived(StreamSocketListener sender, StreamSocketListenerConnectionReceivedEventArgs args)
{
var clientSocket = args.Socket;
clients.Add(clientSocket);
// 有一个Socket客户端连接上了
System.Diagnostics.Debug.WriteLine("有人来了。。。" + clientSocket.Information.RemoteAddress); DataReader reader = new DataReader(clientSocket.InputStream);
while (true)
{
// 不断接收客户端传过来的数据 #region 读取数据中数据头(数据的大小) var length = await reader.LoadAsync(sizeof(uint));
if (length != sizeof(uint))
{
// 客户端发送过来的数据不合法
// 客户端断开连接
System.Diagnostics.Debug.WriteLine(string.Format("客户端{0}断开连接", clientSocket.Information.RemoteAddress));
break;
}
// 客户端发送过来的数据是合法数据
// 读取真实数据长度
var messageLength = reader.ReadUInt32(); #endregion #region 根据数据大小创建缓冲区读取真实数据内容
// 根据真实长度创建内容数据缓冲
var messageLength2 = await reader.LoadAsync(messageLength); if (messageLength2 != messageLength)
{
// 客户端发送过来的数据不合法
// 客户端断开连接
System.Diagnostics.Debug.WriteLine(string.Format("客户端{0}断开连接", clientSocket.Information.RemoteAddress));
break;
} var message = reader.ReadString(messageLength2); #endregion
// 客户端发送过来的数据是合法数据
//var length = reader.ReadUInt32(); // 不再是UI线程执行以下代码
await this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
{
// 该方法会被主线程执行
messageList.Items.Add(string.Format("{1}说:{0}", message, clientSocket.Information.RemoteAddress));
});
//var result = await reader.LoadAsync();
}
} private async void btnSend_Click(object sender, RoutedEventArgs e)
{
foreach (var item in clients)
{
// 发送数据消息
// 先拿到当前建立完连接的Socket
var message = txtMessage.Text; DataWriter writer = new DataWriter(item.OutputStream);
// 先往发送流中写入数据大小
writer.WriteUInt32(writer.MeasureString(message));
// 再将数据写入发送流
writer.WriteString(message);
// 将数据提交到服务端
await writer.StoreAsync();
await this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
{
messageList.Items.Add(string.Format("我说:{0}", message));
});
}
}
客户端代码
<Grid x:Name="LayoutRoot"> <Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions> <!-- 标题面板 -->
<StackPanel Grid.Row="0" Margin="19,0,0,0">
<TextBlock Text="Socket Chat" Style="{ThemeResource TitleTextBlockStyle}" Margin="0,12,0,0"/>
<TextBlock Text="Client" Margin="0,-6.5,0,26.5" Style="{ThemeResource HeaderTextBlockStyle}" CharacterSpacing="{ThemeResource PivotHeaderItemCharacterSpacing}"/>
</StackPanel> <!--TODO: 应将内容放入以下网格-->
<Grid Grid.Row="1" x:Name="ContentRoot" Margin="19,9.5,19,0"> <Grid.RowDefinitions>
<RowDefinition/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions> <ListView x:Name="messageList" Grid.Row="0"/> <Grid Grid.Row="1">
<Grid.ColumnDefinitions>
<ColumnDefinition/>
<ColumnDefinition Width="auto"/>
</Grid.ColumnDefinitions> <TextBox x:Name="txtMessage" Grid.Column="0"/>
<Button
x:Name="btnSend"
Grid.Column="1"
Content="Send"
Click="btnSend_Click"/> </Grid>
</Grid> </Grid>
protected async override void OnNavigatedTo(NavigationEventArgs e)
{
string ip = "127.0.0.1";
int port = ;
HostName host = new HostName(ip);
// 建立Socket连接
socket = new StreamSocket();
try
{
await socket.ConnectAsync(host, port.ToString()); DataReader reader = new DataReader(socket.InputStream); while (true)
{
// 不断接收客户端传过来的数据 #region 读取数据中数据头(数据的大小) var length = await reader.LoadAsync(sizeof(uint));
if (length != sizeof(uint))
{
// 客户端发送过来的数据不合法
// 客户端断开连接
System.Diagnostics.Debug.WriteLine(string.Format("客户端{0}断开连接", socket.Information.RemoteAddress));
break;
}
// 客户端发送过来的数据是合法数据
// 读取真实数据长度
var messageLength = reader.ReadUInt32(); #endregion #region 根据数据大小创建缓冲区读取真实数据内容
// 根据真实长度创建内容数据缓冲
var messageLength2 = await reader.LoadAsync(messageLength); if (messageLength2 != messageLength)
{
// 客户端发送过来的数据不合法
// 客户端断开连接
System.Diagnostics.Debug.WriteLine(string.Format("客户端{0}断开连接", socket.Information.RemoteAddress));
break;
} var message = reader.ReadString(messageLength2); #endregion
// 客户端发送过来的数据是合法数据
//var length = reader.ReadUInt32(); // 不再是UI线程执行以下代码
await this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
{
// 该方法会被主线程执行
messageList.Items.Add(string.Format("{1}说:{0}", message, socket.Information.RemoteAddress));
});
//var result = await reader.LoadAsync();
}
}
catch (Exception ex)
{
//
var status = SocketError.GetStatus(ex.HResult);
System.Diagnostics.Debug.WriteLine("建立连接失败" + status);
App.Current.Exit();
}
} private async void btnSend_Click(object sender, RoutedEventArgs e)
{
// 发送数据消息
// 先拿到当前建立完连接的Socket
var message = txtMessage.Text; DataWriter writer = new DataWriter(socket.OutputStream);
// 先往发送流中写入数据大小
writer.WriteUInt32(writer.MeasureString(message));
// 再将数据写入发送流
writer.WriteString(message);
// 将数据提交到服务端
await writer.StoreAsync();
await this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
{
messageList.Items.Add(string.Format("我说:{0}", message));
});
}
Windows Phone 十七、Socket的更多相关文章
- windows下的socket网络编程
windows下的socket网络编程 windows下的socket网络编程 clinet.c 客户端 server.c 服务器端 UDP通信的实现 代码如下 已经很久没有在windows下编程了, ...
- windows下的socket网络编程(入门级)
windows下的socket网络编程 clinet.c 客户端 server.c 服务器端 UDP通信的实现 代码如下 已经很久没有在windows下编程了,这次因为需要做一个跨平台的网络程序,就先 ...
- winsock教程- windows下的socket编程(c语言实现)
winsock教程- windows下的socket编程(c语言实现) 使用winsock进行socket 编程 这是一个学习windows下socket编程(c语言)的快速指南.这是因为一下 ...
- Java进阶(四十七)Socket通信
Java进阶(四十七)Socket通信 今天讲解一个 Hello Word 级别的 Java Socket 通信的例子.具体通讯过程如下: 先启动Server端,进入一个死循环以便一直监听某端口是 ...
- 基于C++简单Windows API的socket编程(阻塞模式)
1. 概述:简单的基于Windows API的socket点对点聊天程序,为了方便初学者,本文代码均采用阻塞原理编写. 2. 代码样例 Server.cpp(服务端) #include <cst ...
- Windows下通过socket进行字符串和文件传输
今天在windows平台下,通过socket实现了简单的文件传输.通过实现这一功能,了解基本的windows网络编程和相关函数的使用方法. 在windows平台上进行网络编程,首先都需要调用函数WSA ...
- 一个简单的Windows下的socket程序
服务器端代码server.cpp: #include <stdio.h> #include <WinSock2.h> #pragma comment(lib,"ws2 ...
- Linux下TCP网络编程与基于Windows下C#socket编程间通信
一.linux下TCP网络编程基础,需要了解相关函数 Socket():用于套接字初始化. Bind():将 socket 与本机上的一个端口绑定,就可以在该端口监听服务请求. Listen():使s ...
- 成功使Linux服务端和Windows客户端建立socket通信
一.准备工作 1.一台装有虚拟机的Windows7操作系统,虚拟机中装的是CentOS6.5版本的Linux 2.Windows7已经装有java环境 二.编码 使用java编写socket通信的服务 ...
随机推荐
- 2016 Multi-University Training Contest 1 C.Game
Game Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submis ...
- [转]webpack进阶构建项目(一)
阅读目录 1.理解webpack加载器 2.html-webpack-plugin学习 3.压缩js与css 4.理解less-loader加载器的使用 5.理解babel-loader加载器 6.理 ...
- 数据库 sql server
1. if exists(select * from sys.objects where name='test') drop table test go create table test ( id ...
- java接口的嵌套
java接口 1.接口中定义的变量默认是public static final 型,且必须给其初值,所以实现类中不能重新定义,也不能改变其值 2.接口中的方法默认都是 public abstract ...
- 详解Js中文件读取机制
前言,文件读取是提高应用体验度的必须接口,应用场景中需求很频繁. Js处理文件读取,由于处于安全方面的考虑,在2000年以前,都是以“<input type="file"&g ...
- curl 传递用户session
$cmh = curl_multi_init(); $ch = curl_init(); curl_setopt($ch,CURLOPT_URL, $url); curl_setopt($ch, CU ...
- springMVC、https、GET调用别人提供的接口!!!
import org.apache.http.HttpEntity; import org.apache.http.HttpHost; import org.apache.http.HttpStatu ...
- NV SDK 10 (1) Clipmaps
Clipmaps sample: Abstract Clipmaps are a feature first implemented on SGI workstations that allow ma ...
- Unity透明材质Batch
NO Batch ? 游戏场景中存在大量例子的时候,DrallCall的压力很大,但是遍历一遍之后发现,为啥一样的粒子特效竟然没有合并,why?经过很多测试后发现,如果把透明材质的修改为非半透明的, ...
- [lua大坑]一个莫名其妙的lua执行时崩溃引出的堆栈大小问题
这是一个坑,天坑!如果不是我随手删除了一个本地变量,这个问题直到现在我应该也没有头绪. 首先,写了一个新的lua脚本,载入,执行.在执行的时候,出了这么一个莫名其妙的问题: EXC_BAD_ACCES ...