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


Java SslContext類代碼示例

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


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

示例1: initChannel

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
@Override
protected void initChannel(SocketChannel ch) throws Exception {
    if (enableTLS) {
        File tlsCert = new File(serviceConfig.getTlsCertificateFilePath());
        File tlsKey = new File(serviceConfig.getTlsKeyFilePath());
        SslContextBuilder builder = SslContextBuilder.forServer(tlsCert, tlsKey);
        if (serviceConfig.isTlsAllowInsecureConnection()) {
            builder.trustManager(InsecureTrustManagerFactory.INSTANCE);
        } else {
            if (serviceConfig.getTlsTrustCertsFilePath().isEmpty()) {
                // Use system default
                builder.trustManager((File) null);
            } else {
                File trustCertCollection = new File(serviceConfig.getTlsTrustCertsFilePath());
                builder.trustManager(trustCertCollection);
            }
        }
        SslContext sslCtx = builder.clientAuth(ClientAuth.OPTIONAL).build();
        ch.pipeline().addLast(TLS_HANDLER, sslCtx.newHandler(ch.alloc()));
    }
    ch.pipeline().addLast("frameDecoder", new LengthFieldBasedFrameDecoder(PulsarDecoder.MaxFrameSize, 0, 4, 0, 4));
    ch.pipeline().addLast("handler", new ServerConnection(discoveryService));
}
 
開發者ID:apache,項目名稱:incubator-pulsar,代碼行數:24,代碼來源:ServiceChannelInitializer.java

示例2: setupWSChannel

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
protected ChannelHandler setupWSChannel(SslContext sslCtx, Configuration conf, DataStore datastore) {
    return new ChannelInitializer<SocketChannel>() {

        @Override
        protected void initChannel(SocketChannel ch) throws Exception {
            ch.pipeline().addLast("ssl", sslCtx.newHandler(ch.alloc()));
            ch.pipeline().addLast("httpServer", new HttpServerCodec());
            ch.pipeline().addLast("aggregator", new HttpObjectAggregator(8192));
            ch.pipeline().addLast("sessionExtractor", new WebSocketHttpCookieHandler(config));
            ch.pipeline().addLast("idle-handler", new IdleStateHandler(conf.getWebsocket().getTimeout(), 0, 0));
            ch.pipeline().addLast("ws-protocol", new WebSocketServerProtocolHandler(WS_PATH, null, true));
            ch.pipeline().addLast("wsDecoder", new WebSocketRequestDecoder(datastore, config));
            ch.pipeline().addLast("error", new WSExceptionHandler());
        }
    };

}
 
開發者ID:NationalSecurityAgency,項目名稱:qonduit,代碼行數:18,代碼來源:Server.java

示例3: start

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
public void start(String ip, int port) throws Exception {
	// Configure SSL.
	final SslContext sslCtx;
	if (SSL) {
		sslCtx = SslContextBuilder.forClient().trustManager(InsecureTrustManagerFactory.INSTANCE).build();
	} else {
		sslCtx = null;
	}
	EventLoopGroup group = new NioEventLoopGroup();
	try {
		Bootstrap b = new Bootstrap();
		b.group(group).channel(NioSocketChannel.class).handler(new FileClientInitializer(sslCtx));
		Channel ch = b.connect(ip, port).sync().channel();
		ConfigurationContext.propMap.putIfAbsent(SOCKET_CHANNEL, ch);			
	}catch(Exception e){
		e.printStackTrace();
	}
}
 
開發者ID:polarcoral,項目名稱:monica,代碼行數:19,代碼來源:SocketClient.java

示例4: ConnectionFactory

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
ConnectionFactory(
        EventLoopGroup group,
        MessageFraming messageFraming,
        MessageEncoding messageEncoding,
        Optional<Supplier<SslContext>> sslContextSupplier,
        DriftNettyClientConfig clientConfig)
{
    this.group = requireNonNull(group, "group is null");
    this.messageFraming = requireNonNull(messageFraming, "messageFraming is null");
    this.messageEncoding = requireNonNull(messageEncoding, "messageEncoding is null");
    this.sslContextSupplier = requireNonNull(sslContextSupplier, "sslContextSupplier is null");

    requireNonNull(clientConfig, "clientConfig is null");
    this.connectTimeout = clientConfig.getConnectTimeout();
    this.requestTimeout = clientConfig.getRequestTimeout();
    this.socksProxy = Optional.ofNullable(clientConfig.getSocksProxy());
}
 
開發者ID:airlift,項目名稱:drift,代碼行數:18,代碼來源:ConnectionFactory.java

示例5: load

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
@Override
public boolean load() {
    final SslContext previous = reference.get();
    try {
        final SslContext context = loader.get();
        if (context == null) {
            return finishLoadWithReloadState(ReloadState.FAILED, null);
        }

        if (Objects.equals(previous, context)) {
            return finishLoadWithReloadState(ReloadState.NO_CHANGE, null);
        }

        reference.set(context);
        return finishLoadWithReloadState(ReloadState.RELOADED, null);
    } catch (final Exception e) {
        LOGGER.error("Failed to load SslContext.", e);
    }

    return finishLoadWithReloadState(ReloadState.FAILED, null);
}
 
