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


Java Unpooled.copiedBuffer方法代碼示例

本文整理匯總了Java中io.netty.buffer.Unpooled.copiedBuffer方法的典型用法代碼示例。如果您正苦於以下問題:Java Unpooled.copiedBuffer方法的具體用法?Java Unpooled.copiedBuffer怎麽用?Java Unpooled.copiedBuffer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在io.netty.buffer.Unpooled的用法示例。


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

示例1: testEncodings

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
@Test
public void testEncodings() throws Exception {
    final PatternChunkSplitter splitter = new PatternChunkSplitter("^(?:Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)");

    // "Feb 20 17:05:18 Hällö Wörld\nFeb 20 17:05:18 Büe\n" in ISO-8859-1 encoding
    final byte[] bytes = new byte[]{
            0x46, 0x65, 0x62, 0x20, 0x32, 0x30, 0x20, 0x31, 0x37, 0x3a, 0x30, 0x35, 0x3a, 0x31, 0x38, 0x20,
            0x48, (byte) 0xe4, 0x6c, 0x6c, (byte) 0xf6, 0x20, 0x57, (byte) 0xf6, 0x72, 0x6c, 0x64, 0x0a,
            0x46, 0x65, 0x62, 0x20, 0x32, 0x30, 0x20, 0x31, 0x37, 0x3a, 0x30, 0x35, 0x3a, 0x31, 0x38, 0x20,
            0x42, (byte) 0xfc, 0x65, 0x0a
    };

    // With correct encoding
    final ByteBuf buffer = Unpooled.copiedBuffer(bytes);
    final Iterator<String> iterator = splitter.splitRemaining(buffer, ISO_8859_1).iterator();

    assertEquals("Feb 20 17:05:18 Hällö Wörld\n", iterator.next());
    assertEquals("Feb 20 17:05:18 Büe\n", iterator.next());

    // With wrong encoding
    final ByteBuf buffer2 = Unpooled.copiedBuffer(bytes);
    final Iterator<String> iterator2 = splitter.splitRemaining(buffer2, UTF_8).iterator();

    assertNotEquals("Feb 20 17:05:18 Hällö Wörld\n", iterator2.next());
    assertNotEquals("Feb 20 17:05:18 Büe\n", iterator2.next());
}
 
開發者ID:DevOpsStudio,項目名稱:Re-Collector,代碼行數:27,代碼來源:PatternChunkSplitterTest.java

示例2: writeResponse

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
private boolean writeResponse(HttpObject currentObj, ChannelHandlerContext ctx) {
    // Decide whether to close the connection or not.
    boolean keepAlive = HttpHeaders.isKeepAlive(request);

    // Build the response object.
    FullHttpResponse response = new DefaultFullHttpResponse(
        HTTP_1_1, currentObj.getDecoderResult().isSuccess() ? OK : BAD_REQUEST,
        Unpooled.copiedBuffer(buf.toString(), CharsetUtil.UTF_8));

    response.headers().set(CONTENT_TYPE, "application/json");

    if (keepAlive) {
        // Add 'Content-Length' header only for a keep-alive connection.
        response.headers().set(CONTENT_LENGTH, response.content().readableBytes());
        // Add keep alive header as per:
        // - http://www.w3.org/Protocols/HTTP/1.1/draft-ietf-http-v11-spec-01.html#Connection
        response.headers().set(CONNECTION, HttpHeaders.Values.KEEP_ALIVE);
    }

    // Write the response.
    ctx.write(response);

    return keepAlive;
}
 
開發者ID:aerogear,項目名稱:push-network-proxies,代碼行數:25,代碼來源:MockingFCMServerHandler.java

示例3: sendHttpResponse

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
private static void sendHttpResponse(ChannelHandlerContext ctx,
		HttpRequest req, FullHttpResponse res) {
	// Generate an error page if response getStatus code is not OK (200).
	if (res.getStatus().code() != 200) {
		ByteBuf buf = Unpooled.copiedBuffer(res.getStatus().toString(),
				CharsetUtil.UTF_8);
		res.content().writeBytes(buf);
		buf.release();
		setContentLength(res, res.content().readableBytes());
	}

	// Send the response and close the connection if necessary.
	ChannelFuture f = ctx.writeAndFlush(res);
	if (!isKeepAlive(req) || res.getStatus().code() != 200) {
		f.addListener(ChannelFutureListener.CLOSE);
	}
}
 
開發者ID:osswangxining,項目名稱:mqttserver,代碼行數:18,代碼來源:HttpJsonpTransport.java

示例4: readUTF8String

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
public static String readUTF8String(byte[] f) {
	val from = Unpooled.copiedBuffer(f);
	from.readByte();
	int len = readVarInt(from, 2);
	//from.readerIndex(from.readerIndex() + len);
	return from.toString(StandardCharsets.UTF_8);
}
 
