最新资讯

  • 页面中如何实现超大附件上传到服务器指定文件夹?

页面中如何实现超大附件上传到服务器指定文件夹?

2026-01-30 17:39:17 栏目:最新资讯 5 阅读

企业级大文件安全传输解决方案

作为广东软件公司的项目负责人,针对贵司的大文件传输需求,我提供以下专业解决方案。本方案基于.NET技术栈,完全满足高稳定性、高安全性要求,支持100G级别文件传输,并具备完善的浏览器兼容性和信创国产化适配能力。

技术架构设计

系统架构图

[客户端] ←HTTPS(SM4/AES)→ [Web层] ←→ [服务层] ←→ [存储层]
       ↑                    ↑               ↑
       |                    |               |
[管理控制台] ←→ [监控中心] ←→ [审计日志] ←→ [密钥管理]

前端关键代码实现

文件上传组件 (FileTransfer.vue)




import { encryptChunk } from '@/utils/crypto';
import { generateFileId } from '@/utils/file';
import { getResumeInfo, saveResumeInfo } from '@/api/resume';

export default {
  name: 'FileTransfer',
  data() {
    return {
      isFolderMode: false,
      transferQueue: [],
      encryptionAlgorithm: 'SM4',
      encryptionKey: '',
      activeTransfers: new Map()
    };
  },
  mounted() {
    this.loadEncryptionKey();
    this.loadPendingTransfers();
  },
  methods: {
    // 触发文件选择
    triggerFileSelect() {
      this.$refs.fileInput.value = '';
      this.$refs.fileInput.click();
    },
    
    // 处理文件选择
    async handleFileSelect(event) {
      const files = Array.from(event.target.files);
      
      for (const file of files) {
        const fileItem = {
          id: generateFileId(file),
          name: file.name,
          path: file.webkitRelativePath || '',
          size: file.size,
          progress: 0,
          status: 'pending',
          file: file
        };
        
        this.transferQueue.push(fileItem);
        
        // 检查是否有断点记录
        const resumeInfo = await getResumeInfo(fileItem.id);
        if (resumeInfo) {
          fileItem.resumeChunk = resumeInfo.chunkIndex;
        }
      }
      
      this.startTransfer();
    },
    
    // 开始传输
    startTransfer() {
      this.transferQueue
        .filter(item => item.status === 'pending')
        .forEach(item => {
          item.status = 'uploading';
          this.uploadFile(item);
        });
    },
    
    // 文件上传核心方法
    async uploadFile(fileItem) {
      const CHUNK_SIZE = 5 * 1024 * 1024; // 5MB分块
      const totalChunks = Math.ceil(fileItem.size / CHUNK_SIZE);
      const startChunk = fileItem.resumeChunk || 0;
      
      // 创建AbortController用于取消上传
      const controller = new AbortController();
      this.activeTransfers.set(fileItem.id, controller);
      
      try {
        for (let chunkIndex = startChunk; chunkIndex < totalChunks; chunkIndex++) {
          if (fileItem.status === 'paused') break;
          
          const start = chunkIndex * CHUNK_SIZE;
          const end = Math.min(start + CHUNK_SIZE, fileItem.size);
          const chunk = fileItem.file.slice(start, end);
          
          // 加密分块
          const encryptedChunk = await encryptChunk(
            chunk, 
            this.encryptionAlgorithm, 
            this.encryptionKey
          );
          
          const formData = new FormData();
          formData.append('fileId', fileItem.id);
          formData.append('chunkIndex', chunkIndex);
          formData.append('totalChunks', totalChunks);
          formData.append('fileName', fileItem.name);
          formData.append('filePath', fileItem.path);
          formData.append('fileSize', fileItem.size);
          formData.append('chunkData', new Blob([encryptedChunk]));
          formData.append('encryption', this.encryptionAlgorithm);
          
          await this.$http.post('/api/upload/chunk', formData, {
            signal: controller.signal,
            onUploadProgress: (progressEvent) => {
              const loaded = chunkIndex * CHUNK_SIZE + progressEvent.loaded;
              fileItem.progress = Math.round((loaded / fileItem.size) * 100);
              this.$forceUpdate();
            }
          });
          
          // 保存断点
          await saveResumeInfo({
            fileId: fileItem.id,
            chunkIndex: chunkIndex + 1,
            totalChunks: totalChunks
          });
        }
        
        if (fileItem.status !== 'paused') {
          // 合并文件
          await this.$http.post('/api/upload/merge', {
            fileId: fileItem.id,
            fileName: fileItem.name,
            filePath: fileItem.path,
            totalChunks: totalChunks,
            encryption: this.encryptionAlgorithm
          });
          
          fileItem.status = 'completed';
          this.clearResumeData(fileItem.id);
        }
      } catch (error) {
        if (error.name !== 'AbortError') {
          fileItem.status = 'error';
          console.error('上传失败:', error);
        }
      } finally {
        this.activeTransfers.delete(fileItem.id);
      }
    },
    
    // 暂停传输
    pauseTransfer(item) {
      item.status = 'paused';
    },
    
    // 继续传输
    resumeTransfer(item) {
      item.status = 'uploading';
      this.uploadFile(item);
    },
    
    // 取消传输
    cancelTransfer(item) {
      const controller = this.activeTransfers.get(item.id);
      if (controller) {
        controller.abort();
      }
      
      this.$http.post('/api/upload/cancel', { fileId: item.id });
      this.transferQueue = this.transferQueue.filter(i => i.id !== item.id);
      this.clearResumeData(item.id);
    },
    
    // 加载未完成的传输
    loadPendingTransfers() {
      this.$http.get('/api/upload/pending').then(response => {
        this.transferQueue = response.data.map(item => ({
          ...item,
          status: 'paused'
        }));
      });
    },
    
    // 保存加密密钥
    saveEncryptionKey() {
      localStorage.setItem('encryptionKey', this.encryptionKey);
    },
    
    // 加载加密密钥
    loadEncryptionKey() {
      this.encryptionKey = localStorage.getItem('encryptionKey') || '';
    },
    
    // 清除断点数据
    clearResumeData(fileId) {
      localStorage.removeItem(`resume_${fileId}`);
    },
    
    // 格式化文件大小
    formatSize(bytes) {
      if (bytes === 0) return '0 B';
      const k = 1024;
      const sizes = ['B', 'KB', 'MB', 'GB', 'TB'];
      const i = Math.floor(Math.log(bytes) / Math.log(k));
      return parseFloat((bytes / Math.pow(k, i)).toFixed(2)) + ' ' + sizes[i];
    }
  }
};



/* 样式同上,此处省略 */

后端关键代码实现 (.NET)

文件上传控制器 (FileUploadController.cs)

[Route("api/upload")]
[ApiController]
public class FileUploadController : ControllerBase
{
    private readonly IFileStorageService _storageService;
    private readonly IResumeService _resumeService;
    private readonly ILogger _logger;

    public FileUploadController(
        IFileStorageService storageService,
        IResumeService resumeService,
        ILogger logger)
    {
        _storageService = storageService;
        _resumeService = resumeService;
        _logger = logger;
    }

    [HttpPost("chunk")]
    public async Task UploadChunk(
        [FromForm] string fileId,
        [FromForm] int chunkIndex,
        [FromForm] int totalChunks,
        [FromForm] string fileName,
        [FromForm] string filePath,
        [FromForm] long fileSize,
        [FromForm] string encryption,
        [FromForm] IFormFile chunkData)
    {
        try
        {
            // 读取分块数据
            byte[] chunkBytes;
            using (var memoryStream = new MemoryStream())
            {
                await chunkData.CopyToAsync(memoryStream);
                chunkBytes = memoryStream.ToArray();
            }

            // 解密数据
            byte[] decryptedData = DecryptChunk(chunkBytes, encryption);

            // 存储分块
            await _storageService.SaveChunkAsync(fileId, chunkIndex, decryptedData);

            // 保存断点信息
            await _resumeService.SaveResumeInfoAsync(fileId, chunkIndex + 1, totalChunks);

            return Ok();
        }
        catch (Exception ex)
        {
            _logger.LogError(ex, "文件分块上传失败");
            return StatusCode(500, new { error = ex.Message });
        }
    }

    [HttpPost("merge")]
    public async Task MergeChunks([FromBody] MergeRequest request)
    {
        try
        {
            // 验证文件完整性
            if (!await _storageService.ValidateFileChunksAsync(request.FileId, request.TotalChunks))
            {
                return BadRequest("文件分块不完整");
            }

            // 合并文件
            string storedPath = await _storageService.MergeChunksAsync(
                request.FileId,
                request.FileName,
                request.FilePath,
                request.TotalChunks,
                request.Encryption
            );

            // 清理断点信息
            await _resumeService.ClearResumeInfoAsync(request.FileId);

            return Ok(new { filePath = storedPath });
        }
        catch (Exception ex)
        {
            _logger.LogError(ex, "文件合并失败");
            return StatusCode(500, new { error = ex.Message });
        }
    }

    [HttpPost("cancel")]
    public async Task CancelUpload([FromBody] CancelRequest request)
    {
        try
        {
            // 删除已上传的分块
            await _storageService.DeleteChunksAsync(request.FileId);

            // 清理断点信息
            await _resumeService.ClearResumeInfoAsync(request.FileId);

            return Ok();
        }
        catch (Exception ex)
        {
            _logger.LogError(ex, "取消上传失败");
            return StatusCode(500, new { error = ex.Message });
        }
    }

    [HttpGet("pending")]
    public async Task GetPendingTransfers()
    {
        try
        {
            var pendingFiles = await _resumeService.GetPendingTransfersAsync();
            return Ok(pendingFiles);
        }
        catch (Exception ex)
        {
            _logger.LogError(ex, "获取待处理传输失败");
            return StatusCode(500, new { error = ex.Message });
        }
    }

    private byte[] DecryptChunk(byte[] encryptedData, string algorithm)
    {
        if (algorithm == "SM4")
        {
            return SM4Util.Decrypt(encryptedData);
        }
        else
        {
            return AESUtil.Decrypt(encryptedData);
        }
    }
}

public class MergeRequest
{
    public string FileId { get; set; }
    public string FileName { get; set; }
    public string FilePath { get; set; }
    public int TotalChunks { get; set; }
    public string Encryption { get; set; }
}

public class CancelRequest
{
    public string FileId { get; set; }
}

文件存储服务 (FileStorageService.cs)

public interface IFileStorageService
{
    Task SaveChunkAsync(string fileId, int chunkIndex, byte[] chunkData);
    Task MergeChunksAsync(string fileId, string fileName, string filePath, int totalChunks, string encryption);
    Task ValidateFileChunksAsync(string fileId, int totalChunks);
    Task DeleteChunksAsync(string fileId);
    Task DownloadFileAsync(string filePath);
    Task GetFileInfoAsync(string filePath);
}

public class FileStorageService : IFileStorageService
{
    private readonly string _localStoragePath;
    private readonly IOssClient _ossClient;
    private readonly ILogger _logger;

    public FileStorageService(
        IConfiguration configuration,
        IOssClient ossClient,
        ILogger logger)
    {
        _localStoragePath = configuration["Storage:Local:Path"];
        _ossClient = ossClient;
        _logger = logger;
    }

    public async Task SaveChunkAsync(string fileId, int chunkIndex, byte[] chunkData)
    {
        string chunkPath = GetChunkPath(fileId, chunkIndex);
        Directory.CreateDirectory(Path.GetDirectoryName(chunkPath));
        
        await System.IO.File.WriteAllBytesAsync(chunkPath, chunkData);
    }

    public async Task MergeChunksAsync(
        string fileId, 
        string fileName, 
        string filePath, 
        int totalChunks,
        string encryption)
    {
        string storedPath = GetStoredPath(fileName, filePath);
        Directory.CreateDirectory(Path.GetDirectoryName(storedPath));
        
        using (var outputStream = new FileStream(storedPath, FileMode.Create, FileAccess.Write))
        {
            for (int i = 0; i < totalChunks; i++)
            {
                string chunkPath = GetChunkPath(fileId, i);
                byte[] chunkData = await System.IO.File.ReadAllBytesAsync(chunkPath);
                
                await outputStream.WriteAsync(chunkData, 0, chunkData.Length);
                
                // 删除临时分块
                System.IO.File.Delete(chunkPath);
            }
        }
        
        // 上传到云存储
        if (_ossClient != null)
        {
            await UploadToOssAsync(storedPath);
        }
        
        return storedPath;
    }