開發者ID:indeedeng-alpha,項目名稱:indeed-grpc-java,代碼行數:22,代碼來源:SslContextReloader.java

示例6: get

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
@Test
public void get() throws Exception {
    final SslContextReloader reloader = new SslContextReloader(() -> null);

    assertFalse(reloader.load());
    assertEquals(ReloadState.FAILED, reloader.getReloadState());
    assertNull(reloader.getDataVersion());

    final SslContext context = reloader.get();
    assertNotNull(context);

    expectNullPointerException(context::isClient);
    expectNullPointerException(context::cipherSuites);
    expectNullPointerException(context::sessionCacheSize);
    expectNullPointerException(context::sessionTimeout);
    expectNullPointerException(context::applicationProtocolNegotiator);
    expectNullPointerException(context::sessionContext);
    expectNullPointerException(() -> context.newEngine(ByteBufAllocator.DEFAULT));
    expectNullPointerException(() -> context.newEngine(ByteBufAllocator.DEFAULT, "localhost", 1234));
}
 
開發者ID:indeedeng-alpha,項目名稱:indeed-grpc-java,代碼行數:21,代碼來源:SslContextReloaderTest.java

示例7: ImapClient

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
public ImapClient(ImapClientConfiguration configuration,
                  Channel channel,
                  SslContext sslContext,
                  EventExecutorGroup promiseExecutor,
                  String clientName) {
  this.logger = LogUtils.loggerWithName(ImapClient.class, clientName);
  this.configuration = configuration;
  this.channel = channel;
  this.sslContext = sslContext;
  this.promiseExecutor = promiseExecutor;
  this.clientState = new ImapClientState(clientName, promiseExecutor);
  this.codec = new ImapCodec(clientState);
  this.pendingWriteQueue = new ConcurrentLinkedQueue<>();
  this.connectionShutdown = new AtomicBoolean(false);
  this.connectionClosed = new AtomicBoolean(false);
  this.capabilities = new AtomicReference<>(null);

  configureChannel();
}
 
開發者ID:HubSpot,項目名稱:NioImapClient,代碼行數:20,代碼來源:ImapClient.java

示例8: usingNetty

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
static ClientHttpRequestFactory usingNetty(ClientOptions options)
		throws IOException, GeneralSecurityException {

	SslContext sslContext = new JdkSslContext(SSLContext.getDefault(), true, ClientAuth.REQUIRE);

	final Netty4ClientHttpRequestFactory requestFactory = new Netty4ClientHttpRequestFactory();
	requestFactory.setSslContext(sslContext);

	if (options.getConnectionTimeout() != null) {
		requestFactory.setConnectTimeout(options.getConnectionTimeout());
	}
	if (options.getReadTimeout() != null) {
		requestFactory.setReadTimeout(options.getReadTimeout());
	}

	return requestFactory;
}
 
開發者ID:spring-projects,項目名稱:spring-credhub,代碼行數:18,代碼來源:ClientHttpRequestFactoryFactory.java

示例9: createSSlContext

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
/**
 * Create ssl context for the host
 */
public SslContext createSSlContext(String host, boolean useH2) {
    String finalHost = Networks.wildcardHost(host);
    lock.readLock().lock();
    try {
        return sslContextCache.computeIfAbsent(host + ":" + useH2, key -> {
            try {
                return getNettySslContextInner(finalHost, useH2);
            } catch (Exception e) {
                throw new SSLContextException(e);
            }
        });
    } finally {
        lock.readLock().unlock();
    }
}
 
開發者ID:hsiafan,項目名稱:byproxy,代碼行數:19,代碼來源:ServerSSLContextManager.java

示例10: newNettyClientContext

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
private static SslContext newNettyClientContext(
        io.netty.handler.ssl.SslProvider sslProvider, boolean useAlpn) {
    try {
        TestKeyStore server = TestKeyStore.getServer();
        SslContextBuilder ctx =
                SslContextBuilder.forClient()
                        .sslProvider(sslProvider)
                        .trustManager((X509Certificate[]) server.getPrivateKey("RSA", "RSA")
                                              .getCertificateChain());
        if (useAlpn) {
            ctx.applicationProtocolConfig(OpenJdkEngineFactoryConfig.NETTY_ALPN_CONFIG);
        }
        return ctx.build();
    } catch (SSLException e) {
        throw new RuntimeException(e);
    }
}
 
開發者ID:google,項目名稱:conscrypt,代碼行數:18,代碼來源:OpenJdkEngineFactory.java