開發者ID:NickAcPT,項目名稱:Lithium-Spigot,代碼行數:8,代碼來源:LithiumUtils.java

示例5: offer

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
public void offer(FramePacket frame) {
    Preconditions.checkState(frame.fragmented, "Only accept fragmented frame packet");

    int fragmentIndex = frame.fragmentIndex;
    int fragmentID = frame.fragmentID;
    int fragmentCount = frame.fragmentCount;
    ByteBuf[] fragments;
    //TODO: Add pool size checking
    if (!fragmentPool.containsKey(fragmentID)) {
        fragmentPool.put(fragmentID, fragments = new ByteBuf[fragmentCount]);
    } else {
        fragments = fragmentPool.get(fragmentID);
    }

    fragments[fragmentIndex] = frame.fragment;

    //Check if all fragments arrived
    for (ByteBuf buf : fragments) {
        if (buf == null) {
            return;
        }
    }

    fragmentPool.remove(fragmentID);

    ByteBuf fullBuf = Unpooled.copiedBuffer(fragments);

    session.handle(SessionPacket.from(fullBuf));
}
 
開發者ID:MagicDroidX,項目名稱:RakNetty,代碼行數:30,代碼來源:FragmentAggregator.java

示例6: sendError

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
private void sendError(ChannelHandlerContext ctx, HttpResponseStatus status) {
    FullHttpResponse response = new DefaultFullHttpResponse(
            HttpVersion.HTTP_1_1, status, Unpooled.copiedBuffer("Failure: " + status + "\r\n", CharsetUtil.UTF_8));
    response.headers().set(HttpHeaderNames.CONTENT_TYPE, "text/plain; charset=UTF-8");

    // Close the connection as soon as the error message is sent.
    ctx.writeAndFlush(response).addListener(ChannelFutureListener.CLOSE);
}
 
開發者ID:noti0na1,項目名稱:HFSN,代碼行數:9,代碼來源:HttpFileServerHandler.java

示例7: onMessage

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
@Override
public void onMessage(MalmoMessageType messageType, Map<String, String> data) 
{
    String bufstring = data.get("message");
    ByteBuf buf = Unpooled.copiedBuffer(DatatypeConverter.parseBase64Binary(bufstring));
    ItemStack itemStack = ByteBufUtils.readItemStack(buf);
    if (itemStack != null && itemStack.getItem() != null)
    {
        accumulateReward(this.params.getDimension(), itemStack);
    }
    else
    {
        System.out.println("Error - couldn't understand the itemstack we received.");
    }
}
 
開發者ID:Yarichi,項目名稱:Proyecto-DASI,代碼行數:16,代碼來源:RewardForDiscardingItemImplementation.java

示例8: sendListing

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
private void sendListing(ChannelHandlerContext ctx, File dir) throws IOException {
    FullHttpResponse response = new DefaultFullHttpResponse(HttpVersion.HTTP_1_1, HttpResponseStatus.OK);
    response.headers().set(HttpHeaderNames.CONTENT_TYPE, "text/html; charset=UTF-8");
    ByteBuf buffer = Unpooled.copiedBuffer(Pages.getDirectory(dir), CharsetUtil.UTF_8);
    response.content().writeBytes(buffer);
    buffer.release();

    // Close the connection as soon as the error message is sent.
    ctx.writeAndFlush(response).addListener(ChannelFutureListener.CLOSE);
}
 
開發者ID:noti0na1,項目名稱:HFSN,代碼行數:11,代碼來源:HttpFileServerHandler.java

示例9: itIndicatesTheFinalChunkWhenChunking

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
@Test
public void itIndicatesTheFinalChunkWhenChunking() {
  ByteBuf buffer = Unpooled.copiedBuffer(new byte[1000]);

  session.sendChunk(buffer, true);

  verify(channel).write(new DefaultSmtpRequest(SmtpCommand.valueOf("BDAT"), Integer.toString(buffer.readableBytes()), "LAST"));
  verify(channel).write(buffer);
  verify(channel).flush();
}
 
開發者ID:HubSpot,項目名稱:NioSmtpClient,代碼行數:11,代碼來源:SmtpSessionTest.java