    public async Task ValidateFileChunksAsync(string fileId, int totalChunks)
    {
        for (int i = 0; i < totalChunks; i++)
        {
            string chunkPath = GetChunkPath(fileId, i);
            if (!System.IO.File.Exists(chunkPath))
            {
                return false;
            }
        }
        return true;
    }

    public async Task DeleteChunksAsync(string fileId)
    {
        string chunkDir = GetChunkDir(fileId);
        if (Directory.Exists(chunkDir))
        {
            Directory.Delete(chunkDir, true);
        }
    }

    public async Task DownloadFileAsync(string filePath)
    {
        if (_ossClient != null && filePath.StartsWith("oss://"))
        {
            // 从OSS下载
            return await _ossClient.GetObjectStreamAsync(filePath.Substring(6));
        }
        else
        {
            // 从本地下载
            return new FileStream(filePath, FileMode.Open, FileAccess.Read);
        }
    }

    public async Task GetFileInfoAsync(string filePath)
    {
        var info = new FileInfo();
        
        if (_ossClient != null && filePath.StartsWith("oss://"))
        {
            // 从OSS获取文件信息
            var metadata = await _ossClient.GetObjectMetadataAsync(filePath.Substring(6));
            info.Size = metadata.ContentLength;
            info.LastModified = metadata.LastModified.ToUnixTimeMilliseconds();
        }
        else
        {
            // 从本地获取文件信息
            var fileInfo = new System.IO.FileInfo(filePath);
            info.Size = fileInfo.Length;
            info.LastModified = fileInfo.LastWriteTimeUtc.Ticks;
        }
        
        return info;
    }

    private string GetChunkDir(string fileId)
    {
        return Path.Combine(_localStoragePath, "temp", fileId);
    }

    private string GetChunkPath(string fileId, int chunkIndex)
    {
        return Path.Combine(GetChunkDir(fileId), $"{chunkIndex}.chunk");
    }

    private string GetStoredPath(string fileName, string relativePath)
    {
        if (!string.IsNullOrEmpty(relativePath))
        {
            return Path.Combine(_localStoragePath, "files", relativePath, fileName);
        }
        return Path.Combine(_localStoragePath, "files", fileName);
    }

    private async Task UploadToOssAsync(string filePath)
    {
        string objectKey = "files/" + Path.GetFileName(filePath);
        await _ossClient.PutObjectAsync("bucket-name", objectKey, filePath);
    }
}

public class FileInfo
{
    public long Size { get; set; }
    public long LastModified { get; set; }
}

断点续传服务 (ResumeService.cs)

public interface IResumeService
{
    Task SaveResumeInfoAsync(string fileId, int chunkIndex, int totalChunks);
    Task GetResumeInfoAsync(string fileId);
    Task ClearResumeInfoAsync(string fileId);
    Task> GetPendingTransfersAsync();
}

public class ResumeService : IResumeService
{
    private readonly IDistributedCache _cache;
    private readonly ILogger _logger;

    public ResumeService(
        IDistributedCache cache,
        ILogger logger)
    {
        _cache = cache;
        _logger = logger;
    }

    public async Task SaveResumeInfoAsync(string fileId, int chunkIndex, int totalChunks)
    {
        var info = new ResumeInfo
        {
            FileId = fileId,
            ChunkIndex = chunkIndex,
            TotalChunks = totalChunks
        };
        
        string cacheKey = GetResumeKey(fileId);
        string json = JsonSerializer.Serialize(info);
        
        await _cache.SetStringAsync(
            cacheKey, 
            json,
            new DistributedCacheEntryOptions
            {
                AbsoluteExpirationRelativeToNow = TimeSpan.FromDays(7)
            });
    }

    public async Task GetResumeInfoAsync(string fileId)
    {
        string cacheKey = GetResumeKey(fileId);
        string json = await _cache.GetStringAsync(cacheKey);
        
        if (json != null)
        {
            return JsonSerializer.Deserialize(json);
        }
        
        return null;
    }

    public async Task ClearResumeInfoAsync(string fileId)
    {
        string cacheKey = GetResumeKey(fileId);
        await _cache.RemoveAsync(cacheKey);
    }

    public async Task> GetPendingTransfersAsync()
    {
        // 实际实现中需要从数据库或缓存中查询待处理传输
        return new List();
    }

    private string GetResumeKey(string fileId)
    {
        return $"file:resume:{fileId}";
    }
}

public class ResumeInfo
{
    public string FileId { get; set; }
    public int ChunkIndex { get; set; }
    public int TotalChunks { get; set; }
}

public class PendingTransfer
{
    public string FileId { get; set; }
    public string FileName { get; set; }
    public string FilePath { get; set; }
    public long FileSize { get; set; }
    public int Progress { get; set; }
}

数据库设计

文件传输记录表

CREATE TABLE [dbo].[FileTransferRecords](
    64 NOT NULL,
    255 NOT NULL,
    512 NULL,
    [FileSize] [bigint] NOT NULL,
    512 NOT NULL,
    20 NULL DEFAULT 'SM4',
    20 NULL DEFAULT 'uploading',
    [ChunkCount] [int] NULL,
    64 NULL,
    [UploadTime] [datetime] NOT NULL DEFAULT GETDATE(),
    [CompleteTime] [datetime] NULL,
    CONSTRAINT [PK_FileTransferRecords] PRIMARY KEY CLUSTERED ([Id] ASC)
);

文件夹传输记录表

CREATE TABLE [dbo].[FolderTransferRecords](
    64 NOT NULL,
    255 NOT NULL,
    512 NOT NULL,
    [TotalFiles] [int] NOT NULL,
    [TotalSize] [bigint] NOT NULL,
    [CompletedFiles] [int] NULL DEFAULT 0,
    20 NULL DEFAULT 'SM4',
    20 NULL DEFAULT 'uploading',
    64 NULL,
    [UploadTime] [datetime] NOT NULL DEFAULT GETDATE(),
    [CompleteTime] [datetime] NULL,
    CONSTRAINT [PK_FolderTransferRecords] PRIMARY KEY CLUSTERED ([Id] ASC)
);

部署方案

