⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 httputils.java

📁 J2ME MIDP_Example_Applications
💻 JAVA
字号:
// Copyright 2003 Nokia Corporation.
//
// THIS SOURCE CODE IS PROVIDED 'AS IS', WITH NO WARRANTIES WHATSOEVER,
// EXPRESS OR IMPLIED, INCLUDING ANY WARRANTY OF MERCHANTABILITY, FITNESS
// FOR ANY PARTICULAR PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE
// OR TRADE PRACTICE, RELATING TO THE SOURCE CODE OR ANY WARRANTY OTHERWISE
// ARISING OUT OF ANY PROPOSAL, SPECIFICATION, OR SAMPLE AND WITH NO
// OBLIGATION OF NOKIA TO PROVIDE THE LICENSEE WITH ANY MAINTENANCE OR
// SUPPORT. FURTHERMORE, NOKIA MAKES NO WARRANTY THAT EXERCISE OF THE
// RIGHTS GRANTED HEREUNDER DOES NOT INFRINGE OR MAY NOT CAUSE INFRINGEMENT
// OF ANY PATENT OR OTHER INTELLECTUAL PROPERTY RIGHTS OWNED OR CONTROLLED
// BY THIRD PARTIES
//
// Furthermore, information provided in this source code is preliminary,
// and may be changed substantially prior to final release. Nokia Corporation
// retains the right to make changes to this source code at
// any time, without notice. This source code is provided for informational
// purposes only.
//
// Nokia and Nokia Connecting People are registered trademarks of Nokia
// Corporation.
// Java and all Java-based marks are trademarks or registered trademarks of
// Sun Microsystems, Inc.
// Other product and company names mentioned herein may be trademarks or
// trade names of their respective owners.
//
// A non-exclusive, non-transferable, worldwide, limited license is hereby
// granted to the Licensee to download, print, reproduce and modify the
// source code. The licensee has the right to market, sell, distribute and
// make available the source code in original or modified form only when
// incorporated into the programs developed by the Licensee. No other
// license, express or implied, by estoppel or otherwise, to any other
// intellectual property rights is granted herein.
package whiteboard;

import java.io.*;

class HttpUtils
{
    private final static char[] hexdigits = new char[16];

    // Base-64 encoding is defined in http://RFC.net/rfc1521.html
    private final static char[] alphabet = new char[64];

    static
    {
        // fill hexdigits with {0123456789ABCDEF}
        for (int c = '0', i = 0; c <= '9'; c++, i++)
        {
            hexdigits[i] = (char) c;
        }
        for (int c = 'A', i = 10; c <= 'F'; c++, i++)
        {
            hexdigits[i] = (char) c;
        }
        // fill base64 alphabet
        for (int c = 'A', i = 0; c <= 'Z'; c++, i++)
        {
            alphabet[i] = (char) c;
        }
        for (int c = 'a', i = 26; c <= 'z'; c++, i++)
        {
            alphabet[i] = (char) c;
        }
        for (int c = '0', i = 52; c <= '9'; c++, i++)
        {
            alphabet[i] = (char) c;
        }
        alphabet[62] = (char) '+';
        alphabet[63] = (char) '/';
    }


    private HttpUtils()
    {
    }


    // encodes the string in URL format as indicated in RFC 1738
    static String encodeURL(String url)
    {
        int maxBytesPerChar = 10;
        StringBuffer result = new StringBuffer();
        ByteArrayOutputStream buffer = new ByteArrayOutputStream(maxBytesPerChar);
        OutputStreamWriter writer = null;
        // UTF-8 encoding is recommended by W3C
        try
        {
            writer = new OutputStreamWriter(buffer, "UTF-8");
        }
        catch (UnsupportedEncodingException e)
        {
            // use default encoding then
            writer = new OutputStreamWriter(buffer);
        }
        int size = url.length();

        for (int i = 0; i < size; i++)
        {
            int current = (int) url.charAt(i);
            // print non changed chars as normal
            if ((current >= 'a' && current <= 'z')
                 || (current >= 'A' && current <= 'Z')
                 || (current >= '0' && current <= '9')
                 || current == '.' || current == '_' || current == '-' || current == '*')
            {
                result.append((char) current);
            }
            else if (current == ' ')
            {
                // space is a special case
                result.append('+');
            }
            else
            {
                // try to write to the ByteArrayStream
                try
                {
                    writer.write(current);
                    writer.flush();
                }
                catch (IOException e)
                {
                    buffer.reset();
                    continue;
                }
                byte[] array = buffer.toByteArray();
                for (int j = 0; j < array.length; j++)
                {
                    byte currentByte = array[j];
                    int low = (int) (currentByte & 0x0F);
                    int high = (int) ((currentByte & 0xF0) >> 4);

                    result.append('%');
                    result.append(hexdigits[high]);
                    result.append(hexdigits[low]);
                }
                buffer.reset();
            }
        }
        return result.toString();
    }


    // Each 3 chars of input is encoded as 4 chars of output from above
    // 64-char alphabet. It's assumed that chars are 8-bit values.
    // If length is multiple of 3, no problem.
    // If length is multiple of 3 + 1, last output char is zero-completed
    // and two '=' characters are appended.
    // If length is multiple of 3 + 2, last output char is zero-completed
    // and one '=' character is appended
    static String base64Encode(String str)
    {
        StringBuffer buf = new StringBuffer((str.length() + 2) / 3 * 4);
        int completeGroupChars = (str.length() / 3) * 3;
        int extraChars = str.length() % 3;

        // first write complete groups of 3 chars
        int i;
        for (i = 0; i < completeGroupChars; i += 3)
        {
            int group = ((((int) str.charAt(i)) & 0xFF) << 16) |
                ((((int) str.charAt(i + 1)) & 0xFF) << 8) |
                (((int) str.charAt(i + 2)) & 0xFF);

            buf.append(alphabet[(group >> 18) & 63]);
            buf.append(alphabet[(group >> 12) & 63]);
            buf.append(alphabet[(group >> 6) & 63]);
            buf.append(alphabet[group & 63]);
        }

        if (extraChars == 2)
        {
            int group = ((((int) str.charAt(i)) & 0xFF) << 16) |
                ((((int) str.charAt(i + 1)) & 0xFF) << 8);
            buf.append(alphabet[(group >> 18) & 63]);
            buf.append(alphabet[(group >> 12) & 63]);
            buf.append(alphabet[(group >> 6) & 63]);
            buf.append('=');
        }
        else if (extraChars == 1)
        {
            int group = (((int) str.charAt(i)) & 0xFF) << 16;
            buf.append(alphabet[(group >> 18) & 63]);
            buf.append(alphabet[(group >> 12) & 63]);
            buf.append('=');
            buf.append('=');
        }
        return buf.toString();
    }

}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -