Tarun Kumar
Tarun Kumar

Reputation: 3

Permission check failed in J2ME Socket program

I want communication through socket between My Computer host(Server) and A Raspberry pi board(Client). I am using following code:

For Server

 public void startApp() {
        try
    {
 ServerSocketConnection ssc = (ServerSocketConnection) 
  Connector.open("socket://:9002");
  StreamConnection sc = null;
  InputStream is = null;
  try{
    sc = ssc.acceptAndOpen();
    is = sc.openInputStream();
    int ch = 0;
    StringBuffer sb = new StringBuffer();
    while ((ch = is.read()) != -1){
      sb.append((char)ch);
    }
    System.out.println(sb.toString());
  } finally{
      ssc.close();
      sc.close();
      is.close();
  }
} catch (IOException x) {
    x.printStackTrace();
}


    }

For Client

           try{
  SocketConnection sc = (SocketConnection) 
    Connector.open("socket://10.91.40.145:9002");
  OutputStream os = null;
  try{
    os = sc.openOutputStream();
    byte[] data = "Hello from a socket!".getBytes();
    os.write(data);
  } finally{
      sc.close();
      os.close();
  }
} catch (IOException x){
    x.printStackTrace();
}

When I run client on Raspberry pi, I get following Log:

Java is starting. Press Ctrl-C to exit
[CRITICAL] [SECURITY] iso=2:Permission check failed: javax.microedition.io.SocketProtocolPermission "socket://10.91.40.145:9002" ""
TRACE: <at java.security.AccessControlException: >, startApp threw an Exception
java.security.AccessControlException: 
 - com/oracle/meep/security/AccessControllerInternal.checkPermission(), bci=128
 - java/security/AccessController.checkPermission(), bci=1
 - com/sun/midp/io/j2me/socket/Protocol.open(), bci=127
 - com/sun/midp/io/j2me/socket/Protocol.openPrim(), bci=4
 - javax/microedition/io/Connector.open(), bci=77
 - javax/microedition/io/Connector.open(), bci=6
 - javax/microedition/io/Connector.open(), bci=3
 - smartgridapidemopi/SmartGridAPIdemoPI.startApp(SmartGridAPIdemoPI.java:48)
 - javax/microedition/midlet/MIDletTunnelImpl.callStartApp(), bci=1
 - com/sun/midp/midlet/MIDletPeer.startApp(), bci=5
 - com/sun/midp/midlet/MIDletStateHandler.startSuite(), bci=264
 - com/sun/midp/main/AbstractMIDletSuiteLoader.startSuite(), bci=38
 - com/sun/midp/main/CldcMIDletSuiteLoader.startSuite(), bci=5
 - com/sun/midp/main/AbstractMIDletSuiteLoader.runMIDletSuite(), bci=132
 - com/sun/midp/main/AppIsolateMIDletSuiteLoader.main(), bci=26
java.security.AccessControlException: 
 - com/oracle/meep/security/AccessControllerInternal.checkPermission(), bci=[ERROR] [AMS] iso=1:Sending the notification: com.oracle.midp.proxy.RunCommand@d17b7662. FAILED, proxy is disconnected
128
 - java/security/AccessController.checkPermission(), bci=1
 - com/sun/midp/io/j2me/socket/Protocol.open(), bci=127
 - com/sun/midp/io/j2me/socket/Protocol.openPrim(), bci=4
 - javax/microedition/io/Connector.open(), bci=77
 - javax/microedition/io/Connector.open(), bci=6
 - javax/microedition/io/Connector.open(), bci=3
 - smartgridapidemopi/SmartGridAPIdemoPI.startApp(SmartGridAPIdemoPI.java:48)
 - javax/microedition/midlet/MIDletTunnelImpl.callStartApp(), bci=1
 - com/sun/midp/midlet/MIDletPeer.startApp(), bci=5
 - com/sun/midp/midlet/MIDletStateHandler.startSuite(), bci=264
 - com/sun/midp/main/AbstractMIDletSuiteLoader.startSuite(), bci=38
 - com/sun/midp/main/CldcMIDletSuiteLoader.startSuite(), bci=5
 - com/sun/midp/main/AbstractMIDletSuiteLoader.runMIDletSuite(), bci=132
 - com/sun/midp/main/AppIsolateMIDletSuiteLoader.main(), bci=26
[ERROR] [AMS] iso=1:Sending the notification: com.oracle.midp.proxy.RunCommand@d17b76f0. FAILED, proxy is disconnected
[ERROR] [AMS] iso=1:Sending the notification: com.oracle.midp.proxy.StopCommand@d17b76ff. FAILED, proxy is disconnected

How to handle this AccessControlException.??

Upvotes: 0

Views: 590

Answers (2)

user2595111
user2595111

Reputation: 11

Provide API permission javax.microedition.io.SocketProtocolPermission(“socket://:”) javax.microedition.io.SocketProtocolPermission(“socket://:*”)

in your jad file

You can do it in netbeans by navigating project property -> Application Descriptor select API Permission tab.

Upvotes: 0

volkinc
volkinc

Reputation: 2128

Port 9002 closed by firewall or antivirus. Check the port availability.

Upvotes: 0

Related Questions