otr4j主要接口简介

本文介绍了otr4j中三个核心接口:OtrEngine、OtrEngineHost和OtrKeyManager的定义与作用。OtrEngine负责管理加密会话、加密解密等;OtrEngineHost为OtrEngine提供必要的功能支持;OtrKeyManager则专注于密钥管理和验证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

otr4j定义了3个主要接口,OtrEngine,OtrKeyManager和OtrEngineHost。 

OtrEngine  

定义: 
public interface OtrEngine { 

        public String transformReceiving(SessionID sessionID, String content); 
        public String transformSending(SessionID sessionID, String content); 
        
        public void startSession(SessionID sessionID); 
        public void endSession(SessionID sessionID); 
        public void refreshSession(SessionID sessionID); 
        
        public void addOtrEngineListener(OtrEngineListener l); 
        public void removeOtrEngineListener(OtrEngineListener l); 
        public SessionStatus getSessionStatus(SessionID sessionID); 
        
        public PublicKey getRemotePublicKey(SessionID sessionID); 

OtrEngine定义Off-the-Record 功能,OtrEngineImpl是一个OtrEngine的实现。主要用于: 
1、管理加密会话(startSession, endSession, refreshSession) 
2、加密输出,解密输入(transformSending, transformReceiving) 
3、获取会话状态 (getSessionStatus) 通知会话状态的改变 (通过OtrEngineListener). 


OtrEngineHost  

定义: 
public interface OtrEngineHost { 
        public void injectMessage(SessionID sessionID, String msg); 
        public void showWarning(SessionID sessionID, String warning); 
        public void showError(SessionID sessionID, String error); 
        public OtrPolicy getSessionPolicy(SessionID sessionID); 
        public KeyPair getKeyPair(SessionID sessionID); 

OtrEngineHost定义主程序必须提供给OtrEngine的功能。OtrEngineHost作为一个参数传递给OtrEngineImpl构造器。OtrEngineHost被OtrEngine用来: 
1、注入消息,例如在认证密钥交换 
2、通知主程序警告和错误 
3、获取Off-the-Record会话政策 
4、获取长会话密钥对。在此方法的实现中你要调用OtrKeyManager.loadLocalKeyPair(),并且如果返回null,调用OtrKeyManager.generateLocalKeyPair()。 


OtrKeyManager  

定义: 
public interface OtrKeyManager { 

        public void addListener(OtrKeyManagerListener l); 
        public void removeListener(OtrKeyManagerListener l); 
        public void verify(SessionID sessionID); 
        public void unverify(SessionID sessionID); 
        public boolean isVerified(SessionID sessionID); 
        
        public String getRemoteFingerprint(SessionID sessionID); 
        public String getLocalFingerprint(SessionID sessionID); 
        
        public void savePublicKey(SessionID sessionID, PublicKey pubKey); 
        public void generateLocalKeyPair(SessionID sessionID); 
        
        public PublicKey loadRemotePublicKey(SessionID sessionID); 
        public KeyPair loadLocalKeyPair(SessionID sessionID); 

OtrKeyManager定义key管理功能。OtrKeymanagerImpl是OtrKeyManager的一个实现。它完全解耦与OtrEngine,所以你可以实现一个替代的OtrKeyManager,用于通过特殊的方式加载或存储keys。 
它用来: 
1、确认/取消验证会话(通过各自的方法) 
2、获取会话的验证状态(isVerified),并且告知有关验证状态的改变(通过OtrKeyManagerListener) 
3、获取指纹用于主 应用程序 显示(getRemoteFingerprint, getLocalFingerprint) 
4、保存远程各方公钥。主应用程序有一个加密的会话状态发生变化时,调用此方法。(这是可以改善的,公共密钥的保存不应该是主应用程序的责任)。 
5、装入本地密钥对,或产生新的密钥对(这通常是在OtrEngineHost.getKeyPair()中进行,如上面所述)。 
6、加载远程公共密钥。当一个加密的会话进行时,主应用程序将要检查是否远程公共密钥等于由OtrKeyManager存储的,如果是,检查该密钥是否被验证。 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值