最新资讯

  • 基于OpenHarmony鸿蒙开发新闻资讯APP

基于OpenHarmony鸿蒙开发新闻资讯APP

2026-01-30 22:13:19 栏目:最新资讯 2 阅读

文章目录

    • 一、前言
    • 二、项目概述
    • 三、项目架构概览
    • 四、核心功能模块
        • 1. 用户系统
        • 2. 新闻系统
        • 3. 视频系统
        • 4. 项目结构
    • 四、技术架构
    • 五、核心业务功能实现详细分析
        • 1. 用户登录功能
        • 2. 用户注册功能
        • 3. 用户信息管理
        • 3. 新闻分类浏览
        • 4. 新闻详情展示
        • 5. 新闻搜索功能
        • 6. 收藏功能
        • 7. 收藏列表管理
        • 8. 视频播放
    • 六、项目运行效果截图

一、前言

随着移动互联网的快速发展,新闻资讯类应用已成为人们获取信息的重要渠道。HarmonyOS作为华为推出的新一代分布式操作系统,以其独特的技术优势和生态能力,为开发者提供了全新的应用开发体验。本文将深入分析一个基于HarmonyOS开发的新闻客户端项目,从架构设计、功能实现到技术特性进行全面解读,帮助开发者更好地理解和掌握HarmonyOS应用开发的核心要点。

在当今移动应用开发领域,HarmonyOS凭借其分布式架构、一次开发多端部署、原生性能等优势,正逐渐成为开发者的新宠。通过实际项目案例的学习,我们能够更直观地感受到HarmonyOS的技术魅力和开发便利性。

二、项目概述

本项目是一个基于HarmonyOS开发的新闻客户端应用,旨在为用户提供优质的新闻阅读和视频观看体验。该应用集成了新闻浏览、视频播放、用户管理、内容收藏等核心功能,是一个功能完备的移动端资讯平台。

三、项目架构概览

该项目采用典型的HarmonyOS应用结构,使用ArkUI框架开发,分为多个功能模块:

  • API层: api - 统一管理后端接口
  • 组件层: component - 可复用UI组件
  • 控制器层: controller - 业务逻辑控制器
  • HTTP层: http - 网络请求封装
  • 模型层: model - 数据模型定义
  • 页面层: pages - 应用页面
  • 工具层: utils - 工具类

四、核心功能模块

1. 用户系统
  • 登录、注册: 完整的用户身份验证流程
  • 个人中心: 用户信息管理、统计数据展示(统计数据模块为静态页面)
  • 会话管理: 用户状态持久化存储
2. 新闻系统
  • 分类浏览: 多类别新闻内容展示
  • 详情阅读: 丰富的新闻内容呈现
  • 搜索功能: 新闻内容检索能力
  • 互动功能: 点赞、收藏、评论、分享 (目前已实现收藏)
3. 视频系统
  • 视频播放: 基于AVPlayer的高质量视频播放
  • 播放控制: 完整的播放控制功能
  • 全屏播放: 流畅的全屏播放体验
4. 项目结构
Harmony-news-client/
├── AppScope/                 # 应用级资源和配置
├── entry/                   # 主模块
│   ├── src/main/ets/        # ArkTS源代码
│   │   ├── api/            # API配置
│   │   ├── component/      # UI组件库
│   │   ├── controller/     # 控制器层
│   │   ├── http/           # HTTP请求封装
│   │   ├── model/          # 数据模型
│   │   ├── pages/          # 页面组件
│   │   └── utils/          # 工具类
│   └── src/main/resources/  # 应用资源
├── hvigor/                  # 构建工具配置
└── oh-package.json5         # 依赖包管理

四、技术架构

  • 开发语言: ArkTS
  • UI框架: ArkUI
  • 运行环境: HarmonyOS
  • 构建工具: Hvigor

五、核心业务功能实现详细分析

