當前位置: 首頁>>代碼示例>>Java>>正文


Java Handler類代碼示例

本文整理匯總了Java中io.vertx.core.Handler的典型用法代碼示例。如果您正苦於以下問題:Java Handler類的具體用法?Java Handler怎麽用?Java Handler使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Handler類屬於io.vertx.core包,在下文中一共展示了Handler類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: modify

import io.vertx.core.Handler; //導入依賴的package包/類
@Override
public FdfsClient modify(ReadStream<Buffer> stream, long size, FdfsFileId fileId, long offset,
		Handler<AsyncResult<Void>> handler) {
	getTracker().setHandler(tracker -> {
		if (tracker.succeeded()) {
			tracker.result().getStoreStorage(fileId.group(), storage -> {
				if (storage.succeeded()) {
					storage.result().modify(stream, size, fileId, offset, modify -> {
						handler.handle(modify);
					});
				} else {
					handler.handle(Future.failedFuture(storage.cause()));
				}
			});
		} else {
			handler.handle(Future.failedFuture(tracker.cause()));
		}
	});

	return this;
}
 
開發者ID:gengteng,項目名稱:vertx-fastdfs-client,代碼行數:22,代碼來源:FdfsClientImpl.java

示例2: getBooks

import io.vertx.core.Handler; //導入依賴的package包/類
@Override
public BookDatabaseService getBooks(Book book, Handler<AsyncResult<JsonArray>> resultHandler) {
  DynamicQuery dynamicQuery = generateDynamicQuery(SQL_FIND_ALL_BOOKS, book);
  String preparedQuery = dynamicQuery.getPreparedQuery();
  Tuple params = dynamicQuery.getParams();

  pgConnectionPool.rxPreparedQuery(preparedQuery, params)
    .map(PgResult::getDelegate)
    .subscribe(
      pgResult -> {
        JsonArray jsonArray = transformPgResultToJson(pgResult);
        resultHandler.handle(Future.succeededFuture(jsonArray));
      },
      throwable -> {
        LOGGER.error("Failed to get the filtered books by the following conditions"
          + params.toString(), throwable);
        resultHandler.handle(Future.failedFuture(throwable));
      });
  return this;
}
 
開發者ID:BillyYccc,項目名稱:vertx-postgresql-starter,代碼行數:21,代碼來源:BookDatabaseServiceImpl.java

示例3: pageUpdateHandler

import io.vertx.core.Handler; //導入依賴的package包/類
private void pageUpdateHandler(RoutingContext context) {
  String title = context.request().getParam("title");

  Handler<AsyncResult<Void>> handler = reply -> {
    if (reply.succeeded()) {
      context.response().setStatusCode(303);
      context.response().putHeader("Location", "/wiki/" + title);
      context.response().end();
    } else {
      context.fail(reply.cause());
    }
  };

  String markdown = context.request().getParam("markdown");
  if ("yes".equals(context.request().getParam("newPage"))) {
    dbService.createPage(title, markdown, handler);
  } else {
    dbService.savePage(Integer.valueOf(context.request().getParam("id")), markdown, handler);
  }
}
 
開發者ID:dreamzyh,項目名稱:vertx-guide-for-java-devs_chinese,代碼行數:21,代碼來源:HttpServerVerticle.java

示例4: handler

import io.vertx.core.Handler; //導入依賴的package包/類
private Handler<Message<JsonObject>> handler(ServiceHandler serviceHandler) {
	return msg -> {
		vertx.executeBlocking(ar -> {
			try {
				ar.complete(serviceHandler.invokeService(msg.body()));
			} catch (Exception e) {
				ar.fail(e);
			}
		}, res -> {
			if (res.succeeded()) {
				msg.reply(res.result());
			} else {
				int failureCode = 500;
				String message = res.cause().getMessage();
				msg.fail(failureCode, message);
			}
		});
	};
}
 
開發者ID:simonemasoni,項目名稱:vertx_spring,代碼行數:20,代碼來源:ServiceVerticle.java

示例5: processMethods

import io.vertx.core.Handler; //導入依賴的package包/類
/**
 * 分發請求並處理
 * 下麵具體的方法如方法名所示,與DAO層方法命名一致,在此不表
 *
 * @author Leibniz.Hu
 */
