用Java+SSM+Vue2从零搭建一个医学影像Web系统(含Dicom文件处理全流程)

news2026/4/30 0:52:06
用JavaSSMVue2构建医学影像Web系统的实战指南医疗信息化浪潮下医学影像系统的开发需求日益增长。作为一名Java开发者如何快速搭建一个支持Dicom标准的轻量级PACS系统本文将带你从零开始逐步实现一个完整的医学影像Web解决方案。1. 环境准备与基础架构搭建在开始编码前合理的环境配置和架构设计是项目成功的关键。我们需要搭建一个支持Dicom协议处理的开发环境。1.1 开发环境配置首先确保你的开发机器满足以下基本要求JDK 1.8推荐使用OpenJDK 11Maven 3.6用于依赖管理MySQL 5.7存储系统元数据Redis 5.0用于缓存和会话管理Node.js 12前端Vue开发环境安装完成后创建一个标准的Maven多模块项目结构medical-imaging-system ├── ims-common # 公共模块 ├── ims-dao # 数据访问层 ├── ims-service # 业务逻辑层 ├── ims-web # Web控制层 └── ims-vue # 前端项目1.2 SSM框架集成在pom.xml中添加SSM核心依赖!-- Spring核心依赖 -- dependency groupIdorg.springframework/groupId artifactIdspring-context/artifactId version5.3.18/version /dependency !-- MyBatis -- dependency groupIdorg.mybatis/groupId artifactIdmybatis/artifactId version3.5.9/version /dependency !-- Spring MVC -- dependency groupIdorg.springframework/groupId artifactIdspring-webmvc/artifactId version5.3.18/version /dependency配置Spring的核心配置文件applicationContext.xml包括数据源、事务管理和MyBatis集成。2. Dicom服务器选型与集成Dicom协议是医学影像系统的核心我们需要选择合适的开源Dicom服务器作为基础。2.1 主流Dicom服务器对比服务器语言特点适用场景DCM4CHEEJava功能全面社区活跃企业级PACS系统OrthancC轻量级REST API友好小型研究项目ConquestDelphi配置简单Windows友好个人开发者DicoogleJava支持插件扩展需要定制的场景对于Java技术栈DCM4CHEE是最佳选择。它提供了完整的Dicom服务实现包括SCP/SCU、存储、查询/检索等功能。2.2 DCM4CHEE集成步骤下载DCM4CHEE工具包最新版本为5.30.0配置DICOM存储服务Storage SCP# 启动DCM4CHEE存储服务 ./bin/start-storescp.sh -b DICOM_RECEIVER:11112 --directory /data/dicom在Java项目中添加DCM4CHE依赖dependency groupIdorg.dcm4che/groupId artifactIddcm4che-core/artifactId version5.30.0/version /dependency实现Dicom文件接收服务Service public class DicomReceiverService { Value(${dicom.storage.path}) private String storagePath; public void receiveDicomFile(InputStream dicomStream, String fileName) { Path path Paths.get(storagePath, fileName); try { Files.copy(dicomStream, path, StandardCopyOption.REPLACE_EXISTING); // 解析Dicom文件元数据 parseDicomMetadata(path.toFile()); } catch (IOException e) { throw new RuntimeException(Dicom文件接收失败, e); } } private void parseDicomMetadata(File dicomFile) { // 使用DCM4CHE解析Dicom标签 DicomObject dicomObject null; try (DicomInputStream dis new DicomInputStream(dicomFile)) { dicomObject dis.readDicomObject(); String patientName dicomObject.getString(Tag.PatientName); String studyInstanceUID dicomObject.getString(Tag.StudyInstanceUID); // 存储元数据到数据库 saveToDatabase(patientName, studyInstanceUID, dicomFile.getAbsolutePath()); } catch (IOException e) { log.error(Dicom文件解析失败, e); } } }3. 后端核心功能实现医学影像系统的核心功能包括Dicom文件上传、解析、存储和检索。下面我们逐一实现这些功能。3.1 Dicom文件上传接口实现一个支持大文件上传的REST接口RestController RequestMapping(/api/dicom) public class DicomUploadController { PostMapping(/upload) public ResponseEntityString uploadDicomFile( RequestParam(file) MultipartFile file, RequestParam(value patientId, required false) String patientId) { if (file.isEmpty()) { return ResponseEntity.badRequest().body(请选择有效的Dicom文件); } try { String originalFilename file.getOriginalFilename(); String fileExtension originalFilename.substring(originalFilename.lastIndexOf(.)); if (!.dcm.equalsIgnoreCase(fileExtension)) { return ResponseEntity.badRequest().body(仅支持Dicom文件(.dcm)上传); } // 生成唯一文件名 String storageName UUID.randomUUID().toString() fileExtension; InputStream inputStream file.getInputStream(); // 调用Dicom接收服务 dicomReceiverService.receiveDicomFile(inputStream, storageName); return ResponseEntity.ok(Dicom文件上传成功); } catch (IOException e) { return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR) .body(文件上传失败: e.getMessage()); } } }3.2 Dicom元数据存储设计设计数据库表结构存储Dicom元数据CREATE TABLE patient ( id BIGINT PRIMARY KEY AUTO_INCREMENT, patient_id VARCHAR(64) NOT NULL, patient_name VARCHAR(128), patient_sex VARCHAR(16), patient_birth_date DATE, create_time DATETIME, UNIQUE KEY uk_patient_id (patient_id) ); CREATE TABLE study ( id BIGINT PRIMARY KEY AUTO_INCREMENT, study_instance_uid VARCHAR(128) NOT NULL, patient_id BIGINT NOT NULL, study_date DATE, study_description VARCHAR(255), referring_physician VARCHAR(128), create_time DATETIME, FOREIGN KEY (patient_id) REFERENCES patient(id), UNIQUE KEY uk_study_uid (study_instance_uid) ); CREATE TABLE series ( id BIGINT PRIMARY KEY AUTO_INCREMENT, series_instance_uid VARCHAR(128) NOT NULL, study_id BIGINT NOT NULL, modality VARCHAR(16), series_number INT, series_description VARCHAR(255), create_time DATETIME, FOREIGN KEY (study_id) REFERENCES study(id), UNIQUE KEY uk_series_uid (series_instance_uid) ); CREATE TABLE instance ( id BIGINT PRIMARY KEY AUTO_INCREMENT, sop_instance_uid VARCHAR(128) NOT NULL, series_id BIGINT NOT NULL, instance_number INT, file_path VARCHAR(512) NOT NULL, file_size BIGINT, create_time DATETIME, FOREIGN KEY (series_id) REFERENCES series(id), UNIQUE KEY uk_instance_uid (sop_instance_uid) );3.3 影像查询服务实现实现基于患者、检查、序列的多级查询接口Service public class DicomQueryServiceImpl implements DicomQueryService { Autowired private StudyMapper studyMapper; Override public PageInfoStudyVO queryStudies(StudyQueryDTO queryDTO, Pageable pageable) { PageHelper.startPage(pageable.getPageNumber(), pageable.getPageSize()); ListStudy studies studyMapper.selectByCondition(queryDTO); ListStudyVO studyVOs studies.stream() .map(this::convertToVO) .collect(Collectors.toList()); return new PageInfo(studyVOs); } private StudyVO convertToVO(Study study) { StudyVO vo new StudyVO(); vo.setStudyInstanceUid(study.getStudyInstanceUid()); vo.setStudyDate(study.getStudyDate()); vo.setStudyDescription(study.getStudyDescription()); // 查询关联的患者信息 Patient patient patientMapper.selectById(study.getPatientId()); vo.setPatientName(patient.getPatientName()); vo.setPatientId(patient.getPatientId()); // 查询关联的序列数量 int seriesCount seriesMapper.countByStudyId(study.getId()); vo.setSeriesCount(seriesCount); return vo; } }4. 前端影像查看器集成前端使用Vue2框架集成Cornerstone.js实现Dicom影像的渲染和操作。4.1 前端项目初始化创建Vue2项目并安装必要依赖vue create medical-imaging-viewer cd medical-imaging-viewer npm install cornerstone-core cornerstone-tools cornerstone-web-image-loader dicom-parser --save npm install axios vue-router vuex --save4.2 Cornerstone.js集成创建影像查看器组件template div classviewer-container div refviewport classviewport/div div classtoolbar button clickzoomIn放大/button button clickzoomOut缩小/button button clickreset重置/button button clickwindowLevel(40, 400)腹部预设/button /div /div /template script import * as cornerstone from cornerstone-core; import * as cornerstoneTools from cornerstone-tools; import * as cornerstoneWADOImageLoader from cornerstone-web-image-loader; export default { name: DicomViewer, props: { imageId: { type: String, required: true } }, mounted() { this.initCornerstone(); this.loadImage(this.imageId); }, methods: { initCornerstone() { const element this.$refs.viewport; // 配置WADO图像加载器 cornerstoneWADOImageLoader.external.cornerstone cornerstone; cornerstoneWADOImageLoader.configure({ webWorkerPath: /static/cornerstoneWADOImageLoaderWebWorker.js, taskConfiguration: { decodeTask: { codecsPath: /static/cornerstoneWADOImageLoaderCodecs.js } } }); // 启用工具 cornerstoneTools.init(); // 添加工具 cornerstoneTools.addTool(cornerstoneTools.ZoomTool); cornerstoneTools.addTool(cornerstoneTools.WindowLevelTool); cornerstoneTools.addTool(cornerstoneTools.PanTool); // 启用元素 cornerstone.enable(element); }, async loadImage(imageId) { const element this.$refs.viewport; try { const image await cornerstone.loadImage(imageId); cornerstone.displayImage(element, image); // 激活工具 cornerstoneTools.setToolActive(Zoom, { mouseButtonMask: 1 }); cornerstoneTools.setToolActive(Pan, { mouseButtonMask: 2 }); cornerstoneTools.setToolActive(WindowLevel, { mouseButtonMask: 1 }); } catch (error) { console.error(图像加载失败:, error); } }, zoomIn() { cornerstoneTools.setToolActive(Zoom, { mouseButtonMask: 1 }); }, zoomOut() { cornerstoneTools.setToolActive(Zoom, { mouseButtonMask: 1, invert: true }); }, reset() { const element this.$refs.viewport; cornerstone.reset(element); }, windowLevel(windowWidth, windowCenter) { const element this.$refs.viewport; const viewport cornerstone.getViewport(element); viewport.voi.windowWidth windowWidth; viewport.voi.windowCenter windowCenter; cornerstone.setViewport(element, viewport); } } }; /script style scoped .viewer-container { width: 100%; height: 600px; position: relative; } .viewport { width: 100%; height: 100%; background-color: black; } .toolbar { position: absolute; top: 10px; left: 10px; z-index: 100; } /style4.3 前端与后端API集成创建API服务层与后端交互// src/api/dicom.js import axios from axios; const apiClient axios.create({ baseURL: process.env.VUE_APP_API_BASE_URL, timeout: 10000 }); export default { getStudies(page, size) { return apiClient.get(/api/studies, { params: { page, size } }); }, getSeries(studyInstanceUid) { return apiClient.get(/api/series, { params: { studyInstanceUid } }); }, getInstances(seriesInstanceUid) { return apiClient.get(/api/instances, { params: { seriesInstanceUid } }); }, getImageUrl(sopInstanceUid) { return ${process.env.VUE_APP_API_BASE_URL}/api/images/${sopInstanceUid}; }, uploadDicomFile(file, onUploadProgress) { const formData new FormData(); formData.append(file, file); return apiClient.post(/api/dicom/upload, formData, { headers: { Content-Type: multipart/form-data }, onUploadProgress }); } };5. 系统优化与性能调优一个实用的医学影像系统需要处理大量数据和高分辨率图像性能优化至关重要。5.1 大文件上传优化对于大型Dicom文件如CT/MRI序列需要优化上传过程分片上传将大文件分割为多个小块并行上传断点续传记录上传进度支持中断后继续上传压缩传输对Dicom文件进行无损压缩实现分片上传的前端代码async function uploadLargeFile(file, chunkSize 5 * 1024 * 1024) { const totalChunks Math.ceil(file.size / chunkSize); const fileMd5 await calculateFileMd5(file); // 计算文件MD5 // 检查服务器是否已有部分分片 const { uploadedChunks } await apiClient.get(/api/upload/status?md5${fileMd5}); for (let chunkIndex 0; chunkIndex totalChunks; chunkIndex) { if (uploadedChunks.includes(chunkIndex)) { continue; // 跳过已上传的分片 } const start chunkIndex * chunkSize; const end Math.min(start chunkSize, file.size); const chunk file.slice(start, end); const formData new FormData(); formData.append(file, chunk); formData.append(chunkIndex, chunkIndex); formData.append(totalChunks, totalChunks); formData.append(fileMd5, fileMd5); formData.append(fileName, file.name); try { await apiClient.post(/api/upload/chunk, formData); console.log(分片 ${chunkIndex 1}/${totalChunks} 上传成功); } catch (error) { console.error(分片 ${chunkIndex 1} 上传失败:, error); throw error; } } // 通知服务器合并分片 await apiClient.post(/api/upload/merge, { fileMd5, fileName: file.name, totalChunks }); }5.2 影像渲染性能优化前端影像渲染是性能瓶颈之一可采用以下优化策略多分辨率图像金字塔预先生成不同分辨率的图像渐进式加载先加载低分辨率图像再逐步提高质量Web Worker将图像解码放到后台线程内存管理及时释放不再使用的图像数据配置Cornerstone的图像缓存策略// 设置图像缓存大小单位MB cornerstone.imageCache.setMaximumSizeBytes(1024 * 1024 * 500); // 500MB // 配置缓存淘汰策略 cornerstone.imageCache.purgeCacheIfNecessary function() { // 当缓存达到上限时优先淘汰最久未使用的图像 while (this.getCacheSize() this.maximumSizeBytes) { const oldestImageId this.getCacheInfo()[0].imageId; this.removeImagePromise(oldestImageId); } };5.3 后端查询优化针对医学影像系统常见的查询场景进行优化索引优化确保患者ID、检查UID等关键字段有索引查询缓存对高频查询结果使用Redis缓存分页查询避免一次性加载大量数据Cacheable(value studyCache, key #queryDTO.hashCode()) public PageInfoStudyVO queryStudiesWithCache(StudyQueryDTO queryDTO, Pageable pageable) { return queryStudies(queryDTO, pageable); }6. 安全与权限控制医疗数据安全至关重要需要实现严格的安全控制措施。6.1 RBAC权限模型设计设计基于角色的访问控制系统CREATE TABLE user ( id BIGINT PRIMARY KEY AUTO_INCREMENT, username VARCHAR(64) NOT NULL, password VARCHAR(128) NOT NULL, enabled BOOLEAN DEFAULT TRUE, create_time DATETIME, UNIQUE KEY uk_username (username) ); CREATE TABLE role ( id BIGINT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(64) NOT NULL, description VARCHAR(255), create_time DATETIME, UNIQUE KEY uk_name (name) ); CREATE TABLE permission ( id BIGINT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(64) NOT NULL, resource VARCHAR(128) NOT NULL, action VARCHAR(32) NOT NULL, description VARCHAR(255), create_time DATETIME, UNIQUE KEY uk_resource_action (resource, action) ); CREATE TABLE user_role ( user_id BIGINT NOT NULL, role_id BIGINT NOT NULL, PRIMARY KEY (user_id, role_id), FOREIGN KEY (user_id) REFERENCES user(id), FOREIGN KEY (role_id) REFERENCES role(id) ); CREATE TABLE role_permission ( role_id BIGINT NOT NULL, permission_id BIGINT NOT NULL, PRIMARY KEY (role_id, permission_id), FOREIGN KEY (role_id) REFERENCES role(id), FOREIGN KEY (permission_id) REFERENCES permission(id) );6.2 Spring Security配置配置Spring Security实现权限控制Configuration EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { Autowired private UserDetailsService userDetailsService; Override protected void configure(HttpSecurity http) throws Exception { http .csrf().disable() .authorizeRequests() .antMatchers(/api/auth/**).permitAll() .antMatchers(/api/dicom/upload).hasAuthority(DICOM_UPLOAD) .antMatchers(/api/studies/**).hasAnyAuthority(STUDY_READ, RADIOLOGIST) .antMatchers(/api/images/**).hasAnyAuthority(IMAGE_VIEW, RADIOLOGIST) .anyRequest().authenticated() .and() .sessionManagement() .sessionCreationPolicy(SessionCreationPolicy.STATELESS) .and() .addFilterBefore(jwtAuthenticationFilter(), UsernamePasswordAuthenticationFilter.class); } Bean public JwtAuthenticationFilter jwtAuthenticationFilter() { return new JwtAuthenticationFilter(); } Bean public PasswordEncoder passwordEncoder() { return new BCryptPasswordEncoder(); } }6.3 数据脱敏与审计对敏感患者信息进行脱敏处理public class PatientDataMasker { private static final String MASK_CHAR *; public static String maskName(String name) { if (StringUtils.isEmpty(name)) { return name; } if (name.length() 1) { return MASK_CHAR; } if (name.length() 2) { return name.charAt(0) MASK_CHAR; } return name.charAt(0) MASK_CHAR.repeat(name.length() - 2) name.charAt(name.length() - 1); } public static String maskIdNumber(String idNumber) { if (StringUtils.isEmpty(idNumber) || idNumber.length() 8) { return idNumber; } return idNumber.substring(0, 3) MASK_CHAR.repeat(idNumber.length() - 6) idNumber.substring(idNumber.length() - 3); } }实现数据访问审计EntityListeners(AuditingEntityListener.class) MappedSuperclass public abstract class Auditable { CreatedBy Column(name created_by) private String createdBy; CreatedDate Column(name create_time) private LocalDateTime createTime; LastModifiedBy Column(name updated_by) private String updatedBy; LastModifiedDate Column(name update_time) private LocalDateTime updateTime; // getters and setters }7. 部署与运维系统开发完成后需要考虑如何部署和运维。7.1 容器化部署使用Docker容器化部署后端服务# Dockerfile for backend FROM openjdk:11-jre-slim WORKDIR /app COPY target/medical-imaging-system.jar app.jar EXPOSE 8080 ENTRYPOINT [java, -jar, app.jar]前端Dockerfile:# Dockerfile for frontend FROM nginx:alpine COPY dist /usr/share/nginx/html COPY nginx.conf /etc/nginx/conf.d/default.conf EXPOSE 80使用docker-compose编排服务version: 3 services: backend: build: ./backend ports: - 8080:8080 environment: - SPRING_PROFILES_ACTIVEprod - DB_URLjdbc:mysql://mysql:3306/medical_imaging - DB_USERroot - DB_PASSWORDpassword depends_on: - mysql - redis frontend: build: ./frontend ports: - 80:80 mysql: image: mysql:5.7 environment: - MYSQL_ROOT_PASSWORDpassword - MYSQL_DATABASEmedical_imaging volumes: - mysql_data:/var/lib/mysql redis: image: redis:6 ports: - 6379:6379 volumes: - redis_data:/data volumes: mysql_data: redis_data:7.2 监控与日志集成Spring Boot Actuator进行应用监控dependency groupIdorg.springframework.boot/groupId artifactIdspring-boot-starter-actuator/artifactId /dependency配置Prometheus监控management: endpoints: web: exposure: include: health,info,metrics,prometheus metrics: export: prometheus: enabled: true使用ELK收集和分析日志Configuration public class LoggingConfig { Bean public LogstashTcpSocketAppender logstashAppender() { LogstashTcpSocketAppender appender new LogstashTcpSocketAppender(); appender.setName(logstash); appender.setRemoteHost(logstash); appender.setPort(5000); appender.setEncoder(new LogstashEncoder()); return appender; } }7.3 备份与恢复策略制定Dicom文件的备份策略增量备份每天备份新增的Dicom文件全量备份每周执行一次完整备份异地备份每月将备份数据复制到异地存储实现自动备份脚本#!/bin/bash # 备份目录 BACKUP_DIR/backups/dicom DATE$(date %Y%m%d) # 创建备份目录 mkdir -p $BACKUP_DIR/$DATE # 备份数据库 mysqldump -u root -ppassword medical_imaging $BACKUP_DIR/$DATE/db.sql # 备份Dicom文件 rsync -avz /data/dicom/ $BACKUP_DIR/$DATE/dicom/ # 上传到云存储 aws s3 sync $BACKUP_DIR/$DATE s3://medical-imaging-backup/$DATE/ # 删除7天前的本地备份 find $BACKUP_DIR -type d -mtime 7 -exec rm -rf {} \;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2563373.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…