1. 用户登录功能
  • 实现位置: LoginPage.ets
  • 功能流程:
    1. 用户输入用户名和密码
    2. 前端表单验证(用户名≥3字符,密码≥6字符)
    3. 调用后端登录接口 ApiConfig.LOGIN_URL
    4. 接收响应并判断登录结果
    5. 登录成功则跳转至首页,保存用户信息到AppStorage
    6. 登录失败则显示错误信息
  • 数据模型: 使用 UserInfo 存储用户信息
 /**
   * 处理登录
   */
  async handleLogin() {
    // 简单验证
    if (!this.username || this.username.length < 3) {
      this.errorMsg = '用户名至少3位字符'
      return
    }

    if (!this.password || this.password.length < 6) {
      this.errorMsg = '密码至少6位字符'
      return
    }

    this.loading = true
    this.errorMsg = ''

    try {
      const res = await get(ApiConfig.LOGIN_URL, {
        params: {
          "username": this.username,
          "password": this.password,

        }
      })

      if (res.success) {
        // 登录成功,跳转到首页
        this.getUIContext().getRouter().pushUrl({
          url: 'pages/IndexPage'
        })

        //全局保存用户信息
        AppStorage.setOrCreate<UserInfo>('userInfo', res.data as UserInfo)
      } else {
        this.errorMsg = res.msg || '登录失败'
      }
    } catch (error) {
      this.errorMsg = '网络请求失败,请检查网络连接'
      console.error('登录失败:', error)
    } finally {
      this.loading = false
    }
  }

2. 用户注册功能
  • 实现位置: RegisterPage.ets
  • 功能流程:
    1. 用户填写注册信息
    2. 前端表单验证
    3. 调用后端注册接口 ApiConfig.REGISTER_URL
    4. 处理注册结果并给出相应提示
 /**
   * 处理注册
   */
  async handleRegister() {
    // 简单验证
    if (!this.username || this.username.length < 3) {
      this.errorMsg = '用户名至少3位字符'
      return
    }

    if (!this.password || this.password.length < 6) {
      this.errorMsg = '密码至少6位字符'
      return
    }

    if (this.password !== this.confirmPassword) {
      this.errorMsg = '两次输入的密码不一致'
      return
    }

    this.loading = true
    this.errorMsg = ''

    try {
      const res = await get(ApiConfig.REGISTER_URL, {
        params: {
          "username": this.username,
          "password": this.password,
          "nickname": "热爱生活,热爱技术",
          "avatar": "https://q9.itc.cn/q_70/images03/20250730/7e535ac6918d44c4a0ab740ed9aa349d.jpeg"
        }
      })

      if (res.success) {
        // 注册成功,跳转到登录页面
        this.goToLogin()

      } else {
        this.errorMsg = res.msg || '注册失败'
      }
    } catch (error) {
      this.errorMsg = '网络请求失败,请检查网络连接'
      console.error('注册失败:', error)
    } finally {
      this.loading = false
    }
  }

3. 用户信息管理
  • 实现位置: UserInfoEditPage.ets 和 MineComponent.ets
  • 功能流程:
    1. 显示当前用户信息
    2. 允许编辑用户资料
    3. 调用更新接口 ApiConfig.EDIT_USER_INFO_URL
    4. 更新本地用户信息缓存
/**
   * 保存用户信息
   */
  async saveUserInfo() {
    // 简单验证
    if (!this.userInfo!!.nickname || this.userInfo!!.nickname.length < 2) {
      this.errorMsg = '昵称至少2位字符'
      return
    }

    if (this.userInfo!!.mobile && !/^1[3-9]d{9}$/.test(this.userInfo!!.mobile)) {
      this.errorMsg = '请输入正确的手机号'
      return
    }

    this.loading = true
    this.errorMsg = ''
    this.successMsg = ''

    try {
      const res = await postForm(ApiConfig.EDIT_USER_INFO_URL, {
        body: {
          "uid": this.userInfo!!.uid,
          "nickname": this.userInfo!!.nickname,
          "mobile": this.userInfo!!.mobile,
          "sign": this.userInfo!!.sign,
          "address": this.userInfo!!.address
        }
      })

      if (res.success) {
        this.successMsg = '保存成功'
        // 延迟返回上一页
        setTimeout(() => {
          this.getUIContext().getRouter().back()
        }, 1000)
      } else {
        this.errorMsg = res.msg || '保存失败'
      }
    } catch (error) {
      this.errorMsg = '网络请求失败,请检查网络连接'
      console.error('保存用户信息失败:', error)
    } finally {
      this.loading = false
    }
  }
3. 新闻分类浏览
  • 实现位置: TabItemComponent.ets 和 HomeComponent.ets
  • 功能流程:
    1. 页面加载时自动请求对应分类新闻
    2. 调用 ApiConfig.QUERY_NEWS_CATEGORY_URL 接口
    3. 解析返回的新闻列表数据
    4. 使用 NewsItemComponent 渲染新闻列表
    5. 处理加载状态、错误状态和空数据状态