示例11: getServerInitializer

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
private ChannelInitializer<LocalChannel> getServerInitializer(
    PrivateKey privateKey,
    X509Certificate certificate,
    Lock serverLock,
    Exception serverException)
    throws Exception {
  SslContext sslContext = SslContextBuilder.forServer(privateKey, certificate).build();
  return new ChannelInitializer<LocalChannel>() {
    @Override
    protected void initChannel(LocalChannel ch) throws Exception {
      ch.pipeline()
          .addLast(
              sslContext.newHandler(ch.alloc()), new EchoHandler(serverLock, serverException));
    }
  };
}
 
開發者ID:google,項目名稱:nomulus,代碼行數:17,代碼來源:SslClientInitializerTest.java

示例12: getNettySslContextInner

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
private SslContext getNettySslContextInner(String host, boolean useH2) throws Exception {
        long start = System.currentTimeMillis();
        PrivateKeyAndCertChain keyAndCertChain = keyStoreGenerator.generateCertChain(host, Settings.certValidityDays);
        logger.debug("Create certificate for {}, cost {} ms", host, System.currentTimeMillis() - start);
        SslContextBuilder builder = SslContextBuilder
                .forServer(keyAndCertChain.getPrivateKey(), keyAndCertChain.getCertificateChain());
        if (useH2) {
//                .ciphers(Http2SecurityUtil.CIPHERS, SupportedCipherSuiteFilter.INSTANCE)
            builder.applicationProtocolConfig(new ApplicationProtocolConfig(
                    ApplicationProtocolConfig.Protocol.ALPN,
                    SelectorFailureBehavior.NO_ADVERTISE,
                    SelectedListenerFailureBehavior.ACCEPT,
                    ApplicationProtocolNames.HTTP_2,
                    ApplicationProtocolNames.HTTP_1_1));
        }
        return builder.build();
    }
 
開發者ID:hsiafan,項目名稱:byproxy,代碼行數:18,代碼來源:ServerSSLContextManager.java

示例13: initChannel_adds_sslCtx_handler_first_if_available_and_no_utility_handlers

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
@Test
public void initChannel_adds_sslCtx_handler_first_if_available_and_no_utility_handlers() throws SSLException {
    // given
    SslContext sslCtx = new JdkSslClientContext();
    HttpChannelInitializer hci = basicHttpChannelInitializer(sslCtx, 0, 100, false, mock(RequestValidator.class),
                                                             createRequestAndResponseFilterMock());

    // when
    hci.initChannel(socketChannelMock);

    // then
    ArgumentCaptor<ChannelHandler> channelHandlerArgumentCaptor = ArgumentCaptor.forClass(ChannelHandler.class);
    verify(channelPipelineMock, atLeastOnce()).addLast(anyString(), channelHandlerArgumentCaptor.capture());
    List<ChannelHandler> handlers = channelHandlerArgumentCaptor.getAllValues();
    assertThat(handlers.get(0), instanceOf(SslHandler.class));
}
 
開發者ID:Nike-Inc,項目名稱:riposte,代碼行數:17,代碼來源:HttpChannelInitializerTest.java

示例14: getSSLContext

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
private static SslContext getSSLContext() throws IOException, GeneralSecurityException {
    try {
        final String privateKeyFile = "keys/server.pkcs8.key";
        final String certificateFile = "keys/server.crt";
        final String rootCAFile = "keys/rootCA.pem";

        final PrivateKey privateKey = loadPrivateKey(privateKeyFile);
        final X509Certificate certificate = loadX509Cert(certificateFile);
        final X509Certificate rootCA = loadX509Cert(rootCAFile);

        return SslContextBuilder.forClient()
                .sslProvider(SslProvider.JDK)
                .trustManager(rootCA)
                .keyManager(privateKey, certificate)
                .build();

    } catch (IOException | GeneralSecurityException e) {
        LOGGER.warn("Failed to establish SSL Context");
        LOGGER.debug("Failed to establish SSL Context", e);
        throw e;
    }
}
 
開發者ID:inst-tech,項目名稱:opentsdb-plugins,代碼行數:23,代碼來源:RelayClient.java

示例15: main

import io.netty.handler.ssl.SslContext; //導入依賴的package包/類
public static void main(String[] args) throws Exception {
    SelfSignedCertificate ssc = new SelfSignedCertificate();
    SslContext sslCtx = SslContextBuilder.forServer(ssc.certificate(), ssc.privateKey())
        .build();

    EventLoopGroup bossGroup = new NioEventLoopGroup(1);
    EventLoopGroup workerGroup = new NioEventLoopGroup();
    try {
        ServerBootstrap b = new ServerBootstrap();
        b.group(bossGroup, workerGroup)
         .channel(NioServerSocketChannel.class)
         .handler(new LoggingHandler(LogLevel.INFO))
         .childHandler(new SecureChatServerInitializer(sslCtx));

        b.bind(PORT).sync().channel().closeFuture().sync();
    } finally {
        bossGroup.shutdownGracefully();
        workerGroup.shutdownGracefully();
    }
}
 
開發者ID:cowthan,項目名稱:JavaAyo,代碼行數:21,代碼來源:SecureChatServer.java


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