基础环境要求

  • 操作系统:Windows Server 2012+/CentOS 7+/统信UOS
  • .NET环境:.NET 6+ (支持WebForm和.NET Core)
  • 数据库:SQL Server 2012+/MySQL 5.7+/Oracle 11g+
  • Redis:5.0+ (用于断点续传信息存储)

部署步骤

  1. 数据库初始化

    • 执行提供的SQL脚本创建表结构
  2. 配置文件修改

    // appsettings.json
    {
      "Storage": {
        "Local": {
          "Path": "C:FileStorage"
        },
        "Oss": {
          "Enabled": true,
          "Endpoint": "https://oss-cn-shenzhen.aliyuncs.com",
          "AccessKeyId": "your-access-key-id",
          "AccessKeySecret": "your-access-key-secret",
          "BucketName": "your-bucket-name"
        }
      },
      "Redis": {
        "Configuration": "localhost:6379",
        "InstanceName": "FileTransfer:"
      }
    }
    
  3. 发布和部署

    • 使用Visual Studio 2022发布项目
    • 部署到IIS或Kestrel服务器

信创环境适配

国产化适配清单

  1. 操作系统

    • 统信UOS:验证文件路径兼容性
    • 银河麒麟:验证服务启动脚本
  2. 数据库

    • 达梦DM8:调整SQL语法
    • 人大金仓:验证事务隔离级别
  3. 中间件

    • 东方通TongWeb:验证Servlet容器兼容性
    • 金蝶AAS:验证JNDI数据源配置

适配代码示例

// 操作系统检测
public static class OSValidator
{
    public static bool IsUOS()
    {
        return RuntimeInformation.OSDescription.Contains("UOS");
    }
    
    public static bool IsKylin()
    {
        return RuntimeInformation.OSDescription.Contains("Kylin");
    }
}

// 达梦数据库适配
public class DamengDbContext : DbContext
{
    protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    {
        if (OSValidator.IsUOS())
        {
            optionsBuilder.UseDameng("ConnectionString");
        }
        else
        {
            optionsBuilder.UseSqlServer("ConnectionString");
        }
    }
}

成功案例

央企客户A

  • 项目规模:部署节点30+
  • 传输数据量:日均1.5TB+
  • 稳定性:连续运行120天无故障

政府客户B

  • 安全要求:等保三级认证
  • 适配环境:统信UOS + 达梦DM8
  • 性能指标:100GB文件传输平均耗时45分钟

商务合作方案

授权模式

  1. 年度授权:20万元/年

    • 无限次部署权限
    • 全年技术支持服务
    • 免费版本升级
  2. 增值服务

    • 定制开发服务:5万元起
    • 紧急响应服务:2万元/次

资质证明

  1. 软件著作权证书(登记号:2023SR123456)
  2. 商用密码产品认证证书
  3. 5个央企客户合作证明(含合同复印件)

设置框架

安装.NET Framework 4.7.2
https://dotnet.microsoft.com/en-us/download/dotnet-framework/net472
框架选择4.7.2

添加3rd引用

编译项目

NOSQL

NOSQL无需任何配置可直接访问页面进行测试

SQL

使用IIS
大文件上传测试推荐使用IIS以获取更高性能。

使用IIS Express

小文件上传测试可以使用IIS Express

创建数据库

配置数据库连接信息

检查数据库配置

访问页面进行测试


相关参考:
文件保存位置,

效果预览

文件上传

文件刷新续传

支持离线保存文件进度,在关闭浏览器,刷新浏览器后进行不丢失,仍然能够继续上传

文件夹上传

支持上传文件夹并保留层级结构,同样支持进度信息离线保存,刷新页面,关闭页面,重启系统不丢失上传进度。

下载完整示例

下载完整示例

本文地址:https://www.yitenyun.com/3457.html

搜索文章

Tags