@Component
export struct HomeComponent {
  titles: string[] = ["推荐", "军事", "教育", "文化", "健康", "财经", "体育", "汽车", "科技"]
  @State currentIndex: number = 0

  @Builder
  tabBuilder(title: string, targetIndex: number) {
    Text(title)
      .padding(10)
      .fontSize(18)
      .fontColor(this.currentIndex === targetIndex ? '#ff4d3b' : '#333333')
      .fontWeight(this.currentIndex === targetIndex ? FontWeight.Bold : FontWeight.Normal)
  }

  build() {
    Column() {
      // 增加一个新闻搜索入口
      Row() {
        // 搜索框
        Image($r('app.media.ic_logo')).width(36).margin({ right: 10 })
        Row() {
          SymbolGlyph($r('sys.symbol.magnifyingglass'))
            .fontSize(20)
            .fontColor(['#999999'])

          Text('搜索新闻...')
            .fontSize(16)
            .fontColor('#999999')
            .layoutWeight(1)
            .padding({ left: 8 })
        }
        .width('80%')
        .height(40)
        .backgroundColor('#f5f5f5')
        .borderRadius(20)
        .padding({ left: 16, right: 16 })
        .onClick(() => {
          // 跳转到搜索页面
          this.getUIContext().getRouter().pushUrl({
            url: 'pages/NewsSearchPage'
          })
        })
      }
      .width('100%')
      .justifyContent(FlexAlign.Center)
      .padding({ top: 10, bottom: 10 })

      Tabs() {
        ForEach(this.titles, (item: string, index: number) => {
          TabContent() {
            if (index==0) {
              TabItem2Component({
                title: item
              })
            }else {
              TabItemComponent({
                title: item
              })
            }


          }
          .tabBar(this.tabBuilder(item, index))
        })
      }
      .layoutWeight(1)

      .barMode(BarMode.Scrollable)
      .onChange((index: number) => {
        this.currentIndex = index
      })

    }
    .width('100%')
    .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP])
  }
}
4. 新闻详情展示
  • 实现位置: NewsDetailPage.ets
  • 功能流程:
    1. 从路由参数获取新闻信息
    2. 检查当前用户是否已收藏该新闻
    3. 显示新闻标题、作者、时间、图片和详细内容
@Entry
@Component
export struct NewsDetailPage {
  @StorageLink('userInfo') userInfo: UserInfo | null = null
  @State newsInfo: NewsInfo = {
    news_id: 0,
    title: '',
    news_img: '',
    details: '',
    author: '',
    news_type: '',
    create_time: ''
  }
  @State loading: boolean = false
  @State error: string = ''
  @State isLiked: boolean = false
  @State isFavorite: boolean = false
  @State likeCount: number = 128
  @State commentCount: number = 36
  newsId: number = 0

  aboutToAppear(): void {
    // 从路由参数中获取新闻ID
    let params = this.getUIContext().getRouter().getParams() as NewsInfo
    if (params) {
      this.newsInfo = params

      //检擦是否收藏过
      this.checkIsFavorite()
    }
  }

  /**
   * 检擦是否收藏过
   */
  async checkIsFavorite() {
    const res = await postForm(ApiConfig.IS_COLLECT_URL, {
      body: {
        "news_id": this.newsInfo.news_id,
        "user_id": this.userInfo!!.uid,
      }
    })

    if (res.success) {
      this.isFavorite = false
    } else {
      this.isFavorite = true
    }

  }

  /**
   * 处理点赞
   */
  handleLike() {
    this.isLiked = !this.isLiked
    this.likeCount = this.isLiked ? this.likeCount + 1 : this.likeCount - 1
    // TODO: 调用API保存点赞状态
  }

  /**
   * 处理收藏
   */
  async handleFavorite() {
    const res = await postForm(ApiConfig.FAVORITE_URL, {
      body: {
        "news_id": this.newsInfo.news_id,
        "user_id": this.userInfo!!.uid,
      }
    })

    if (res.success) {
      this.isFavorite = !this.isFavorite
    } else {
      this.getUIContext().getPromptAction().showToast({
        message: res.msg
      })
    }

  }

  /**
   * 处理分享
   */
  handleShare() {
    // TODO: 实现分享功能
    console.log('分享新闻:', this.newsInfo.title)
  }

