集成环信客服 拉取欢迎语,注意哦,是欢迎语不是问候语

2023-10-25 07:20

本文主要是介绍集成环信客服 拉取欢迎语,注意哦,是欢迎语不是问候语,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

环信客服的问候语直接打开开关就可以,但是欢迎语需要自己去掉环信的接口获取。

 

获取欢迎语的思路是,通过环信的接口获取欢迎语,然后拿到欢迎语封装成一条消息,导入数据库中,刷新tableView即可。

具体的步骤:(先贴代码,具体看附件,先把附件的1,2步骤完成)

1.通过post请求先获取管理员的token

// 自己封装好一个方法 获取token  这里采用的是AFNetworking
+ (void)HXGetTokenWithReturnValeuBlock: (HXGetTokenSuccessBlock) successblock WithFailureBlock: (FailureBlock) failureBlock
{
    NSURL *url = [NSURL URLWithString:@"https://a1.easemob.com/下图中的“组织”/下图中的应用名称/token"];
    NSDictionary *body = @{@"grant_type":@"password",@"username": “手机app登录的用户名”,@"password":@"环信密码"};
    NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];
    [request setHTTPMethod:@"POST"];
    [request setHTTPBody:[[self DictionaryConversionJson:body] dataUsingEncoding:NSUTF8StringEncoding]];
    AFHTTPSessionManager *manager = [self manager];
    SKURLSessionTask *task = [manager dataTaskWithRequest:request completionHandler:^(NSURLResponse * _Nonnull response, id  _Nullable responseObject, NSError * _Nullable error) {

        if (responseObject==nil) {
            return;
        }
        id obj = [NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingMutableContainers error:nil];
        NSLog(@"服务器返回信息%@",obj);
        if (obj==nil) {
            return;
        }
        NSString* token = [obj safeJsonObjForKey:@"access_token"];
        successblock(token);
    }];
    [task resume];
}

+(NSString*)DictionaryConversionJson:(NSDictionary *)Dictionary
{
    NSError *parseError = nil;
    NSString *jsonStr = @"";
    if ([Dictionary isKindOfClass:[NSDictionary class]]){
        NSData *jsonData = [NSJSONSerialization dataWithJSONObject:Dictionary options:NSJSONWritingPrettyPrinted error:&parseError];
        jsonStr = [[NSString alloc]initWithData:jsonData encoding:NSUTF8StringEncoding];
    }
    
    return jsonStr;
}

 

2.获取token后,再去获取欢迎语

+ (void)HXGetWelComeStrWithToken:(NSString *)token ReturnValeuBlock: (HXGetTokenSuccessBlock) successblock WithFailureBlock: (FailureBlock) failureBlock;
{
    NSString *userName = USER_NAME;
    NSString *url = [NSString stringWithFormat:@"http://kefu.easemob.com/v1/tenantapi/welcome?tenantId=“填写tenantId”&orgName=“填写组织”&appName=“填写应用名称”&userName=%@&token=%@",userName,token];


    AFHTTPSessionManager *manager = [self manager];
    [manager GET:url parameters:@"" progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
        id obj = [[NSString alloc] initWithData:responseObject encoding:NSUTF8StringEncoding];
        NSLog(@"服务器返回信息%@",obj);
        successblock(obj);

    } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
        failureBlock(error.code);
    }];
}
3.获取到欢迎语后构造一条消息,我们的聊天界面采用的是环信的EaseMessageViewController

所以在viewDidLoad里面去构造这个消息

// 获取管理员的token
    [SKRequest HXGetTokenWithReturnValeuBlock:^(NSString *token) {
        //获取欢迎语
        [SKRequest HXGetWelComeStrWithToken:token ReturnValeuBlock:^(NSString *token) {
            
            EMTextMessageBody *body = [[EMTextMessageBody alloc] initWithText:token];
            NSString *from = [[EMClient sharedClient] currentUsername];
            //生成Message
            EMMessage *message = [[EMMessage alloc] initWithConversationID:@"填写IM服务号,注意全部小写" from:from to:@"填写IM服务号,注意全部小写" body:body ext:nil];
            message.chatType = EMChatTypeChat;// 设置为单聊消息
            message.status=EMMessageStatusSuccessed;
            message.direction = EMMessageDirectionReceive;
            EMConversation *conversation = [[EMClient sharedClient].chatManager getConversation:from  type:EMConversationTypeChat createIfNotExist:YES];
            [conversation insertMessage:message];
            
            [self.tableView reloadData];
            
        } WithFailureBlock:^(NSInteger errorCode) {
            
        }];
    } WithFailureBlock:^(NSInteger errorCode) {
        
    }];

4.完成

转载于:https://www.cnblogs.com/darren-chen/p/6552591.html

这篇关于集成环信客服 拉取欢迎语,注意哦,是欢迎语不是问候语的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/weixin_33826268/article/details/94548815
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/280951

相关文章

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

SpringBoot集成LiteFlow工作流引擎的完整指南

《SpringBoot集成LiteFlow工作流引擎的完整指南》LiteFlow作为一款国产轻量级规则引擎/流程引擎,以其零学习成本、高可扩展性和极致性能成为微服务架构下的理想选择,本文将详细讲解Sp... 目录一、LiteFlow核心优势二、SpringBoot集成实战三、高级特性应用1. 异步并行执行2

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

Java集成Onlyoffice的示例代码及场景分析

《Java集成Onlyoffice的示例代码及场景分析》:本文主要介绍Java集成Onlyoffice的示例代码及场景分析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 需求场景:实现文档的在线编辑,团队协作总结:两个接口 + 前端页面 + 配置项接口1:一个接口,将o

Swagger2与Springdoc集成与使用详解

《Swagger2与Springdoc集成与使用详解》:本文主要介绍Swagger2与Springdoc集成与使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1. 依赖配置2. 基础配置2.1 启用 Springdoc2.2 自定义 OpenAPI 信息3.