Android开源 - RxWebSocket:基于 OkHttp 和 RxJava 封装的 WebSocket 客户端

   <p>RxWebSocket是一个基于okhttp和RxJava封装的WebSocket客户端,此库的核心特点是 除了手动关闭WebSocket(就是RxJava取消订阅),WebSocket在异常关闭的时候(onFailure,发生异常,如WebSocketException等等),会自动重连,永不断连.其次,对WebSocket做的缓存处理,同一个URL,共享一个WebSocket.</p>    <h2>原理解析: <a href="/misc/goto?guid=4959754903084484188" rel="nofollow,noindex">戳我戳我戳我</a></h2>    <h2>效果图</h2>    <p><img src="https://simg.open-open.com/show/6c1d1e0f90909522e9bbbdd6ab45a74b.gif"></p>    <h3>断网重连测试</h3>    <p><img src="https://simg.open-open.com/show/eaf554fa8cde0d5acda2c087a178a0ee.gif"></p>    <h2>how to use</h2>    <h3>添加依赖:</h3>    <p>本项目依赖 okhttp和RxJava,RxAndroid开发,所以在module下除了加入本项目依赖,还需加入okhttp和RxJava,RxAndroid依赖:</p>    <pre>  <code class="language-java">//本项目   compile 'com.dhh:websocket:1.3.0'      //okhttp,RxJava,RxAndroid   compile 'com.squareup.okhttp3:okhttp:3.9.0'   compile 'io.reactivex:rxjava:1.3.1'   compile 'io.reactivex:rxandroid:1.2.1'</code></pre>    <h3>init</h3>    <pre>  <code class="language-java">//if you want to use your okhttpClient          OkHttpClient yourClient = new OkHttpClient();          RxWebSocketUtil.getInstance().setClient(yourClient);    // show log,default false          RxWebSocketUtil.getInstance().setShowLog(true);</code></pre>    <h3>open WebSocket</h3>    <pre>  <code class="language-java">RxWebSocketUtil.getInstance().getWebSocketInfo(url)                           .subscribe(new Action1<WebSocketInfo>() {                               @Override                               public void call(WebSocketInfo webSocketInfo) {                                   mWebSocket = webSocketInfo.getWebSocket();                                   Log.d("MainActivity", webSocketInfo.getString());                                   Log.d("MainActivity", "webSocketInfo.getByteString():" + webSocketInfo.getByteString());                               }                           });      mWebSocket.send("hello word");        //get StringMsg      RxWebSocketUtil.getInstance().getWebSocketString(url)              .subscribe(new Action1<String>() {                  @Override                  public void call(String s) {                  }              });      // get ByteString      RxWebSocketUtil.getInstance().getWebSocketByteString(url)              .subscribe(new Action1<ByteString>() {                  @Override                  public void call(ByteString byteString) {                    }              });      //get WebSocket      RxWebSocketUtil.getInstance().getWebSocket(url)              .subscribe(new Action1<WebSocket>() {                  @Override                  public void call(WebSocket webSocket) {                    }              });   //with timeout      RxWebSocketUtil.getInstance().getWebSocketInfo(url, 10, TimeUnit.SECONDS)              .subscribe(new Action1<WebSocketInfo>() {                  @Override                  public void call(WebSocketInfo webSocketInfo) {                    }              });</code></pre>    <pre>  <code class="language-java">// Rxbinding      RxView.clicks(centect)              .flatMap(new Func1<Void, Observable<String>>() {                  @Override                  public Observable<String> call(Void aVoid) {                      return RxWebSocketUtil.getInstance().getWebSocketString(url);                  }              })              .subscribe(new Action1<String>() {                  @Override                  public void call(String s) {                      //the s !=null                        Log.d("MainActivity", s);                      textview.setText(Html.fromHtml(s));                    }              });</code></pre>    <h3>发送消息</h3>    <pre>  <code class="language-java">//用WebSocket的引用直接发     mWebSocket.send("hello word");        //url 对应的WebSocket已经打开可以这样send,否则报错     RxWebSocketUtil.getInstance().send(url, "hello");     RxWebSocketUtil.getInstance().send(url, ByteString.EMPTY);        //异步发送,若WebSocket已经打开,直接发送,若没有打开,打开一个WebSocket发送完数据,直接关闭.     RxWebSocketUtil.getInstance().asyncSend(url, "hello");     RxWebSocketUtil.getInstance().asyncSend(url, ByteString.EMPTY);</code></pre>    <h3>注销</h3>    <p>RxJava的注销方式,就可以取消订阅. 项目里的demo里,简单实现了一个Lifecycle.仅供参考.</p>    <pre>  <code class="language-java">Subscription subscription = RxWebSocketUtil.getInstance().getWebSocketString("ws://sdfs").subscribe();   //注销      if(subscription!=null&&!subscription.isUnsubscribed()) {          subscription.unsubscribe();      }</code></pre>    <p>更优雅的注销处理方式,请看我的另一个项目: <a href="/misc/goto?guid=4959754903170931126" rel="nofollow,noindex">RxLifecycle</a> ,优雅地处理RxJava注销问题,和Activity生命周期绑定.</p>    <h2>如果本库对你有帮助,谢谢您的star!</h2>    <h2>License</h2>    <pre>  <code class="language-java">Licensed under the Apache License, Version 2.0 (the "License");  you may not use this file except in compliance with the License.  You may obtain a copy of the License at       http://www.apache.org/licenses/LICENSE-2.0    Unless required by applicable law or agreed to in writing, software  distributed under the License is distributed on an "AS IS" BASIS,  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the License for the specific language governing permissions and  limitations under the License.</code></pre>    <p> </p>    <p> </p>