  /**
   * 跳转到评论页面
   */
  goToComment() {
    // TODO: 实现评论功能
    console.log('跳转到评论页面')
  }

  build() {
    Column() {
      // 标题栏
      TopBarComponent({
        title: "新闻详情"
      })

      // 内容区域
      Scroll() {
        Column() {
          // 新闻标题
          Text(this.newsInfo.title)
            .fontSize(20)
            .fontWeight(FontWeight.Bold)
            .textAlign(TextAlign.Start)
            .padding({ left: 16, right: 16, top: 16 })

          // 新闻信息
          Row() {
            Text(this.newsInfo.author)
              .fontSize(14)
              .fontColor('#999999')

            Text(this.newsInfo.create_time)
              .fontSize(14)
              .fontColor('#999999')
              .margin({ left: 16 })

            Text(this.newsInfo.news_type)
              .fontSize(14)
              .fontColor('#999999')
              .margin({ left: 16 })
          }
          .padding({
            left: 16,
            right: 16,
            top: 12,
            bottom: 12
          })

          // 新闻图片
          if (this.newsInfo.news_img && this.newsInfo.news_img !== '') {
            // 使用容器来实现左右间距
            Row() {
              Image(this.newsInfo.news_img)
                .width('100%')
                .height(200)
                .objectFit(ImageFit.Cover)
            }
            .padding({ left: 16, right: 16, top: 10 })
          }

          // 新闻内容
          Text(this.newsInfo.details)
            .fontSize(16)
            .textAlign(TextAlign.Start)
            .padding({
              left: 16,
              right: 16,
              top: 16,
              bottom: 16
            })

          Blank().layoutWeight(1)
        }

      }
      .layoutWeight(1)

      // 底部功能栏
      Row() {
        // 分享
        Column() {
          SymbolGlyph($r('sys.symbol.share'))
            .fontSize(24)
            .fontColor(['#666666'])

          Text('分享')
            .fontSize(12)
            .fontColor('#999999')
            .margin({ top: 4 })
        }
        .layoutWeight(1)
        .justifyContent(FlexAlign.Center)
        .onClick(() => {
          this.handleShare()
        })

        // 评论
        Column() {
          SymbolGlyph($r('sys.symbol.combine'))
            .fontSize(24)
            .fontColor(['#666666'])

          Text(`评论 ${this.commentCount}`)
            .fontSize(12)
            .fontColor('#999999')
            .margin({ top: 4 })
        }
        .layoutWeight(1)
        .justifyContent(FlexAlign.Center)
        .onClick(() => {
          this.goToComment()
        })

        // 喜欢
        Column() {
          SymbolGlyph(this.isLiked ? $r('sys.symbol.heart_fill') : $r('sys.symbol.heart'))
            .fontSize(24)
            .fontColor(this.isLiked ? ['#ff4d3b'] : ['#666666'])

          Text(`喜欢 ${this.likeCount}`)
            .fontSize(12)
            .fontColor('#999999')
            .margin({ top: 4 })
        }
        .layoutWeight(1)
        .justifyContent(FlexAlign.Center)
        .onClick(() => {
          this.handleLike()
        })

        // 收藏
        Column() {
          SymbolGlyph(this.isFavorite ? $r('sys.symbol.bookmark_fill') : $r('sys.symbol.bookmark'))
            .fontSize(24)
            .fontColor(this.isFavorite ? ['#ff4d3b'] : ['#666666'])

          Text('收藏')
            .fontSize(12)
            .fontColor('#999999')
            .margin({ top: 4 })
        }
        .layoutWeight(1)
        .justifyContent(FlexAlign.Center)
        .onClick(() => {
          this.handleFavorite()
        })
      }
      .height(60)
      .backgroundColor('#ffffff')
      .border({ width: { top: 1 }, color: '#f0f0f0' })
    }
    .width('100%')
    .height('100%')
  }
}
5. 新闻搜索功能
  • 实现位置: NewsSearchPage.ets 和 HomeComponent.ets
  • 功能流程:
    1. 在首页点击搜索框进入搜索页面
    2. 调用 ApiConfig.SEARCH_URL 接口
    3. 显示搜索结果列表
@Entry
@Component
struct NewsSearchPage {
  @State searchKeyword: string = ''
  @State searchResults: NewsInfo[] = []
  @State loading: boolean = false
  @State error: string = ''
  @State hasSearched: boolean = false

