This library makes it easy to integrate a Java SE enabled device with coap based services like mbed Cloud. It can also help to emulate an embedded device for prototyping and testing purposes.
The following features are supported by the library:
- Complete CoAP support
- CoRE Link Format processing API
- Constrained RESTful Environments (CoRE) Link Format RFC 6690
- CoAP server mode
- CoAP client mode
- Coap over tcp draft-ietf-core-coap-tcp-tls-09
- excluding: websockets, observations with BERT blocks
- Network transports:
- plain text UDP
- TLS
- LwM2M TLV and JSON data formats
- JRE v1.8
- JDK v1.8
- maven 3.x
Add repository to build file:
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
Add dependency into your pom.xml
:
<dependency>
<groupId>com.mbed.java-coap</groupId>
<artifactId>coap-core</artifactId>
<version>{VERSION}</version>
</dependency>
To initialize a server, you must at minimum define the port number. You must set the server parameters before starting a server.
CoapServer server = CoapServer.builder().transport(5683).build();
server.start();
To stop a server, use the stop()
method.
server.stop();
You can add handlers before or while the server is running. There can be several URI paths assigned to the same handler. You can also remove a handler at any time.
CoapHandler handler = new SimpleCoapResource("24", "ucum:Cel", 0);
server.addRequestHandler("/s/temp", handler);
server.addRequestHandler("/temperature", handler);
server.removeRequestHandler(handler);
To create a CoAP resource, you must implement a CoapHandler
. There is one abstract helper class CoapResource
that can be extended. At minimum, implement the get()
method.
The following example overrides get()
and put()
and creates a simple CoAP resource:
public class SimpleCoapResource extends CoapResource {
private String body="Hello World";
@Override
public void get(CoapExchange ex) throws CoapCodeException {
ex.setResponseBody("Hello World");
ex.setResponseCode(Code.C205_CONTENT);
ex.sendResponse();
}
@Override
public void put(CoapExchange ex) throws CoapCodeException {
body = ex.getRequestBodyString();
ex.setResponseCode(Code.C204_CHANGED);
ex.sendResponse();
}
}
To make a CoAP request, use the class CoapClient
. It uses fluent API. The following is a simple example on the usage:
CoapClient client = CoapClientBuilder.newBuilder(new InetSocketAddress("localhost",5683)).build();
CoapPacket coapResp = client.resource("/s/temp").sync().get();
coapResp = client.resource("/a/relay").payload("1", MediaTypes.CT_TEXT_PLAIN).sync().put();
//it is important to close connection in order to release socket
client.closeConnection();
This example client demonstrates how to build coap client and use it with connector.mbed.com or other LwM2M server.
mvn clean install
mvn clean install -P ci
mvn com.mycila:license-maven-plugin:format
All contributions are Apache 2.0. Only submit contributions where you have authored all of the code. If you do this on work time make sure your employer is OK with this.
Unless specifically indicated otherwise in a file, files are licensed under the Apache 2.0 license, as can be found in: LICENSE