示例10: testSingleBuffer

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
@Test
public void testSingleBuffer() {
    final Path logFile = Paths.get("/tmp/file"); // this is never actually materialized

    // the Buffer subclass to check the messages that are generated
    final ChunkProcessor processor = setupProcessor(logFile, new Buffer() {
        int messagenumber = 0;

        @Override
        public void insert(Message message) {
            log.debug("Received message {}", message);
            messagenumber++;
            assertEquals("test", message.getSource());
            switch (messagenumber) {
                case 1:
                    assertEquals("some line", message.getMessage());
                    break;
                case 2:
                    assertEquals("another line", message.getMessage());
                    break;
            }
        }

        @Override
        public Message remove() {
            return null;
        }
    });

    final FileChunk chunk = new FileChunk(logFile, Unpooled.copiedBuffer("some line\nanother line\n", UTF_8), 1);
    processor.process(chunk);
}
 
開發者ID:DevOpsStudio,項目名稱:Re-Collector,代碼行數:33,代碼來源:ChunkProcessorTest.java

示例11: successfulSplitLF

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
@Test
public void successfulSplitLF() throws Exception {
    final NewlineChunkSplitter splitter = new NewlineChunkSplitter();

    final String logLines = "Feb 20 17:05:18 otter kernel[0]: CODE SIGNING: cs_invalid_page(0x1000): p=32696[GoogleSoftwareUp] final status 0x0, allow (remove VALID)ing page\n" +
            "Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KeystoneDaemon logServiceState] GoogleSoftwareUpdate daemon (1.1.0.3659) vending:\n" +
            "Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KSUpdateEngine updateProductID:] KSUpdateEngine updating product ID: \"com.google.Keystone\"\n";

    final ByteBuf buffer = Unpooled.copiedBuffer(logLines, UTF_8);
    final Iterable<String> firstTwoChunks = splitter.split(buffer, UTF_8);
    final Iterable<String> remainingChunk = splitter.splitRemaining(buffer, UTF_8);

    int messageNum = 0;
    for (String chunk : Iterables.concat(firstTwoChunks, remainingChunk)) {
        switch (++messageNum) {
            case 1:
                assertEquals("Feb 20 17:05:18 otter kernel[0]: CODE SIGNING: cs_invalid_page(0x1000): p=32696[GoogleSoftwareUp] final status 0x0, allow (remove VALID)ing page", chunk);
                break;
            case 2:
                assertEquals("Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KeystoneDaemon logServiceState] GoogleSoftwareUpdate daemon (1.1.0.3659) vending:", chunk);
                break;
            case 3:
                assertEquals("Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KSUpdateEngine updateProductID:] KSUpdateEngine updating product ID: \"com.google.Keystone\"", chunk);
                break;
        }
    }

    assertEquals("the last chunk should have triggered a message (no follow mode active)", 3, messageNum);
}
 
開發者ID:DevOpsStudio,項目名稱:Re-Collector,代碼行數:30,代碼來源:NewlineChunkSplitterTest.java

示例12: successfulSplitCRLF

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
@Test
public void successfulSplitCRLF() throws Exception {
    final NewlineChunkSplitter splitter = new NewlineChunkSplitter();

    final String logLines = "Feb 20 17:05:18 otter kernel[0]: CODE SIGNING: cs_invalid_page(0x1000): p=32696[GoogleSoftwareUp] final status 0x0, allow (remove VALID)ing page\r\n" +
            "Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KeystoneDaemon logServiceState] GoogleSoftwareUpdate daemon (1.1.0.3659) vending:\r\n" +
            "Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KSUpdateEngine updateProductID:] KSUpdateEngine updating product ID: \"com.google.Keystone\"\r\n";

    final ByteBuf buffer = Unpooled.copiedBuffer(logLines, UTF_8);
    final Iterable<String> firstTwoChunks = splitter.split(buffer, UTF_8);
    final Iterable<String> remainingChunk = splitter.splitRemaining(buffer, UTF_8);

    int messageNum = 0;
    for (String chunk : Iterables.concat(firstTwoChunks, remainingChunk)) {
        switch (++messageNum) {
            case 1:
                assertEquals("Feb 20 17:05:18 otter kernel[0]: CODE SIGNING: cs_invalid_page(0x1000): p=32696[GoogleSoftwareUp] final status 0x0, allow (remove VALID)ing page", chunk);
                break;
            case 2:
                assertEquals("Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KeystoneDaemon logServiceState] GoogleSoftwareUpdate daemon (1.1.0.3659) vending:", chunk);
                break;
            case 3:
                assertEquals("Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KSUpdateEngine updateProductID:] KSUpdateEngine updating product ID: \"com.google.Keystone\"", chunk);
                break;
        }
    }

    assertEquals("the last chunk should have triggered a message (no follow mode active)", 3, messageNum);
}
 
開發者ID:DevOpsStudio,項目名稱:Re-Collector,代碼行數:30,代碼來源:NewlineChunkSplitterTest.java