  /**
   * 搜索新闻
   */
  async searchNews() {
    if (!this.searchKeyword || this.searchKeyword.trim() === '') {
      this.error = '请输入搜索关键词'
      return
    }

    this.loading = true
    this.error = ''
    this.hasSearched = true

    try {
      const res = await get(ApiConfig.SEARCH_URL, {
        params: {
          "title": this.searchKeyword.trim()
        }
      })

      if (res.success) {
        const newsRes = res.data as NewsRes
        this.searchResults = newsRes.list
      } else {
        this.error = res.msg || '搜索失败'
      }
    } catch (err) {
      this.error = '网络请求失败,请检查网络连接'
      console.error('搜索新闻失败:', err)
    } finally {
      this.loading = false
    }
  }

  /**
   * 清空搜索结果
   */
  clearSearch() {
    this.searchKeyword = ''
    this.searchResults = []
    this.error = ''
    this.hasSearched = false
  }



  build() {
    Column() {
      // 标题栏
      Row() {
        Button('取消')
          .fontSize(16)
          .fontColor('#333333')
          .backgroundColor('#ffffff')
          .borderRadius(0)
          .height(40)
          .onClick(() => {
            this.getUIContext().getRouter().back()
          })

        // 搜索框
        Row() {
          SymbolGlyph($r('sys.symbol.magnifyingglass'))
            .fontSize(20)
            .fontColor(['#999999'])

          TextInput({
            placeholder: '请输入搜索关键词',
            text: this.searchKeyword
          })
            .placeholderColor('#cccccc')
            .backgroundColor('#f5f5f5')
            .fontSize(16)
            .layoutWeight(1)
            .padding({ left: 8 })
            .onChange((value: string) => {
              this.searchKeyword = value
            })
            .onSubmit(() => {
              this.searchNews()
            })
        }
        .layoutWeight(1)
        .height(40)
        .backgroundColor('#f5f5f5')
        .borderRadius(20)
        .padding({ left: 16, right: 16 })

        Button('搜索')
          .fontSize(16)
          .fontColor('#007DFF')
          .backgroundColor('#ffffff')
          .borderRadius(0)
          .height(40)
          .onClick(() => {
            this.searchNews()
          })
      }
      .height(50)
      .backgroundColor('#ffffff')
      .borderRadius(0)
      .padding({ left: 10, right: 10 })


      // 内容区域
      if (this.loading) {
        Column() {
          Text('搜索中...')
            .fontSize(16)
            .fontColor('#999999')
        }
        .layoutWeight(1)
        .justifyContent(FlexAlign.Center)
      } else if (this.error) {
        Column() {
          Text(this.error)
            .fontSize(16)
            .fontColor('#ff0000')
            .margin({ bottom: 20 })

          Button('重新搜索')
            .onClick(() => {
              this.searchNews()
            })
        }
        .layoutWeight(1)
        .justifyContent(FlexAlign.Center)
        .padding(20)
      } else if (this.hasSearched && this.searchResults.length === 0) {
        Column() {
          Image($r('app.media.img_empty'))
            .width(140)

          Text('暂无搜索结果')
            .fontSize(14)
            .margin({ top: 16 })
            .fontColor('#999999')
        }
        .layoutWeight(1)
        .justifyContent(FlexAlign.Center)
        .padding(20)
      } else if (this.searchResults.length > 0) {
        // 搜索结果列表
        Column() {
          Row() {
            Text(`搜索结果 (${this.searchResults.length}条)`)
              .fontSize(14)
              .fontColor('#999999')
              .layoutWeight(1)

            Button('清空')
              .fontSize(14)
              .fontColor('#007DFF')
              .backgroundColor('#ffffff')
              .onClick(() => {
                this.clearSearch()
              })
          }
          .padding({
            left: 16,
            right: 16,
            top: 10,
            bottom: 10
          })

          Scroll() {
            Column() {
              ForEach(this.searchResults, (item: NewsInfo) => {
                NewsItemComponent({
                  newsInfo: item
                })
              })
              Blank().layoutWeight(1)
            }
          }
          .layoutWeight(1)
        }
      } else {
        // 默认状态 - 显示搜索提示
        Column() {
          SymbolGlyph($r('sys.symbol.magnifyingglass'))
            .fontSize(80)
            .fontColor(['#e0e0e0'])

          Text('请输入关键词搜索新闻')
            .fontSize(16)
            .fontColor('#999999')
            .margin({ top: 20 })
        }
        .layoutWeight(1)
        .justifyContent(FlexAlign.Center)
      }
    }
    .width('100%')
    .height('100%')
    .backgroundColor('#f5f5f5')
    .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.BOTTOM])
  }
}
6. 收藏功能
  • 实现位置: NewsDetailPage.ets 和 CollectListPage.ets
  • 功能流程:
    1. 在新闻详情页点击收藏按钮
    2. 调用 ApiConfig.FAVORITE_URL 接口
    3. 成功后更新收藏状态
    4. 在"我的收藏"页面可查看收藏列表
    5. 支持取消收藏功能
 /**
   * 处理收藏
   */
  async handleFavorite() {
    const res = await postForm(ApiConfig.FAVORITE_URL, {
      body: {
        "news_id": this.newsInfo.news_id,
        "user_id": this.userInfo!!.uid,
      }
    })

    if (res.success) {
      this.isFavorite = !this.isFavorite
    } else {
      this.getUIContext().getPromptAction().showToast({
        message: res.msg
      })
    }

  }