@Override
protected <T> void processMethods(Handler<T> replyMsg, JsonArray params, EventBusNamespace method) {
    switch (method) {
        case COMMAND_INSERT_ORDER:
            insertOrder(replyMsg, params);
            break;
        case COMMAND_GET_ORDER_BY_ALIPAY_ORDER_ID:
            getOrderByAlipayOrderId(replyMsg, params);
            break;
        case COMMAND_GET_ORDER_BY_WECHAT_ORDER_ID:
            getOrderByWechatOrderId(replyMsg, params);
            break;
        case COMMAND_UPDATE_PAID_ORDER:
            updateAfterPaid(replyMsg, params);
            break;
        default:
            log.error("未能處理的請求方法:{}", method);
    }
}
 
開發者ID:Leibnizhu,項目名稱:AlipayWechatPlatform,代碼行數:26,代碼來源:OrderDBVerticle.java

示例6: fetchAllPages

import io.vertx.core.Handler; //導入依賴的package包/類
@Override
public WikiDatabaseService fetchAllPages(Handler<AsyncResult<JsonArray>> resultHandler) {
  dbClient.query(sqlQueries.get(SqlQuery.ALL_PAGES), res -> {
    if (res.succeeded()) {
      JsonArray pages = new JsonArray(res.result()
        .getResults()
        .stream()
        .map(json -> json.getString(0))
        .sorted()
        .collect(Collectors.toList()));
      resultHandler.handle(Future.succeededFuture(pages));
    } else {
      LOGGER.error("Database query error", res.cause());
      resultHandler.handle(Future.failedFuture(res.cause()));
    }
  });
  return this;
}
 
開發者ID:vert-x3,項目名稱:vertx-guide-for-java-devs,代碼行數:19,代碼來源:WikiDatabaseServiceImpl.java

示例7: fetchPage

import io.vertx.core.Handler; //導入依賴的package包/類
@Override
public WikiDatabaseService fetchPage(String name, Handler<AsyncResult<JsonObject>> resultHandler) {
  dbClient.queryWithParams(sqlQueries.get(SqlQuery.GET_PAGE), new JsonArray().add(name), fetch -> {
    if (fetch.succeeded()) {
      JsonObject response = new JsonObject();
      ResultSet resultSet = fetch.result();
      if (resultSet.getNumRows() == 0) {
        response.put("found", false);
      } else {
        response.put("found", true);
        JsonArray row = resultSet.getResults().get(0);
        response.put("id", row.getInteger(0));
        response.put("rawContent", row.getString(1));
      }
      resultHandler.handle(Future.succeededFuture(response));
    } else {
      LOGGER.error("Database query error", fetch.cause());
      resultHandler.handle(Future.failedFuture(fetch.cause()));
    }
  });
  return this;
}
 
開發者ID:vert-x3,項目名稱:vertx-guide-for-java-devs,代碼行數:23,代碼來源:WikiDatabaseServiceImpl.java

示例8: connect_success

import io.vertx.core.Handler; //導入依賴的package包/類
@Test
public void connect_success(@Mocked NetSocketImpl netSocket) {
  FutureFactoryImpl futureFactory = new FutureFactoryImpl();
  new MockUp<NetClientWrapper>(netClientWrapper) {
    @Mock
    void connect(boolean ssl, int port, String host, Handler<AsyncResult<NetSocket>> connectHandler) {
      connectHandler.handle(futureFactory.succeededFuture(netSocket));
    }
  };

  tcpClientConnection.connect();

  Assert.assertSame(netSocket, tcpClientConnection.getNetSocket());
  Assert.assertEquals(Status.WORKING, Deencapsulation.getField(tcpClientConnection, "status"));
}
 
開發者ID:apache,項目名稱:incubator-servicecomb-java-chassis,代碼行數:16,代碼來源:TestTcpClientConnection.java

示例9: WikiDatabaseServiceImpl

import io.vertx.core.Handler; //導入依賴的package包/類
WikiDatabaseServiceImpl(io.vertx.ext.jdbc.JDBCClient dbClient, HashMap<SqlQuery, String> sqlQueries, Handler<AsyncResult<WikiDatabaseService>> readyHandler) {
  this.dbClient = new JDBCClient(dbClient);
  this.sqlQueries = sqlQueries;

  getConnection()
    .flatMap(conn -> conn.rxExecute(sqlQueries.get(SqlQuery.CREATE_PAGES_TABLE)))
    .map(v -> this)
    .subscribe(RxHelper.toSubscriber(readyHandler));
}
 
開發者ID:vert-x3,項目名稱:vertx-guide-for-java-devs,代碼行數:10,代碼來源:WikiDatabaseServiceImpl.java

示例10: countAsync

import io.vertx.core.Handler; //導入依賴的package包/類
/**
 * Count all records of the underlying table asynchronously.
 * @param resultHandler the resultHandler which succeeds when the blocking method of this type succeeds or fails
 *                      with an <code>DataAccessException</code> if the blocking method of this type throws an exception
 * @see #count()
 */
