XMPP Smack 4.1.0 rc1 ACCES(权限被拒绝)在 Android 上

Posted

技术标签:

【中文标题】XMPP Smack 4.1.0 rc1 ACCES(权限被拒绝)在 Android 上【英文标题】:XMPP Smack 4.1.0 rc1 ACCES (Permission denied) on Android 【发布时间】:2015-03-21 22:40:34 【问题描述】:

我正在尝试使用来自https://github.com/igniterealtime/Smack 的 Smack 4.1.0 rc1 进行 XMPP 连接 我按照本指南 https://github.com/igniterealtime/Smack/wiki/Smack-4.1-Readme-and-Upgrade-Guide 导入 Gradle。

源代码:

package com.example.xmpp_app;

import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.view.Menu;
import android.view.MenuItem;

import org.jivesoftware.smack.AbstractXMPPConnection;
import org.jivesoftware.smack.SmackException;
import org.jivesoftware.smack.XMPPException;
import org.jivesoftware.smack.tcp.XMPPTCPConnection;
import org.jivesoftware.smack.tcp.XMPPTCPConnectionConfiguration;

import java.io.IOException;

public class MainActivity extends ActionBarActivity 

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // Create the configuration for this new connection
        XMPPTCPConnectionConfiguration.Builder configBuilder = XMPPTCPConnectionConfiguration.builder();
        configBuilder.setUsernameAndPassword("test@example.com", "password123");
        configBuilder.setResource("test");
        configBuilder.setServiceName("127.0.0.1");

        AbstractXMPPConnection connection = new XMPPTCPConnection(configBuilder.build());
        // Connect to the server
        try 
            connection.connect();
         catch (SmackException e) 
            e.printStackTrace();
         catch (IOException e) 
            e.printStackTrace();
         catch (XMPPException e) 
            e.printStackTrace();
        
        // Log into the server
        try 
            connection.login();
         catch (XMPPException e) 
            e.printStackTrace();
         catch (SmackException e) 
            e.printStackTrace();
         catch (IOException e) 
            e.printStackTrace();
        

        // Disconnect from the server
        connection.disconnect();
    


    @Override
    public boolean onCreateOptionsMenu(Menu menu) 
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_main, menu);
        return true;
    

    @Override
    public boolean onOptionsItemSelected(MenuItem item) 
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) 
            return true;
        

        return super.onOptionsItemSelected(item);
    

分级:

// Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript 
    repositories 
        jcenter()
        maven 
            url 'https://oss.sonatype.org/content/repositories/snapshots'
        
        mavenCentral()
    
    dependencies 
        classpath 'com.android.tools.build:gradle:1.1.0'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    


allprojects 
    repositories 
        jcenter()
    

构建等级:

apply plugin: 'com.android.application'

android 
    compileSdkVersion 21
    buildToolsVersion "21.1.2"

    defaultConfig 
        applicationId "com.example.xmpp_app"
        minSdkVersion 15
        targetSdkVersion 21
        versionCode 1
        versionName "1.0"
    
    buildTypes 
        release 
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        
    


dependencies 
    compile fileTree(dir: 'libs', include: ['*.jar'])
    compile 'com.android.support:appcompat-v7:21.0.3'
    compile "org.igniterealtime.smack:smack-android:4.1.0-rc1"
    // Optional for XMPPTCPConnection
    compile "org.igniterealtime.smack:smack-tcp:4.1.0-rc1"
    // Optional for XMPP-IM (RFC 6121) support (Roster, Threaded Chats, …)
    compile "org.igniterealtime.smack:smack-im:4.1.0-rc1"
    // Optional for XMPP extensions support
    compile "org.igniterealtime.smack:smack-extensions:4.1.0-rc1"

错误:

我找到了一些如何请求互联网许可的指南,但我无法测试它,因为我现在不在家,我如何使用我的本地主机尝试它?当我尝试这个时,它说

Exception while resovling SRV records for 127.0.0.1. Consider adding '_xmpp-(server|client)._tcp' DNS SRV Records android.os.NetworkOnMainThreadException 

即使它仍然显示与前一个相同的错误消息

03-21 14:57:30.332 1176-1176/com.example.xmpp_app W/System.err﹕ org.jivesoftware.smack.SmackException$ConnectionException: The following addresses failed: '127.0.0.1:5222' failed because java.net.SocketException: socket failed: EACCES (Permission denied) 03-21 14:57:30.372 1176-1176/com.example.xmpp_app W/System.err﹕ at org.jivesoftware.smack.tcp.XMPPTCPConnection.connectUsingConfiguration(XMPPTCPCo‌​nnection.java:574

有人可以帮我解决这个问题吗?我只是想检查一下连接是否正常。

注意:我已经加了:<uses-permission android:name="android.permission.INTERNET" /> 在我的安卓清单上。

【问题讨论】:

android.os.NetworkOnMainThreadException 的可能副本 现在这是下一个错误:javax.net.ssl.SSLHandshakeException: java.security.cert.CertPathValidatorException: Trust anchor for certification path not found. 【参考方案1】:

您的问题是您在主线程中发出网络请求 这个网络调用会抛出一个android.os.NetworkOnMainThreadException 您必须使用 AsyncTask 或 java 中的简单线程创建一个单独的线程,然后调用 smack 来连接、登录并执行您对服务器的任何操作。

http://developer.android.com/reference/android/os/AsyncTask.html

【讨论】:

【参考方案2】:

你用的是安卓模拟器吗?如果你是 android 模拟器,你应该使用 10.0.2.2 作为 localhost。 127.0.0.1 是它自己的环回接口。 同时添加 INTERNET 权限

请看http://developer.android.com/tools/devices/emulator.html

【讨论】:

这是迟到的回复。但可以帮助其他读者解决他们的问题。【参考方案3】:

连接必须在后台线程中,像这样。

 AsyncTask.execute(new Runnable() 
            @Override
            public void run() 
                try 
                    getMainActivity().connection.connect().login();
                 catch (XMPPException e) 
                    e.printStackTrace();
                 catch (SmackException e) 
                    e.printStackTrace();
                 catch (IOException e) 
                    e.printStackTrace();
                

                Log.d(TAG, "onCreate: isConnected " + getMainActivity().connection.isConnected());
                Log.d(TAG, "onCreate: isAuthenticated " + getMainActivity().connection.isAuthenticated());
            
        );

【讨论】:

以上是关于XMPP Smack 4.1.0 rc1 ACCES(权限被拒绝)在 Android 上的主要内容,如果未能解决你的问题,请参考以下文章

smack 使用 4.1.0 rc1 在 muc 中接收消息

使用 Smack 4.1.0 的 GCM XMPP 服务器 - 需要添加哪些 jar

XMPP Smack 4.1.0 检查用户是不是已经注册

当使用 Smack 4.1.0 API 作为 Google 的 GCM CCS 的 XMPP 客户端时,SecurityMode.required 不起作用

android中的XMPP连接使用smack

添加增强调试器以查看基于 Smack android 的 XMPP 客户端的数据包级别信息