7. 收藏列表管理
  • 实现位置: CollectListPage.ets
  • 功能流程:
    1. 加载当前用户的收藏列表
    2. 调用 ApiConfig.QUERY_FAVORITE_URL 接口
    3. 使用列表形式展示收藏的新闻
    4. 支持左滑删除(取消收藏)功能
    5. 处理加载、错误和空数据状态
 /**
   * 加载收藏列表
   */
  async loadCollectList() {
    this.loading = true
    this.error = ''

    try {
      // 使用正确的收藏列表API
      const res = await get(ApiConfig.QUERY_FAVORITE_URL, {
        params: { "user_id": this.userInfo!!.uid }
      })

      if (res.success) {
        const newsRes = res.data as CollectRes
        this.collectList = newsRes.list || []
        this.hasData = this.collectList.length > 0
      } else {
        this.error = res.msg || '获取收藏列表失败'
      }
    } catch (err) {
      this.error = '网络请求失败,请稍后重试'
    } finally {
      this.loading = false
    }
  }
8. 视频播放
  • 实现位置: VideoComponent.ets, VideoPlayer.ets
  • 功能流程:
    1. 使用Swiper组件实现垂直视频轮播
    2. 基于AVPlayer实现视频播放
    3. 支持播放/暂停、进度控制
    4. 提供全屏播放模式
    5. 支持播放速度调整
@Component
export struct VideoComponent{
  @State curIndex: number = 0;
  @State isPageShow: boolean = false;
  private swiperController: SwiperController = new SwiperController();
  private windowUtil: WindowUtil = WindowUtil.getInstance();
  @StorageLink('isFullLandscapeScreen') isFullLandscapeScreen: boolean = false;

  aboutToAppear(): void {
    this.windowUtil.registerOnWindowSizeChange((size) => {
      if (size.width > size.height) {
        this.isFullLandscapeScreen = true;
      } else {
        this.isFullLandscapeScreen = false;
      }
    });

  }

  onPageShow(): void {
    this.isPageShow = true;
  }

  onPageHide(): void {
    this.isPageShow = false;
  }

  build() {
    Stack() {
      Column() {
        Stack() {
          // [Start Swiper]
          Swiper(this.swiperController) {
            LazyForEach(new AVDataSource(SOURCES), (item: VideoData, index: number) => {
              AVPlayerView({
                curSource: item,
                curIndex: this.curIndex,
                index: index,
                isPageShow: this.isPageShow
              })
                .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP])
            })
          }
          .cachedCount(3)
          .vertical(true)
          .loop(true)
          .curve(Curve.Ease)
          .duration(300)
          .indicator(false)
          .height('100%')
          .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP])
          .onAnimationStart((index: number, targetIndex: number, extraInfo: SwiperAnimationEvent) => {
            Logger.info("-------", `onAnimationStart index:${index} , targetIndex: ${targetIndex},extraInfo: ${extraInfo}`);
            this.curIndex = targetIndex;
            // key point: Animation starts updating index
          })

          // [End Swiper]
        }

        // [End Swiper]
      }
      .backgroundColor(Color.Black)
      .height('100%')
    }
    .backgroundColor(Color.Black)
    .height('100%')
    .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP])

  }
}

六、项目运行效果截图


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

搜索文章

Tags

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