Reputation: 3
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
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
Reputation: 2128
Port 9002 closed by firewall or antivirus. Check the port availability.
Upvotes: 0