示例13: sendError

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
private void sendError(ChannelHandlerContext ctx, HttpResponseStatus status) {
    ByteBuf content = Unpooled.copiedBuffer("Failure: " + status + "\r\n",
            CharsetUtil.UTF_8);
    FullHttpResponse response = new DefaultFullHttpResponse(
            HttpVersion.HTTP_1_1, status, content);
    response.headers().set(HttpHeaderNames.CONTENT_TYPE, "text/plain; charset=UTF-8");

    // Close the connection as soon as the error message is sent.
    ctx.writeAndFlush(response).addListener(ChannelFutureListener.CLOSE);
}
 
開發者ID:xipki,項目名稱:xitk,代碼行數:11,代碼來源:HttpServer.java

示例14: prepareServerIcon

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
private void prepareServerIcon()
{
    if (this.server.getBase64EncodedIconData() == null)
    {
        this.mc.getTextureManager().deleteTexture(this.serverIcon);
        this.icon = null;
    }
    else
    {
        ByteBuf bytebuf = Unpooled.copiedBuffer((CharSequence)this.server.getBase64EncodedIconData(), Charsets.UTF_8);
        ByteBuf bytebuf1 = null;
        BufferedImage bufferedimage;
        label103:
        {
            try
            {
                bytebuf1 = Base64.decode(bytebuf);
                bufferedimage = TextureUtil.readBufferedImage(new ByteBufInputStream(bytebuf1));
                Validate.validState(bufferedimage.getWidth() == 64, "Must be 64 pixels wide", new Object[0]);
                Validate.validState(bufferedimage.getHeight() == 64, "Must be 64 pixels high", new Object[0]);
                break label103;
            }
            catch (Throwable throwable)
            {
                LOGGER.error("Invalid icon for server {} ({})", new Object[] {this.server.serverName, this.server.serverIP, throwable});
                this.server.setBase64EncodedIconData((String)null);
            }
            finally
            {
                bytebuf.release();

                if (bytebuf1 != null)
                {
                    bytebuf1.release();
                }
            }

            return;
        }

        if (this.icon == null)
        {
            this.icon = new DynamicTexture(bufferedimage.getWidth(), bufferedimage.getHeight());
            this.mc.getTextureManager().loadTexture(this.serverIcon, this.icon);
        }

        bufferedimage.getRGB(0, 0, bufferedimage.getWidth(), bufferedimage.getHeight(), this.icon.getTextureData(), 0, bufferedimage.getWidth());
        this.icon.updateDynamicTexture();
    }
}
 
開發者ID:sudofox,項目名稱:Backmemed,代碼行數:51,代碼來源:ServerListEntryNormal.java

示例15: buildDefaultFullHttpResponse

import io.netty.buffer.Unpooled; //導入方法依賴的package包/類
/**
 * convert response to DefaultFullHttpResponse
 */
public HttpResponse buildDefaultFullHttpResponse() throws IOException {
    DefaultHttpResponse fullHttpResponse = null;

    int length = 0;
    //set body
    if (this.body() == null && this.file == null) {
        fullHttpResponse = new DefaultHttpResponse(HttpVersion.HTTP_1_1, this.responseStatus());
    } else {
        if (this.body() != null) {
            DefaultFullHttpResponse response = new DefaultFullHttpResponse(HttpVersion.HTTP_1_1, this.responseStatus(), Unpooled.copiedBuffer(JSON.toJSONString(body()).getBytes()));
            length = response.content().readableBytes();
            fullHttpResponse = response;
        } else {
            //http file
            fullHttpResponse = new DefaultHttpResponse(HttpVersion.HTTP_1_1, this.responseStatus());
        }
    }

    //set headers
    for (String s : this.headers().keySet()) {
        fullHttpResponse.headers().add(s, headers.get(s));
    }

    //set content type if has not been done
    if (!fullHttpResponse.headers().contains("Content-type")) {
        if (body instanceof String) {
            fullHttpResponse.headers().set(HttpHeader.CONTENT_TYPE, "text/plain");
        } else {
            fullHttpResponse.headers().set(HttpHeader.CONTENT_TYPE, "application/json;charset=utf-8");
        }
    }

    //set set-cookie header
    if (cookies() != null) {
        fullHttpResponse.headers().add(HttpHeader.SET_COOKIE, cookies().stream()
                .map(Cookie::toString)
                .collect(Collectors.toList()));
    }
    fullHttpResponse.headers().set(HttpHeader.CONNECTION, "keep-alive");
    fullHttpResponse.headers().set(HttpHeader.CONTENT_LENGTH, length + fileLength());
    fullHttpResponse.headers().set(HttpHeader.SERVER, "Ink");
    return fullHttpResponse;
}
 
開發者ID:zhyzhyzhy,項目名稱:Ink,代碼行數:47,代碼來源:Response.java


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