#远程工作 #服务器 #python #pip #conda #ios面试 #ios弱网 #断点续传 #ios开发 #objective-c #ios #ios缓存 香港站群服务器 多IP服务器 香港站群 站群服务器 #kubernetes #笔记 #平面 #容器 #linux #学习方法 #运维 #docker #后端 #数据库 #进程控制 #MobaXterm #ubuntu #Conda # 私有索引 # 包管理 #Trae #IDE #AI 原生集成开发环境 #Trae AI #开发语言 #云原生 #iventoy #VmWare #OpenEuler #cpolar #人工智能 #node.js #fastapi #html #css #内网穿透 #网络 #低代码 #爬虫 #音视频 #github #git #学习 #物联网 #websocket #vscode #mobaxterm #深度学习 #计算机视觉 #开源 #RTP over RTSP #RTP over TCP #RTSP服务器 #RTP #TCP发送RTP #android #腾讯云 #c# #算法 #大数据 #数信院生信服务器 #Rstudio #生信入门 #生信云服务器 #安全 #nginx #tcp/ip #golang #java #redis #hadoop #hbase #hive #zookeeper #spark #kafka #flink #缓存 #web安全 #kylin #jmeter #功能测试 #软件测试 #自动化测试 #职场和发展 #unity #游戏引擎 #我的世界 #云计算 #windows #银河麒麟高级服务器操作系统安装 #银河麒麟高级服务器V11配置 #设置基础软件仓库时出错 #银河麒高级服务器系统的实操教程 #生产级部署银河麒麟服务系统教程 #Linux系统的快速上手教程 #qt #C++ #凤希AI伴侣 #udp #c++ #需求分析 #prometheus #gpu算力 #grafana #jar #todesk #华为云 #部署上线 #动静分离 #Nginx #新人首发 #架构 #面试 #ssh #改行学it #创业创新 #程序员创富 #claude #银河麒麟 #系统升级 #信创 #国产化 #多个客户端访问 #IO多路复用 #回显服务器 #TCP相关API #vllm #大模型 #Streamlit #Qwen #本地部署 #AI聊天机器人 #编辑器 #ide #SRS #流媒体 #直播 #elasticsearch #版本控制 #Git入门 #开发工具 #代码托管 #课程设计 #vue.js #前端 #ollama #ai #llm #守护进程 #复用 #screen #http #性能优化 #n8n #c语言 #stm32 #Android #Bluedroid #umeditor粘贴word #ueditor粘贴word #ueditor复制word #ueditor上传word图片 #智能手机 #java-ee #分阶段策略 #模型协议 #mamba #压力测试 #1024程序员节 #MCP #我的世界服务器搭建 #minecraft #openlayers #bmap #tile #server #vue #网络协议 #AI #大模型学习 #json #scala #测试用例 #测试工具 #Dell #PowerEdge620 #内存 #硬盘 #RAID5 #asp.net大文件上传 #asp.net大文件上传下载 #asp.net大文件上传源码 #ASP.NET断点续传 #asp.net上传文件夹 #apache #ping通服务器 #读不了内网数据库 #bug菌问答团队 #flutter #数码相机 #SSH #X11转发 #Miniconda #mcu #cpp #项目 #高并发 #debian #MCP服务器 #企业开发 #ERP #项目实践 #.NET开发 #C#编程 #编程与数学 #gemini #gemini国内访问 #gemini api #gemini中转搭建 #Cloudflare #screen 命令 #asp.net #华为 #ModelEngine #spring #flask #mvp #个人开发 #设计模式 #金融 #mcp #金融投资Agent #Agent #JumpServer #堡垒机 #振镜 #振镜焊接 #毕设 #语音识别 #spring boot #rustdesk #p2p #科技 #个人博客 #进程 #操作系统 #进程创建与终止 #shell #unity3d #游戏 #服务器框架 #Fantasy #YOLOFuse # Base64编码 # 多模态检测 #SPA #单页应用 #django #web3.py #阿里云 #自动化 #centos #RustDesk #IndexTTS 2.0 #本地化部署 #麒麟OS #swagger #毕业设计 #车辆排放 #pycharm #ms-swift # 大模型 # 模型训练 #Spring AI #STDIO协议 #Streamable-HTTP #McpTool注解 #服务器能力 #xlwings #Excel #php #nfs #iscsi #epoll #transformer #prompt #react.js #sqlite #javascript #wordpress #雨云 #电气工程 #C# #PLC #oracle #rdp #自然语言处理 #神经网络 #libosinfo #mysql #PyTorch # Triton # 高并发部署 #ddos #AIGC #单片机 #嵌入式硬件 #TCP #客户端 #嵌入式 #DIY机器人工房 #jenkins #maven #gitlab #LoRA # lora-scripts # 模型微调 #https #tomcat #sql #intellij-idea #webrtc #idm #EMC存储 #存储维护 #NetApp存储 #万悟 #联通元景 #智能体 #镜像 #微信小程序 #小程序 #微信 #健身房预约系统 #健身房管理系统 #健身管理系统 #高级IO #select #计算机网络 #硬件架构 #NAS #Termux #Samba #Linux #ansible #sqlserver #鸭科夫 #逃离鸭科夫 #鸭科夫联机 #鸭科夫异地联机 #开服 #gitea #macos #北京百思可瑞教育 #百思可瑞教育 #北京百思教育 #risc-v #程序员 #大模型教程 #AI大模型 #deepseek #网站 #截图工具 #批量处理图片 #图片格式转换 #图片裁剪 #harmonyos #鸿蒙PC #进程等待 #wait #waitpid #SSH公钥认证 # PyTorch # 安全加固 #fiddler #电脑 #部署 #搜索引擎 #jvm #tdengine #时序数据库 #制造 #涛思数据 #分布式 #pytorch #API限流 # 频率限制 # 令牌桶算法 #Proxmox VE #虚拟化 #VMware #iBMC #UltraISO #黑群晖 #虚拟机 #无U盘 #纯小白 #东方仙盟 #蓝湖 #Axure原型发布 #NPU #CANN #idea #intellij idea #AI编程 #arm开发 #智能路由器 #5G #网络安全 #单元测试 #集成测试 #C2000 #TI #实时控制MCU #AI服务器电源 #微服务 #DisM++ # GLM-4.6V # 系统维护 #京东云 #DeepSeek #蓝耘智算 #UDP的API使用 #处理器 #910B #昇腾 #ida #研发管理 #禅道 #禅道云端部署 #YOLO # 目标检测 #深度优先 #DFS #RAID #RAID技术 #磁盘 #存储 #YOLO26 #目标检测 #数据结构 #milvus #springboot #知识库 #语言模型 #web server #请求处理流程 #postman #cursor # TTS服务器 # 键鼠锁定 #媒体 #mybatis #交通物流 #chatgpt #WinSCP 下载安装教程 #SFTP #FTP工具 #服务器文件传输 #scrapy #系统架构 #STDIO传输 #SSE传输 #WebMVC #WebFlux #bootstrap #ArkUI #ArkTS #鸿蒙开发 #aws #node #政务 #经验分享 #机器学习 #kmeans #聚类 #Clawdbot #个人助理 #数字员工 #文件IO #输入输出流 #信息与通信 #信号处理 #tcpdump #Nacos #web #参数估计 #矩估计 #概率论 #ui #分类 #KMS #slmgr #Java #puppeteer #pve #LangGraph #CLI #Python #JavaScript #langgraph.json #scikit-learn #随机森林 #paddleocr #安全威胁分析 #源码 #闲置物品交易系统 #企业级存储 #网络设备 #仙盟创梦IDE #Smokeping #IPv6 #DNS #大模型应用 #API调用 #PyInstaller打包运行 #服务端部署 #spring cloud #大语言模型 #视频去字幕 #3d #zotero #WebDAV #同步失败 #代理模式 #工具集 #文件管理 #文件服务器 #openEuler #欧拉 #numpy #jetty #计算机 #openresty #lua #LobeChat #vLLM #GPU加速 #麒麟 #SA-PEKS # 关键词猜测攻击 # 盲签名 # 限速机制 #小艺 #鸿蒙 #搜索 #产品经理 #就业 #KMS激活 #算力一体机 #ai算力服务器 #langchain #大模型开发 #大模型部署 #mindie #大模型推理 #cesium #可视化 #CosyVoice3 # 语音合成 #aiohttp #asyncio #异步 #数据分析 #SSH反向隧道 # Miniconda # Jupyter远程访问 #数据仓库 #软件 #本地生活 #电商系统 #商城 #简单数论 #埃氏筛法 #Ansible #Playbook #AI服务器 #CSDN #yum #AI论文写作工具 #学术写作辅助 #论文创作效率提升 #AI写论文实测 #windows11 #microsoft #系统修复 #飞牛NAS #监控 #NVR #EasyNVR #.netcore #codex #MC #ARM架构 #x86_64 #数字人系统 #rtsp #转发 #三维 #3D #三维重建 #uni-app #notepad++ #负载均衡 #其他 #Dify #鲲鹏 #.net #net core #kestrel #web-server #asp.net-core #ssl #CVE-2025-61686 #漏洞 #路径遍历高危漏洞 #1panel #vmware #vuejs #MC群组服务器 #web服务器 #说话人验证 #声纹识别 #CAM++ #LangFlow # 智能运维 # 性能瓶颈分析 # GPU租赁 # 自建服务器 #云服务器 #个人电脑 #devops #C语言 #机器人 #密码学 #PTP_1588 #gPTP #FTP服务器 #Windows #fpga开发 #信创国产化 #达梦数据库 #adb #散列表 #哈希算法 #树莓派 #温湿度监控 #WhatsApp通知 #IoT #MySQL #SMTP # 内容安全 # Qwen3Guard #硬件 #CUDA #Triton #推荐算法 # ControlMaster #postgresql #PowerBI #企业 #dify #平板 #零售 #硬件工程 #智能硬件 #opencv #数据挖掘 #无人机 #Deepoc #具身模型 #开发板 #未来 #Qwen3-14B # 大模型部署 # 私有化AI #vnstat #聊天小程序 #AutoDL #运维开发 #文心一言 #AI智能体 #练习 #基础练习 #数组 #循环 #九九乘法表 #计算机实现 #ETL管道 #RAG #向量存储 #数据预处理 #DocumentReader #飞牛nas #fnos #支付 #ffmpeg #SSH跳板机 # Python3.11 #SSH密钥 # CUDA #系统管理 #服务 #银河麒麟部署 #银河麒麟部署文档 #银河麒麟linux #银河麒麟linux部署教程 #Modbus-TCP #screen命令 #GPU服务器 #8U #cosmic #管道Pipe #system V #ai编程 #llama #门禁 #梯控 #智能一卡通 #门禁一卡通 #消费一卡通 #智能梯控 #一卡通 #uv #uvx #uv pip #npx #Ruff #pytest #leetcode #H5 #跨域 #发布上线后跨域报错 #请求接口跨域问题解决 #跨域请求代理配置 #request浏览器跨域 #AI 推理 #NV #SAP #ebs #metaerp #oracle ebs #muduo库 #rust #Tokio #远程桌面 #远程控制 #游戏机 #智能体来了 #智能体对传统行业冲击 #行业转型 #AI赋能 #teamviewer #中间件 #Anaconda配置云虚拟环境 #MQTT协议 #vivado license #CVE-2025-68143 #CVE-2025-68144 #CVE-2025-68145 #bash #html5 #排序算法 #jupyter #svn #fabric #sql注入 #可信计算技术 #win11 #LLM #chat #openHiTLS #TLCP #DTLCP #商用密码算法 #zabbix #HeyGem # 服务器配置 # GPU #serverless #CPU #测评 #CCE #Dify-LLM #Flexus # 双因素认证 # TensorFlow #free #vmstat #sar # 轻量化镜像 # 边缘计算 #mariadb #react native #OpenHarmony #连接数据库报错 #AI-native #ftp #sftp #网络攻击模型 #pyqt #微PE #硬盘克隆 #DiskGenius #Discord机器人 #云部署 #程序那些事 #远程连接 #r语言 #cpu #工程设计 #预混 #扩散 #燃烧知识 #层流 #湍流 #TRO #TRO侵权 #TRO和解 #excel #运维工具 # CosyVoice3 # 批量部署 #copilot #智能家居 #chrome #C #rocketmq #selenium #领域驱动 #AI写作 #PN 结 #企业微信 #服务器线程 # SSL通信 # 动态结构体 #RWK35xx #语音流 #实时传输 #服务器IO模型 #非阻塞轮询模型 #多任务并发模型 #异步信号模型 #多路复用模型 #报表制作 #职场 #数据可视化 #信息可视化 #用数据讲故事 #系统安全 #手机h5网页浏览器 #安卓app #苹果ios APP #手机电脑开启摄像头并排查 #ipmitool #BMC # 黑屏模式 #visual studio code #入侵 #日志排查 #蓝牙 #LE Audio #BAP #powerbi #嵌入式编译 #ccache #distcc #es安装 #串口服务器 #工业级串口服务器 #串口转以太网 #串口设备联网通讯模块 #串口服务器选型 #embedding #lvs #铁路桥梁 #DIC技术 #箱梁试验 #裂纹监测 #四点弯曲 #模型训练 #星图GPU #可再生能源 #绿色算力 #风电 #麦克风权限 #访问麦克风并录制音频 #麦克风录制音频后在线播放 #用户拒绝访问麦克风权限怎么办 #uniapp 安卓 苹果ios #将音频保存本地或上传服务器 #链表 #express #cherry studio #Spring AOP #程序人生 #漏洞挖掘 #Exchange #POC #问答 #交付 #动态规划 #GPU #租显卡 #训练推理 #wsl #AI应用编程 # 自动化运维 #dlms #dlms协议 #逻辑设备 #逻辑设置间权限 #多进程 #python技巧 #蓝桥杯 #iot #软件工程 #若依 #GLM-4.6V-Flash-WEB # AI视觉 # 本地部署 #AI Agent #开发者工具 #ambari #bigtop #hdp #hue #kerberos #pencil #pencil.dev #设计 #Anything-LLM #IDC服务器 #私有化部署 #Minecraft #Minecraft服务器 #PaperMC #我的世界服务器 #翻译 #前端框架 #计算机外设 #Langchain-Chatchat # 国产化服务器 # 信创 #Karalon #AI Test #YOLOv8 # Docker镜像 #kong #Kong Audio #Kong Audio3 #KongAudio3 #空音3 #空音 #中国民乐 #journalctl #健康医疗 #树莓派4b安装系统 #scanf #printf #getchar #putchar #cin #cout #Reactor #ET模式 #非阻塞 #高并发服务器 #生产服务器问题查询 #日志过滤 #Autodl私有云 #深度服务器配置 #esp32教程 # IndexTTS 2.0 #VoxCPM-1.5-TTS # 云端GPU # PyCharm宕机 #儿童AI #图像生成 #pjsip #工程实践 #人脸识别sdk #视频编解码 #人脸识别 #AI生成 # outputs目录 # 自动化 #AI应用 #海外服务器安装宝塔面板 #stl #漏洞修复 #IIS Crypto #开源工具 #高考 #编程助手 #gpt #API #taro #jdk #排序 #青少年编程 #决策树 #laravel #sglang #ZooKeeper #ZooKeeper面试题 #面试宝典 #深入解析 #vps #业界资讯 #国产操作系统 #V11 #kylinos #论文阅读 #信息安全 #信息收集 #poll #Hadoop #word #通信 # 服务器迁移 # 回滚方案 #大模型入门 #eureka #性能 #优化 #DDR #RAM #wireshark #广播 #组播 #并发服务器 #材料工程 #智能电视 #VMware创建虚拟机 #信令服务器 #Janus #MediaSoup #reactjs #web3 #gpu #nvcc #cuda #nvidia #IntelliJ IDEA #Spring Boot #SQL注入主机 #Coturn #TURN #STUN #Go并发 #高并发架构 #Goroutine #系统设计 #Tracker 服务器 #响应最快 #torrent 下载 #2026年 #Aria2 可用 #迅雷可用 #BT工具通用 #AI技术 #DooTask #模块 #RXT4090显卡 #RTX4090 #深度学习服务器 #硬件选型 #Ubuntu服务器 #硬盘扩容 #命令行操作 #群晖 #音乐 #产品运营 #eBPF #Puppet # IndexTTS2 # TTS #Socket #echarts #高斯溅射 #ThingsBoard MCP #云开发 #空间计算 #原型模式 #KMS 激活 #Harbor #戴尔服务器 #戴尔730 #装系统 #AI智能棋盘 #Rock Pi S #边缘计算 #驱动开发 # 服务器IP访问 # 端口映射 #unix #gateway #Comate #SSH别名 #遛狗 #CS2 #debian13 #bug #clickhouse #asp.net上传大文件 #代理 #ceph #数据访问 #uip #磁盘配额 #存储管理 #形考作业 #国家开放大学 #系统运维 #自动化运维 #VMware Workstation16 #服务器操作系统 #DHCP #agent #ai大模型 #pdf #结构体 #wpf #全文检索 #Modbus #MOXA #lucene # 一锤定音 # 大模型微调 ##租显卡 #机器视觉 #6D位姿 #数据安全 #注入漏洞 #汽车 #渗透测试 #黑客技术 #文件上传漏洞 #密码 #firefox #safari # RTX 3090 #Kylin-Server #服务器安装 #Docker #Android16 #音频性能实战 #音频进阶 #b树 #短剧 #短剧小程序 #短剧系统 #微剧 #hibernate #nosql #昇腾300I DUO #H5网页 #网页白屏 #H5页面空白 #资源加载问题 #打包部署后网页打不开 #HBuilderX #CTF #目标跟踪 #A2A #GenAI #SSE # AI翻译机 # 实时翻译 #VMWare Tool #ue5 #googlecloud #IO #IFix #c++20 # 远程连接 #FHSS #心理健康服务平台 #心理健康系统 #心理服务平台 #心理健康小程序 #bond #服务器链路聚合 #网卡绑定 #CNAS #CMA #程序文件 #matplotlib #安全架构 #攻防演练 #Java web #红队 #nodejs #opc ua #opc #学术论文创作 #论文效率提升 #MBA论文写作 # 环境迁移 #vp9 #dynadot #域名 #TTS私有化 # IndexTTS # 音色克隆 #esb接口 #走处理类报异常 #交互 #WT-2026-0001 #QVD-2026-4572 #smartermail #具身智能 #LVDS #高速ADC #网路编程 #百万并发 #Emby #视频 #smtp #smtp服务器 #PHP #声源定位 #MUSIC #ip # ARM服务器 # 大模型推理 #AI电商客服 #Gunicorn #WSGI #Flask #并发模型 #容器化 #性能调优 #超时设置 #客户端/服务器 #网络编程 #挖矿 #Linux病毒 #turn #网安应急响应 # GLM # 服务连通性 #azure #ROS # 局域网访问 # 批量处理 #源代码管理 #ServBay # 高并发 #数据恢复 #视频恢复 #视频修复 #RAID5恢复 #流媒体服务器恢复 #Llama-Factory # 树莓派 # ARM架构 #npu #大剑师 #nodejs面试题 #状态模式 #dba #银河麒麟操作系统 #openssh #华为交换机 #信创终端 #国产化OS # 跳板机 #ansys #ansys问题解决办法 #TTS #go # WebUI # 网络延迟 # GPU集群 #ranger #MySQL8.0 #统信UOS #win10 #qemu #服务器开启 TLS v1.2 #IISCrypto 使用教程 #TLS 协议配置 #IIS 安全设置 #服务器运维工具 #远程软件 #uniapp #合法域名校验出错 #服务器域名配置不生效 #request域名配置 #已经配置好了但还是报错 #uniapp微信小程序 #框架搭建 #ASR #SenseVoice #glibc #能源 #blender #设计师 #图像处理 #游戏美术 #技术美术 #weston #x11 #x11显示服务器 #视觉检测 #visual studio #计算几何 #斜率 #方向归一化 #叉积 # 批量管理 #elk #证书 #odoo #winscp #ONLYOFFICE #MCP 服务器 #HarmonyOS #后端框架 #Apple AI #Apple 人工智能 #FoundationModel #Summarize #SwiftUI #arm #集成学习 # TURN # NAT穿透 #MCP服务器注解 #异步支持 #方法筛选 #声明式编程 #自动筛选机制 #服务器繁忙 # 串口服务器 # NPort5630 #appche #pxe #muduo #TcpServer #accept #远程开发 # 数字人系统 # 远程部署 #YOLO识别 #YOLO环境搭建Windows #YOLO环境搭建Ubuntu #Python办公自动化 #Python办公 #实时音视频 #opc模拟服务器 #spine #量子计算 #移动端h5网页 #调用浏览器摄像头并拍照 #开启摄像头权限 #拍照后查看与上传服务器端 #摄像头黑屏打不开问题 #AI部署 # ms-swift #超算中心 #PBS #lsf #语音生成 #nas #IndexTTS2 # 阿里云安骑士 # 木马查杀 #adobe #宝塔面板部署RustDesk #RustDesk远程控制手机 #手机远程控制 #人大金仓 #Kingbase #Node.js # child_process #gmssh #宝塔 #策略模式 # keep-alive #静脉曲张 #腿部健康 #运动 #生信 #面向对象 #基础语法 #标识符 #常量与变量 #数据类型 #运算符与表达式 #前端开发 #raid #raid阵列 #EN4FE #自由表达演说平台 #演说 #java大文件上传 #java大文件秒传 #java大文件上传下载 #java文件传输解决方案 #轻量化 #低配服务器 #范式 #docker安装seata #iphone #PyCharm # 远程调试 # YOLOFuse #流程图 #论文笔记 #图论 #国产开源制品管理工具 #Hadess #一文上手 #okhttp #Syslog #系统日志 #日志分析 #日志监控 # 水冷服务器 # 风冷服务器 #全链路优化 #实战教程 #database #everything #CMake #Make #C/C++ #图像识别 #OpenAI #高可用 #故障 #多模态 #微调 #超参 #LLamafactory #SSH保活 #rabbitmq #esp32 arduino #wps #Linux多线程 #HistoryServer #Spark #YARN #jobhistory #Java程序员 #Java面试 #后端开发 #Spring源码 #Spring #SpringBoot #ComfyUI # 推理服务器 #Beidou #北斗 #SSR #n8n解惑 #内存接口 # 澜起科技 # 服务器主板 # GLM-4.6V-Flash-WEB # 显卡驱动备份 #模拟退火算法 #计算机毕业设计 #程序定制 #毕设代做 #课设 #coffeescript #CPU利用率 #simulink #matlab #nacos #银河麒麟aarch64 #uvicorn #uvloop #asgi #event #传统行业 #homelab #Lattepanda #Jellyfin #Plex #Kodi #yolov12 #研究生life #开关电源 #热敏电阻 #PTC热敏电阻 #文件传输 #电脑文件传输 #电脑传输文件 #电脑怎么传输文件到另一台电脑 #电脑传输文件到另一台电脑 #mongodb # AI部署 #TensorRT # 推理优化 #AB包 #远程更新 #缓存更新 #多指令适配 #物料关联计划 #挖漏洞 #攻击溯源 #编程 #企业存储 #RustFS #对象存储 #warp # 自动化部署 # VibeThinker #Aluminium #Google #数字化转型 #实体经济 #商业模式 #软件开发 #数智红包 #商业变革 #创业干货 #neo4j #NoSQL #SQL #m3u8 #HLS #移动端H5网页 #APP安卓苹果ios #监控画面 直播视频流 #Prometheus #log4j #Zabbix #语音合成 #Jetty # 嵌入式服务器 #二值化 #Canny边缘检测 #轮廓检测 #透视变换 #FASTMCP #防毒面罩 #防尘面罩 #建筑缺陷 #红外 #数据集 #UEFI #BIOS #Legacy BIOS #SMARC #ARM #联机教程 #局域网联机 #局域网联机教程 #局域网游戏 # 代理转发 #交换机 #三层交换机 # 服务器IP # 端口7860 #junit # 公钥认证 #身体实验室 #健康认知重构 #系统思维 #微行动 #NEAT效应 #亚健康自救 #ICT人 #VibeVoice # 云服务器 #模型上下文协议 #MultiServerMCPC #load_mcp_tools #load_mcp_prompt #c++高并发 #BoringSSL #I/O模型 #并发 #水平触发、边缘触发 #多路复用 #云计算运维 #MinIO服务器启动与配置详解 #SSH复用 # 远程开发 # 鲲鹏 #ShaderGraph #图形 #http头信息 #ci/cd #k8s #C++ UA Server #SDK #跨平台开发 #eclipse #servlet # 权限修复 #ICE #arm64 #MS #Materials #TCP服务器 #开发实战 #GATT服务器 #蓝牙低功耗 #银河麒麟服务器系统 #UOS #海光K100 #统信 #mssql # HiChatBox # 离线AI #Fun-ASR # 语音识别 #可撤销IBE #服务器辅助 #私钥更新 #安全性证明 #双线性Diffie-Hellman #memory mcp #Cursor #扩展屏应用开发 #android runtime #nmodbus4类库使用教程 #docker-compose #TLS协议 #HTTPS #运维安全 #windbg分析蓝屏教程 #le audio #低功耗音频 #连接 #vncdotool #链接VNC服务器 #如何隐藏光标 #内存治理 #插件 #开源软件 #网络安全大赛 #r-tree #Buck #NVIDIA #算力 #交错并联 #DGX #实时检测 #卷积神经网络 #DAG #gerrit #云服务器选购 #Saas #线程 #NFC #智能公交 #服务器计费 #FP-增长 #outlook #错误代码2603 #无网络连接 #2603 #算力建设 #xshell #host key #HarmonyOS APP #指针 #anaconda #虚拟环境 #tensorflow #GB28181 #SIP信令 #视频监控 # GLM-TTS # 数据安全 #log #rtmp #agi #spring ai #oauth2 #claude code #code cli #ccusage # 高温监控 #fs7TF # 远程访问 #memcache #SSH免密登录 #华为od #华为机试 #ESP32 # OTA升级 # 黄山派 #内网 #SSH跳转 #Gateway #认证服务器集成详解 #RK3576 #瑞芯微 #硬件设计 #mtgsig #美团医药 #美团医药mtgsig #美团医药mtgsig1.2 #代理服务器 #rsync # 数据同步 #套接字 #I/O多路复用 #字节序 #分布式数据库 #集中式数据库 #业务需求 #选型误 #samba # Connection refused #RSO #机器人操作系统 #Socket网络编程 #跳槽 #工作 #gRPC #注册中心 #多线程 #claudeCode #content7 #Ubuntu #c #JNI #安卓 #sentinel #MinIO #Host #SSRF #反向代理 #数据迁移 #测速 #iperf #iperf3 #系统安装 #边缘AI # Kontron # SMARC-sAMX8 #remote-ssh #模版 #函数 #类 #笔试 #WEB #流量监控 #diskinfo # 磁盘健康 #SSH Agent Forwarding # 容器化 #webpack #链表的销毁 #链表的排序 #链表倒置 #判断链表是否有环 #VS Code调试配置 #服务器解析漏洞 #Ascend #MindIE #ARM服务器 # 多模态推理 #雨云服务器 #教程 #MCSM面板