当前位置: 首页 > backend >正文

网页端调用本地应用打开本地文件(PDF、Word、excel、PPT)

一、背景原因

        根据浏览器的安全策略,在网页端无法直接打开本地文件,所以需要开发者曲线救国。

二、实现步骤

        前期准备:

                确保已安装好可以打开文件的应用软件,如,WPS;

                把要打开的文件统一放在一个文件夹,如,在D盘创建文件夹【文件夹名】。

1. 创建Windows应用程序—callexe

namespace callexe
{static class Program{/// <summary>/// 应用程序的主入口点。/// </summary>[STAThread]static void Main(string[] args){Application.EnableVisualStyles();Application.SetCompatibleTextRenderingDefault(false);string strNew = args[0].Substring(10);string utoSs = System.Web.HttpUtility.UrlDecode(strNew);// 直接打开目录string v_OpenFolderPath1 = @"D:/文件夹名/";string v_OpenFolderPath = string.Concat(v_OpenFolderPath1, utoSs);// 直接打开指定的文件System.Diagnostics.Process.Start(v_OpenFolderPath);Application.Exit();}}
}

2. 创建openfile.reg文件。

    为了方便编辑文件,先创建openfile.txt文件,编辑完成后修改文件后缀为.reg,然后双击打开。

   .reg:windows操作系统的注册表脚本文件。

   创建open-exe文件夹并放在D盘,把callexe文件和openfile.reg放在open-exe里面。

Windows Registry Editor Version 5.00
[HKEY_CLASSES_ROOT\OPENFILE]
@="URL:OPENFILE"
"URL Protocol"="D:\\open-exe\\callexe\\bin\\Debug\\callexe.exe"
[HKEY_CLASSES_ROOT\OPENFILE\DefaultIcon]
@="D:\\open-exe\\callexe\\bin\\Debug\\callexe.exe,1"
[HKEY_CLASSES_ROOT\OPENFILE\shell]
[HKEY_CLASSES_ROOT\OPENFILE\shell\open]
[HKEY_CLASSES_ROOT\OPENFILE\shell\open\command]
@="D:\\open-exe\\callexe\\bin\\Debug\\callexe.exe %1"

3. 在前端调用

window.open("crealife1:xxx.pdf");

具体原理以后慢慢补充。

http://www.xdnf.cn/news/95.html

相关文章:

  • day31和day32图像处理OpenCV
  • 数据通信学习笔记之OSPF配置命令
  • 大数据应用开发——大数据平台集群部署
  • 数据结构——二叉树
  • GB28181的SIP注册与PS推流学习
  • 常用绑定事件方式有哪几种
  • Spring AI与通义千问的完美结合:构建智能对话应用
  • 【OSG学习笔记】Day 3: 加载你的第一个3D模型
  • C++每日训练 Day 16:构建 GUI 响应式信号机制(面向初学者)
  • Linux 文件传输:系统数据交互的动脉
  • 【Leetcode 每日一题 - 补卡】2537. 统计好子数组的数目
  • Flink-01学习 介绍Flink及上手小项目之词频统计
  • GPT对话UI--通义千问API
  • Linux 权限
  • 2025.4.17学习日记 初识JavaScript 以及Java和JavaScript有什么区别
  • 什么是分布式锁?
  • Linux: 生产者消费者模型
  • 从零开始学A2A四:A2A 协议的安全性与多模态支持
  • 多个路由器互通(静态路由)无单臂路由(简单版)
  • STM32 时钟树
  • TCP连接建立:为什么是三次握手?
  • 正则表达式在爬虫中的应用:匹配 HTML 和 JSON 的技巧
  • 操作教程|通过DataEase制作MaxKB系统数据大屏
  • QML之Overlay
  • R4打卡——pytorch实现LSTM预测火灾
  • 《vue3学习手记4》
  • openai发布今天发布了o3和o4-mini。
  • Vue 3 reactive 和 ref 区别及 失去响应性问题
  • 大数据常见的模型定义及应用场景建议╮(╯▽╰)╭
  • 深入理解常见排序算法:从原理到实践