default void countAsync(Handler<AsyncResult<Long>> resultHandler){
    VertxDAOHelper.countAsync(this, (query,mapper)->{
        client().fetchOne(query,mapper, h -> {
            if (h.succeeded()) {
                resultHandler.handle(Future.succeededFuture((Long) h.result().get()));
            } else {
                resultHandler.handle(Future.failedFuture(h.cause()));
            }
        });
        return null;
    });
}
 
開發者ID:jklingsporn,項目名稱:vertx-jooq-async,代碼行數:19,代碼來源:VertxDAO.java

示例11: ofSucceededVoid

import io.vertx.core.Handler; //導入依賴的package包/類
public static <A, B> Handler<AsyncResult<A>> ofSucceededVoid(Handler<AsyncResult<B>> handler, VoidConsumer alwaysDo, Consumer<A> consumer)
{
    return e -> {
        if (alwaysDo != null) {
            alwaysDo.accept();
        }

        if (e.failed()) {
            handler.handle(failedFuture(e.cause()));
            return;
        }
        consumer.accept(e.result());
    };
}
 
開發者ID:DavidQuan,項目名稱:vertx-ssdb,代碼行數:15,代碼來源:F.java

示例12: connect

import io.vertx.core.Handler; //導入依賴的package包/類
@Override
public BinlogClientImpl connect(Handler<AsyncResult<Void>> startHandler) {
  if (connected) {
    throw new IllegalStateException("Client already connected.");
  }
  connected = true;
  vertx.<Void>executeBlocking((f) -> {
    try {
      client.connect(connectTimeout);
      Runtime.getRuntime().addShutdownHook(shutdownHook);
      f.complete();
    } catch (Exception e) {
      f.fail(e);
    }
  }, true, (ar) -> {
    if (ar.succeeded()) {
      if (logger.isDebugEnabled()) {
        logger.debug("Binlog listener " +
          "[" + host + ":" + port + "]" +
          " started ");
      }
    } else {
      connected = false;
      if (exceptionHandler != null) {
        exceptionHandler.handle(ar.cause());
      }
    }
    startHandler.handle(ar);
  });
  return this;
}
 
開發者ID:guoyu511,項目名稱:vertx-mysql-binlog-client,代碼行數:32,代碼來源:BinlogClientImpl.java

示例13: compareBodyHandler

import io.vertx.core.Handler; //導入依賴的package包/類
private Handler<HttpClientResponse> compareBodyHandler(String message, TestContext context, Async f) {
	return r -> {
		context.assertEquals(200, r.statusCode(), "Failed to call consumes test '" + message + "'");
		r.exceptionHandler(context::fail).bodyHandler(body -> {
			context.assertEquals(message, body.toString());
			f.complete();
		});
	};
}
 
開發者ID:GreenfieldTech,項目名稱:irked,代碼行數:10,代碼來源:TestMountController.java

示例14: request

import io.vertx.core.Handler; //導入依賴的package包/類
private @NotNull HttpClientRequest request(@NotNull Handler<Buffer> handler, @NotNull Async latch) {
  return vertx.createHttpClient()
      .get(PORT, "localhost", "/metrics")
      .handler(response -> {
        context.assertEquals(HttpResponseStatus.OK.code(), response.statusCode());
        response.bodyHandler(body -> {
          handler.handle(body);
          latch.complete();
        });
      });
}
 
開發者ID:nolequen,項目名稱:vertx-prometheus-metrics,代碼行數:12,代碼來源:PrometheusMetricsTestCase.java

示例15: fetchAllPages

import io.vertx.core.Handler; //導入依賴的package包/類
@Override
// tag::rx-data-flow[]
public WikiDatabaseService fetchAllPages(Handler<AsyncResult<JsonArray>> resultHandler) {
  dbClient.rxQuery(sqlQueries.get(SqlQuery.ALL_PAGES))
    .flatMapObservable(res -> {  // <1>
      List<JsonArray> results = res.getResults();
      return Observable.from(results); // <2>
    })
    .map(json -> json.getString(0)) // <3>
    .sorted() // <4>
    .collect(JsonArray::new, JsonArray::add) // <5>
    .subscribe(RxHelper.toSubscriber(resultHandler));
  return this;
}
 
開發者ID:dreamzyh,項目名稱:vertx-guide-for-java-devs_chinese,代碼行數:15,代碼來源:WikiDatabaseServiceImpl.java


注:本文中的io.vertx.core.Handler類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。