【JCEF】JS与JAVA进行交互

简介: 【JCEF】JS与JAVA进行交互

前言

之前介绍了JCEF的可用性,经过几天的摸索,有了一个初步的理解并尝试着运行测试案例

一:介绍

在传统的Web开发中,前后端连接通常是通过以下方式实现的:

HTTP请求: 前端通过HTTP请求向后端发送请求,后端处理请求并返回数据。这可以是常规的GET请求、POST请求等。前端通常使用JavaScript或其他前端框架来发起这些请求。

API(应用程序编程接口): 后端提供一组API,这些API定义了前端可以调用的功能和数据。前端通过HTTP请求调用这些API来获取或发送数据。API可以返回数据,如JSON或XML格式的信息。

WebSocket: WebSocket是一种双向通信协议,允许前后端实时交换数据。与传统的HTTP请求不同,WebSocket连接保持打开状态,允许双方在任何时候都能发送和接收数据。

二:开始

JCEF(Java Chromium Embedded Framework)是一个将Chromium嵌入到Java应用程序中的框架,使您可以在Java应用程序中嵌入一个完整的浏览器引擎。JCEF提供了一种在Java应用程序中展示网页内容的方式,并且允许您在Java和JavaScript之间进行交互。下面是一个简单的示例,展示如何在JCEF中实现Java和JavaScript之间的交互:

首先,您需要设置JCEF的开发环境。这涉及到引入JCEF的库和配置,这里简单介绍一下步骤:

下载JCEF的库文件,并将它们添加到您的Java项目中。

配置JCEF的运行参数,主要是设置Chromium本地库的路径。

初始化JCEF框架,启动Chromium引擎。

创建JFrame或JPanel来嵌入JCEF组件,以展示网页内容。

以下是一个简化的示例,展示如何在JCEF中实现Java和JavaScript之间的交互:

1. import org.cef.CefApp;
2. import org.cef.CefClient;
3. import org.cef.CefSettings;
4. import org.cef.browser.CefBrowser;
5. import org.cef.handler.CefAppHandlerAdapter;
6. import org.cef.handler.CefLoadHandlerAdapter;
7. import org.cef.handler.CefMessageRouterHandlerAdapter;
8. import org.cef.handler.CefRequestHandlerAdapter;
9. 
10. import javax.swing.*;
11. 
12. public class JCEFExample {
13. public static void main(String[] args) {
14.         CefApp.addAppHandler(new CefAppHandlerAdapter(args));
15. CefSettings settings = new CefSettings();
16. CefApp cefApp = CefApp.getInstance(args, settings);
17. 
18.         SwingUtilities.invokeLater(() -> {
19. JFrame frame = new JFrame("JCEF Example");
20.             frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
21. 
22. CefClient client = cefApp.createClient();
23. CefBrowser browser = client.createBrowser("https://www.example.com", false, false);
24. 
25.             frame.getContentPane().add(browser.getUIComponent());
26. 
27.             frame.setSize(800, 600);
28.             frame.setVisible(true);
29.         });
30.     }
31. }

上述代码创建了一个简单的JCEF应用程序窗口,并在窗口中展示了一个网页。接下来,让我们看一下如何在JavaScript和Java之间进行交互。

在JCEF中,要实现JavaScript和Java之间的交互,您可以使用CefMessageRouter。

下面是一个简单的示例:

1. import org.cef.browser.CefBrowser;
2. import org.cef.callback.CefQueryCallback;
3. import org.cef.handler.CefMessageRouterHandlerAdapter;
4. 
5. public class JCEFMessageRouterHandler extends CefMessageRouterHandlerAdapter {
6. @Override
7.     public boolean onQuery(CefBrowser browser, long queryId, String request, boolean persistent, CefQueryCallback callback) {
8. if (request.equals("getJavaData")) {
9. String javaData = "This data is from Java";
10.             callback.success(javaData);
11. return true;
12.         }
13. return false;
14.     }
15. }

在上述代码中,我们创建了一个CefMessageRouterHandlerAdapter的子类,重写了onQuery方法来处理来自JavaScript的查询。当JavaScript代码中调用cefQuery并传递"getJavaData"时,Java代码会返回一段数据。

然后,您需要在之前的示例中将这个JCEFMessageRouterHandler注册到CefMessageRouter中。这样,您就可以在JavaScript中使用cefQuery来与Java进行交互了。

JavaScript代码示例:

1. // 在JavaScript中调用Java方法并获取返回值
2. cefQuery({
3.     request: "getJavaData",
4.     onSuccess: function(response) {
5.         console.log("Data from Java: " + response);
6.     },
7.     onFailure: function(errorCode, errorMessage) {
8.         console.error("Java query failed: " + errorCode + " - " + errorMessage);
9.     }
10. });

总结

JCEF使得在Java应用程序中嵌入Chromium引擎成为可能,并且通过使用CefMessageRouter,您可以在Java和JavaScript之间实现双向的交互。请注意,实际开发中需要更多的配置和处理,这里只是一个简化的示例

相关文章
|
人工智能 JavaScript 关系型数据库
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
476 14
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
|
前端开发 JavaScript Java
【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
610 13
【03】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架搭建-服务端-后台管理-整体搭建-优雅草卓伊凡商业项目实战
|
SQL JavaScript 安全
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
548 11
【04】Java+若依+vue.js技术栈实现钱包积分管理系统项目-若依框架二次开发准备工作-以及建立初步后端目录菜单列-优雅草卓伊凡商业项目实战
|
人工智能 JavaScript 安全
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
646 13
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
|
监控 前端开发 Java
构建高效Java后端与前端交互的定时任务调度系统
通过以上步骤,我们构建了一个高效的Java后端与前端交互的定时任务调度系统。该系统使用Spring Boot作为后端框架,Quartz作为任务调度器,并通过前端界面实现用户交互。此系统可以应用于各种需要定时任务调度的业务场景,如数据同步、报告生成和系统监控等。
629 9
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
3706 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
694 5
|
JSON 前端开发 JavaScript
聊聊 Go 语言中的 JSON 序列化与 js 前端交互类型失真问题
在Web开发中,后端与前端的数据交换常使用JSON格式,但JavaScript的数字类型仅能安全处理-2^53到2^53间的整数,超出此范围会导致精度丢失。本文通过Go语言的`encoding/json`包,介绍如何通过将大整数以字符串形式序列化和反序列化,有效解决这一问题,确保前后端数据交换的准确性。
413 4
|
开发框架 JavaScript 前端开发
HarmonyOS UI开发:掌握ArkUI(包括Java UI和JS UI)进行界面开发
【10月更文挑战第22天】随着科技发展,操作系统呈现多元化趋势。华为推出的HarmonyOS以其全场景、多设备特性备受关注。本文介绍HarmonyOS的UI开发框架ArkUI,探讨Java UI和JS UI两种开发方式。Java UI适合复杂界面开发,性能较高;JS UI适合快速开发简单界面,跨平台性好。掌握ArkUI可高效打造符合用户需求的界面。
664 8
|
设计模式 前端开发 JavaScript
揭秘!前端大牛们如何巧妙利用JavaScript,打造智能交互体验!
【10月更文挑战第30天】前端开发领域充满了无限可能与创意,JavaScript作为核心语言,凭借强大的功能和灵活性,成为打造智能交互体验的重要工具。本文介绍前端大牛如何利用JavaScript实现平滑滚动、复杂动画、实时数据更新和智能表单验证等效果,展示了JavaScript的多样性和强大能力。
372 4