как получить доступ к Facebook или Твиттеру с помощью API ежевики?

DATE_ADD () функция добьется цели. (Можно также использовать ADDTIME () функция, если Вы работаете, по крайней мере, v4.1.1.)

Для Вашего запроса, это было бы:

SELECT * 
FROM courses 
WHERE DATE_ADD(now(), INTERVAL 2 HOUR) > start_time

Или,

SELECT * 
FROM courses 
WHERE ADDTIME(now(), '02:00:00') > start_time

10
задан Maksym Gontar 14 September 2009 в 06:42
поделиться

2 ответа

Facebook предлагает API на основе веб-сервисов, который вы можете использовать - они предоставляют информация об этом здесь:

http://wiki.developers.facebook.com/index.php/Platform_Basics

Я настоятельно рекомендую использовать Sun Java Wireless Toolkit (Sun Java Wireless Toolkit 2.5.2_01 для CLDC, доступный здесь : SJW Toolkit ) - используйте приложение Utilities при установке, а затем «Генератор заглушек» - он создаст классы J2ME и заглушки для всех вызовов веб-сервисов, которые вы затем можете перенести в свой проект BlackBerry. Я обязательно использовал это для вызова веб-служб из BlackBerry, и это намного проще, чем создание собственных оболочек вызовов веб-служб.

8
ответ дан 3 December 2019 в 22:01
поделиться

BlackBerry FaceBook Connect

См. пример кода, предоставленный Eki Y. Baskoro: Facebook Connect на Blackberry

Ниже приводится краткое HOWTO по использованию Facebook Подключитесь к Blackberry. Я создал простой фасад, инкапсулирующий API REST Facebook, а также добавил «грубый» подход MVC для экранной навигации. Я тестировал JDE 4.5 с помощью симулятора 8320. Эта работа все еще продолжается, и все работы под лицензией GPL.

BlackBerry Twitter Connect

Кстати, о twitter , есть twitter api и клиент j2me с открытым исходным кодом - jibjib , на который стоит посмотреть.
Образец статуса публикации:

 class Scr extends MainScreen implements FieldChangeListener {
    BasicEditField musername;
    BasicEditField mPassword;
    BasicEditField mStatus;
    ButtonField mUpdateStatus;

    public Scr() {
        add(musername = new BasicEditField("username: ", ""));
        add(mPassword = new BasicEditField("password: ", ""));
        add(mStatus = new BasicEditField("status: ", ""));
        mUpdateStatus = new ButtonField(ButtonField.CONSUME_CLICK);
        mUpdateStatus.setLabel("update status");
        mUpdateStatus.setChangeListener(this);
        add(mUpdateStatus);
    }

    public void fieldChanged(Field field, int context) {
        if (mUpdateStatus == field) {
            String username = musername.getText().trim();
            String password = mPassword.getText().trim();
            String status = mStatus.getText().trim();
            updateStatus(username, password, status);
        } else {

        }
    }

    void updateStatus(String username, String password, String status) {
        String response = "";
        try {
            String query = "status=" + urlEncode(status);
            String len = String.valueOf(query.length());
            SocketConnection hc = (SocketConnection) Connector
                    .open("socket://twitter.com:80");
            DataOutputStream dout = 
                new DataOutputStream(hc.openOutputStream());
            DataInputStream din = new DataInputStream(hc.openInputStream());
            String userPass = username + ":" + password;
            byte[] encoded = Base64OutputStream.encode(userPass.getBytes(), 0,
                    userPass.length(), false, false);
            ByteArrayOutputStream bos = new ByteArrayOutputStream();
            String request = "POST /statuses/update.json HTTP/1.1\r\n"
                    + "Host: twitter.com:80\r\n"
                    + "User-Agent: curl/7.18.0 (i486-pc-linux-gnu) " +
                            "libcurl/7.18.0 OpenSSL/0.9.8g zlib/1.2.3.3 " +
                            "libidn/1.1\r\n"
                    + "Accept: */*\r\n"
                    + "Content-Type: application/x-www-form-urlencoded\r\n"
                    + "Content-Length: " + len + "\r\nAuthorization: Basic "
                    + new String(encoded) + "\r\n\r\n";
            bos.write(request.getBytes());
            bos.write(query.getBytes());
            dout.write(bos.toByteArray());
            dout.flush();
            dout.close();
            byte[] bs = new byte[900];
            din.readFully(bs);
            bos = new ByteArrayOutputStream();
            bos.write(bs);
            din.close();
            hc.close();
            response = bos.toString();
        } catch (Exception ex) {
            System.out.println(ex.getMessage()+" "+response);
        }
    }

    public static String urlEncode(String s) {
        if (s != null) {
            try {
                s = new String(s.getBytes("UTF-8"), "ISO-8859-1");
            } catch (UnsupportedEncodingException e) {
            }
            StringBuffer tmp = new StringBuffer();
            try {
                for (int i = 0; i < s.length(); i++) {
                    int b = (int) s.charAt(i);
                    if ((b >= 0x30 && b <= 0x39) || (b >= 0x41 && b <= 0x5A)
                            || (b >= 0x61 && b <= 0x7A)) {
                        tmp.append((char) b);
                    } else if (b == 0x20) {
                        tmp.append("+");
                    } else {
                        tmp.append("%");
                        if (b <= 0xf) {
                            tmp.append("0");
                        }
                        tmp.append(Integer.toHexString(b));
                    }
                }
            } catch (Exception e) {
            }
            return tmp.toString();
        }
        return null;
    }
}

ОБНОВЛЕНИЕ

Twitter API ME lib v.1.8 для RIM доступно в Project Kenai

7
ответ дан 3 December 2019 в 22:01
поделиться
Другие вопросы по тегам:

Похожие вопросы: