博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
让delphi解析chrome扩展的native应用
阅读量:5261 次
发布时间:2019-06-14

本文共 1804 字,大约阅读时间需要 6 分钟。

chrome浏览器自从去年以来逐步去掉了对浏览器插件的支持,npapi的方案马上不可用。 当务之急要选择一个替代方案,最常用的就是扩展了。扩展程序提供了一套和本地程序交互的方案——“原生消息通信”

写本地应用的工具和语言很多,比如:C#,C++,phyon 都可以,本人对delphi熟悉一点,就说说delphi怎么接收和发送消息的吧。

Chrome扩展对原生消息通信有非常明确的说明

Chrome 浏览器在单独的进程中启动每一个原生消息通信宿主,并使用标准输入(stdin)与标准输出(stdout)与之通信。向两个方向发送消息时使用相同的格式:每一条消息使用 JSON 序列化,以 UTF-8 编码,并在前面附加 32 位的消息长度(使用本机字节顺序)。

 

怎么做呢? 

1、background.js中定义消息

var nativeHostName='com.xxx.mytest';//chrome与本地程序通信的桥梁,根据该名称进行配置项的寻找。windows下在注册表HKEY_CURRENT_USER\Software\Google\Chrome\NativeMessagingHosts内寻找,linux下在目录/etc/opt/chrome/native-messaging-hosts/寻找该名称的json文件()  //native startchrome.runtime.sendNativeMessage(nativeHostName,jsonData, function(response){    if (chrome.runtime.lastError){        console.log("lastError:" + chrome.runtime.lastError.message);    }    else{        console.log("recieved message: ", response.message);    }});

 

2、新建一个Delphi控制台程序,添加标出输入和标准输出接口即可

  接收数据的标准输入

function ReadInputJson():WideString;var     strmInput: THandleStream;    LBuffer: TBytes;    resLen:Integer;    sData: string;begin    strmInput := THandleStream.Create(GetStdHandle(STD_INPUT_HANDLE));    try        SetLength(LBuffer, 4);        strmInput.ReadBuffer(Pointer(LBuffer)^,4);        resLen:= PInteger(LBuffer)^;        SetLength(sData, resLen);        strmInput.Read(sData[1], resLen);        Result := UTF8Decode(sData);    finally       strmInput.Free;    end;    end;

 

  返回数据的标准输出

procedure WriteOutputJson(const str:String);var strmOut: THandleStream; len:Integer; json:String;begin    json:=UTF8Encode(str);    len:=Length(json);    strmOut := THandleStream.Create(GetStdHandle(STD_OUTPUT_HANDLE));    try      strmOut.Write(len,4);      strmOut.Write(PChar(json)^, len);    finally      strmOut.Free;    end;  end;

 

主要是处理UTF8编码和前32位长度,非常容易出错。

  

转载于:https://www.cnblogs.com/freeton/p/4801163.html

你可能感兴趣的文章
fish redux 个人理解
查看>>
java 笔记一些
查看>>
夜晚的岳麓山
查看>>
Struts2工作原理及流程
查看>>
Chrome(谷歌浏览器)不识别document.documentElement.scrollTop
查看>>
/Home/Tpl/Equipment/rangeIndex.html 里调用魔板
查看>>
创建本地索引和全局索引
查看>>
Oracle导出存储过程
查看>>
创建LIST分区
查看>>
一些规范(自用)
查看>>
记录SSD中的一些东西
查看>>
第二十一章 Django的分页与cookie
查看>>
表示一个文件的 File 类型
查看>>
ORA-01403:no data found 解决办法
查看>>
当 智能箭头 碰到 方向箭头 。。。。。。。
查看>>
巧妙运用ViewStub写出类似Tab选项卡(想怎么写tab就怎么写,横着写竖着写随你)(转)...
查看>>
WPF的2D图形化实现--WPF 集装箱堆场图形化实现实例
查看>>
(转)从零实现3D图像引擎:(10)Hello3DWorld
查看>>
C#中时间差的计算
查看>>
Mysql 常用命令
查看>>