当前位置: 首页 > 知识库问答 >
问题:

Cisco交换机使用Android java应用程序的Telnet客户端

蓬野
2023-03-14

我正在尝试使用apache.commons.net.telnet为思科交换机(2960)编写一个Android应用程序作为telnet客户端。但我的联系有问题。在android模拟器上没有显示输出,但ConnectBot运行在同一模拟器上,并且可以完美地telnet到交换机。下面是代码示例:

mainactivity.java

package com.example.android2switch;

import java.io.IOException;
import java.net.SocketException;
import java.util.ArrayList;

import org.apache.commons.net.telnet.EchoOptionHandler;
import org.apache.commons.net.telnet.InvalidTelnetOptionException;
import org.apache.commons.net.telnet.SuppressGAOptionHandler;
import org.apache.commons.net.telnet.TelnetClient;
import org.apache.commons.net.telnet.TelnetOptionHandler;
import org.apache.commons.net.telnet.TerminalTypeOptionHandler;

import android.app.Activity;
import android.os.Bundle;
import android.text.Editable;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.view.View;

public class MainActivity extends Activity {

    Button button;
    TextView textview;
    EditText edit1;
    Editable server;
    static TelnetClient telnetClient = new TelnetClient();

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

        Button b1=(Button)findViewById(R.id.button1);
        b1.setOnClickListener(new View.OnClickListener() {
            public void onClick(View v) {
                try {
                    setOptionHandlers();
                    //telnetClient.connect("192.168.0.1");
                    edit1 = (EditText)findViewById(R.id.edit1);
                    server = edit1.getEditableText();
                    telnetClient.connect(server.toString());

                    read();
                    telnetClient.disconnect();
                } catch (SocketException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }   
              }});      
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.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();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

    private static void setOptionHandlers() throws IOException {
        ArrayList<TelnetOptionHandler> optionHandlers = new ArrayList<TelnetOptionHandler>();
        optionHandlers.add(new TerminalTypeOptionHandler("VT100", false, false, true, false));
        optionHandlers.add(new EchoOptionHandler(true, false, true, false));
        optionHandlers.add(new SuppressGAOptionHandler(true, true, true, true));
        for (TelnetOptionHandler handler : optionHandlers) {
            try {
                telnetClient.addOptionHandler(handler);
            }
            catch (InvalidTelnetOptionException e) {
                System.err.println("Error registering option handler " + handler.getClass().getSimpleName());
            }
        }
    }

    public static void write(byte[] data) throws IOException {
        telnetClient.getOutputStream().write(data);
        telnetClient.getOutputStream().flush();
    }

    public void read() throws IOException {

        TextView tv1=(TextView)findViewById(R.id.textView1);
        tv1.setText("Read");
        byte[] buff = new byte[1024];
        int read;
        if((read = telnetClient.getInputStream().read(buff)) > 0) {
            tv1.append(new String(buff));
        }
        tv1.append("read="+read);
    }

}

activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" 
tools:context="com.example.android2switch.MainActivity" >

<EditText
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:id="@+id/edit1"
android:hint="Command"
android:text="ip address" />
<Button
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:text="Run Program"
android:id="@+id/button1" />
<ScrollView
android:id="@+id/scrollView1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >

<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
 />

