SignalR是一个实时通信库,可以在Web应用程序中实现实时通信功能。要实现文件同步与共享,可以使用SignalR来实现实时更新和传输文件。
以下是一个简单的示例,演示如何使用SignalR实现文件同步与共享:
public class FileHub : Hub
{
public async Task UploadFile(byte[] fileData, string fileName)
{
// 保存文件到服务器
// 广播文件给其他连接的客户端
await Clients.All.SendAsync("FileUploaded", fileData, fileName);
}
public async Task DownloadFile(string fileName)
{
// 从服务器获取文件数据
// 发送文件给连接的客户端
byte[] fileData = // 从服务器获取文件数据的逻辑
await Clients.Caller.SendAsync("FileDownloaded", fileData, fileName);
}
}
public void ConfigureServices(IServiceCollection services)
{
...
services.AddSignalR();
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
...
app.UseSignalR(routes =>
{
routes.MapHub<FileHub>("/filehub");
});
}
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/signalr/3.1.11/signalr.min.js"></script>
<script>
var connection = new signalR.HubConnectionBuilder().withUrl("/filehub").build();
connection.on("FileUploaded", function (fileData, fileName) {
// 处理接收到的文件数据
});
connection.on("FileDownloaded", function (fileData, fileName) {
// 处理接收到的文件数据
});
connection.start().then(function () {
// 文件上传功能
$("#uploadButton").click(function () {
var fileInput = document.getElementById("fileInput");
var file = fileInput.files[0];
var reader = new FileReader();
reader.onload = function (e) {
var fileData = e.target.result;
connection.invoke("UploadFile", fileData, file.name);
};
reader.readAsArrayBuffer(file);
});
// 文件下载功能
$("#downloadButton").click(function () {
var fileName = "example.txt";
connection.invoke("DownloadFile", fileName);
});
}).catch(function (err) {
console.error(err.toString());
});
</script>
通过以上步骤,就可以实现使用SignalR实时同步和共享文件的功能。当一个客户端上传文件时,其他连接的客户端会收到文件数据,并可以实时下载文件。