loadLibrary msc error:java.lang.UnsatisfiedLinkError: dlopen failed: library “libmsc.so” not found
解决这个坑还花了挺长时间的(可能是因为太菜了),特此记录一下。

**背景:**为了实现个机器人语音播报的小功能,集成了科大讯飞的 语音合成Android SDK。

**问题:**按照官方文档的描述进行集成后,结果一启动就报如下错误:

E/MscSpeechLog: loadLibrary msc error:java.lang.UnsatisfiedLinkError: dlopen failed: library "libmsc.so" not found
E/MscSpeechLog: init failed
W/System.err: 组件未安装.(错误码:21002)
        at com.iflytek.cloud.SpeechUtility.<init>(SourceFile:201)
W/System.err:     at com.iflytek.cloud.SpeechUtility.createUtility(SourceFile:140)
        at com.zj.smartbutler.application.BaseApplication.onCreate(BaseApplication.kt:28)
        at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1192)
W/System.err:     at android.app.ActivityThread.handleBindApplication(ActivityThread.java:6712)
        at android.app.ActivityThread.access$1300(ActivityThread.java:237)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1913)
        at android.os.Handler.dispatchMessage(Handler.java:106)
W/System.err:     at android.os.Looper.loop(Looper.java:223)
        at android.app.ActivityThread.main(ActivityThread.java:7656)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
W/System.err:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947) 


这个问题会导致SDK初始化失败:

// 初始化Speech

SpeechUtility.createUtility(
    this, "${SpeechConstant.APPID}=${Constants.VOICE_APP_ID}"
) 


从而导致执行这句代码时报空指针异常:

mTts = SpeechSynthesizer.createSynthesizer(activity, mTtsInitListener)
1.
于是在网上搜罗了一番解决方案,基本都是说把 .so 文件目录放到 src/main/jniLibs 下,或者放到app/libs下,然后在 build.gradle 中配置 sourceSets。然而,我都尝试了一遍并没有解决这个问题。

解决方式
找了半天原因,结果是因为我使用的模拟器是x86的,但科大讯飞的语音合成只支持arm,并且我在ndk中配置了x86。错误配置如下:

android {
    ...

    defaultConfig {
        ...

        ndk {
            // 设置支持的SO库架构
            abiFilters 'armeabi', 'armeabi-v7a', 'arm64-v8a', 'x86_64', 'x86'
        }
    }

    ...
} 


将x86相关的配置删除后,如下,再次启动就没问题了:

android {
    ...

    defaultConfig {
        ...

        ndk {
            // 设置支持的SO库架构
            abiFilters 'armeabi', 'armeabi-v7a', 'arm64-v8a'
        }
    }

    ...
}


-----------------------------------
©著作权归作者所有:来自51CTO博客作者ZeroOne01的原创作品,请联系作者获取转载授权,否则将追究法律责任
集成科大讯飞语音合成Android SDK遇到的坑
https://blog.51cto.com/zero01/2622074

com.iflytek.cloud.a.c.c occur Error = 本地引擎错误.(错误码:20021)

Logo

技术共进,成长同行——讯飞AI开发者社区

更多推荐