</LinearLayout>
</ScrollView>
</LinearLayout>
06-10 00:35:52.976: E/Trace(1938): error opening trace file: No such file or directory (2)
06-10 00:35:53.716: D/libEGL(1938): loaded /system/lib/egl/libEGL_emulation.so
06-10 00:35:53.716: D/libEGL(1938): loaded /system/lib/egl/libGLESv1_CM_emulation.so
06-10 00:35:53.716: D/libEGL(1938): loaded /system/lib/egl/libGLESv2_emulation.so
06-10 00:35:53.726: D/(1938): HostConnection::get() New Host Connection established 0xb8c6d868, tid 1938
06-10 00:35:53.887: W/EGL_emulation(1938): eglSurfaceAttrib not implemented
06-10 00:35:53.906: D/OpenGLRenderer(1938): Enabling debug mode 0
06-10 00:36:26.367: W/EGL_emulation(1938): eglSurfaceAttrib not implemented
06-10 00:36:39.556: D/AndroidRuntime(1938): Shutting down VM
06-10 00:36:39.556: W/dalvikvm(1938): threadid=1: thread exiting with uncaught exception (group=0xb3df9288)
06-10 00:36:39.616: E/AndroidRuntime(1938): FATAL EXCEPTION: main
06-10 00:36:39.616: E/AndroidRuntime(1938): android.os.NetworkOnMainThreadException
06-10 00:36:39.616: E/AndroidRuntime(1938):     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at libcore.io.IoBridge.connect(IoBridge.java:112)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at java.net.Socket.connect(Socket.java:842)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at org.apache.commons.net.SocketClient.connect(SocketClient.java:182)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at org.apache.commons.net.SocketClient.connect(SocketClient.java:203)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at org.apache.commons.net.SocketClient.connect(SocketClient.java:296)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at com.example.android2switch.MainActivity$1.onClick(MainActivity.java:45)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at android.view.View.performClick(View.java:4084)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at android.view.View$PerformClick.run(View.java:16966)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at android.os.Handler.handleCallback(Handler.java:615)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at android.os.Handler.dispatchMessage(Handler.java:92)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at android.os.Looper.loop(Looper.java:137)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at android.app.ActivityThread.main(ActivityThread.java:4745)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at java.lang.reflect.Method.invokeNative(Native Method)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at java.lang.reflect.Method.invoke(Method.java:511)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
06-10 00:36:39.616: E/AndroidRuntime(1938):     at dalvik.system.NativeStart.main(Native Method)

我对Android开发(Eclipse Luna)是全新的,我找不到任何用于cisco交换机/路由器的Android base telnet客户端的参考/示例。任何参考资料,示例代码或指导将非常感谢,谢谢!

共有1个答案

颜镜
2023-03-14

是否向清单文件添加了正确的权限?确保您添加了允许应用程序打开网络套接字的权限。

"<uses-permission android:name="android.permission.INTERNET"/>

有关详细信息,请参阅此处:http://developer.android.com/reference/android/manifest.permission.html

同样,这里也解决了类似的问题:错误消息“java.net.socketexception:socket failed:EACCES(权限被拒绝)”

 类似资料:
  • 我使用这个代码https://gist.github.com/svett/b7f56afc966a6b6ac2fc作为起点。 使用它并将其指向cisco路由器会得到以下错误消息: 所以我又说: 到我的ssh.clientconfig,我得到了一个不同的错误: 拨号失败:SSH:握手失败:SSH:主机密钥没有通用算法;提供的客户端:[aes128cbcID],提供的服务器:[ssh-rsa] 这基本

  • 我需要编写一个基于桌面的客户端应用程序,它在进行基于SAML的SSO身份验证后对SharePoint服务器进行一些Web服务方法调用。 我发现SAML SSO主要用于处理所有细节的浏览器。根据这个问题,SAML 2.0中似乎有一种技术称为ECP,专门用于启用非基于浏览器的客户端。 然而,SharePoint 2010/2013等一些应用程序仅支持SAML 1.1;在这种情况下可以使用什么?

  • 我需要一个用于java spring应用程序的graphQL客户端,以与另一个基于graphQL API的微服务通信。我知道Apollo Android,但它似乎没有用maven实现(也许你知道maven的一些链接或示例等)。有什么想法和建议吗?提前感谢!

  • 问题内容: 我已经阅读了很多有关该主题的内容,telnet是一种协议,而不是简单的套接字连接,正在等待换行符,使用外部库等等。 最重要的是,我需要启动并运行一个快速且肮脏的Java telnet应用程序,它不一定可扩展且不一定漂亮,因此我试图避免使用库,系统函数调用等。我一直在尝试和测试,到目前为止,当尝试登录路由器(当然是通过telnet)时,我什么都没有。 这是到目前为止我一直在使用的代码的一

  • 我想在java上创建一个客户机/服务器应用程序,服务器的IP地址为192.168.1.100,在端口4500上等待客户机请求。 客户端从键盘上读取字符串,向服务器发送连接请求。一旦建立了连接,它就会将字符串发送到服务器。 这是我尝试的代码: 对于服务者: 对于客户端: 但这段代码有一个问题: