Форум программистов, компьютерный форум CyberForum.ru

Программирование Android

Войти
Регистрация
Восстановить пароль
 
yura91
28 / 26 / 2
Регистрация: 23.10.2013
Сообщений: 2,195
#1

Для чего применяется класс OAuthConsumer при публикации приложений в твиттере? - Android

04.08.2014, 15:33. Просмотров 448. Ответов 7
Метки нет (Все метки)

для чего применяется этот класс в публикации приложений в твиттере ?? Он помоему сохраняет пользовательский логин и пароль ?? а как туда заносятся данные получается сразу после того как пользователь вводит логин и пароль в браузере как работает этот класс?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
04.08.2014, 15:33     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере?
Посмотрите здесь:

Android Разработка приложений для Андроид. С чего начать? Что нужно изучить?
Прервет ли Тоаст работу других приложений при появлении Android
С чего начать разработку приложений Android
Падает приложение для публикации вконтакте Android
Как прочитать личные сообщения в твиттере Android
Как правильно создать аккаунт разработчика для публикации проекта? Android
Ошибка при публикации приложения в Play Market Android
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
YuraAAA
 Аватар для YuraAAA
1564 / 1306 / 269
Регистрация: 25.10.2009
Сообщений: 3,424
Записей в блоге: 2
04.08.2014, 16:32     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере? #2
Это видимо класс какой-то либы, это не нативный android framework.
yura91
28 / 26 / 2
Регистрация: 23.10.2013
Сообщений: 2,195
04.08.2014, 19:22  [ТС]     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере? #3
да это класс либы

Добавлено через 1 минуту
но если речь идет о регистрации через приложение твиттере то он служит для сохранения пользовательского логина и пароля по ходу да?
Netscape
 Аватар для Netscape
371 / 358 / 48
Регистрация: 02.10.2009
Сообщений: 712
Записей в блоге: 4
05.08.2014, 15:43     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере? #4
В нем сохраняется ключ доступа. Пароль и логин не сохраняются.
yura91
28 / 26 / 2
Регистрация: 23.10.2013
Сообщений: 2,195
20.08.2014, 14:20  [ТС]     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере? #5
просто дело в том что почему когда я запускаю приложение для публикации картинок в твиттер меня выводит не на страницу авторизации в твиттер а на страницу авторизации приложения это получается я как то не правильно задал ключи в проекте???я ж регистрировал приложение не подскажите почему это происходит???
KillAndEat
63 / 63 / 8
Регистрация: 17.05.2013
Сообщений: 286
21.08.2014, 03:50     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере? #6
yura91, может вы токен для работы с методами апи нигде не сохранили?
yura91
28 / 26 / 2
Регистрация: 23.10.2013
Сообщений: 2,195
21.08.2014, 17:50  [ТС]     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере? #7
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
findViewById(R.id.postImageButton).setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                if (LoginActivity.isActive(context)) {
                    try {
 
                        mAlertBuilder = new AlertDialog.Builder(context).create();
                        mAlertBuilder.setCancelable(false);
                        mAlertBuilder.setTitle(R.string.please_wait_title);
                        View view = getLayoutInflater().inflate(R.layout.view_loading, null);
                        ((TextView) view.findViewById(R.id.messageTextViewFromLoading)).setText(getString(R.string.posting_image_message));
                        mAlertBuilder.setView(view);
                        mAlertBuilder.show();
 
                        InputStream inputStream  = v.getContext().getAssets().open("1.png");
                        Bitmap bmp = BitmapFactory.decodeStream(inputStream);
                        String filename = Environment.getExternalStorageDirectory().toString() + File.separator + "1.png";
                        Log.d("BITMAP", filename);
                        FileOutputStream out = new FileOutputStream(filename);
                        bmp.compress(Bitmap.CompressFormat.PNG, 90, out);
 
                        HelperMethods.postToTwitterWithImage(context, ((Activity)context), filename, getString(R.string.tweet_with_image_text), new TwitterCallback() {
 
                            @Override
                            public void onFinsihed(Boolean response) {
                                mAlertBuilder.dismiss();
                                Log.d(TAG, "----------------response----------------" + response);
                                Toast.makeText(context, getString(R.string.image_posted_on_twitter), Toast.LENGTH_SHORT).show();
                            }
                        });
 
                    } catch (Exception ex) {
                        Toast.makeText(context, "ERROR", Toast.LENGTH_SHORT).show();
                    }
                }else{
                    startActivity(new Intent(context, LoginActivity.class));
                }               
            }
        });
Добавлено через 2 минуты
сдесь идет обработчик кнопки который вызывает диалог

Добавлено через 1 минуту
Java
1
2
3
4
5
public static void postToTwitterWithImage(Context context, final Activity callingActivity, final String imageUrl, final String message, final TwitterCallback postResponse){
        if(!LoginActivity.isActive(context)){
            postResponse.onFinsihed(false);
            return;
        }
вызывается вот такой вот метод

Добавлено через 2 минуты
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
package com.learnncode.demotwitterimagepost;
 
import twitter4j.Twitter;
import twitter4j.TwitterFactory;
import twitter4j.auth.AccessToken;
import twitter4j.auth.RequestToken;
import twitter4j.conf.Configuration;
import twitter4j.conf.ConfigurationBuilder;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.content.SharedPreferences.Editor;
import android.graphics.Bitmap;
import android.graphics.Color;
import android.net.Uri;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.TextView;
import android.widget.Toast;
 
public class LoginActivity extends Activity {
 
    public static final int TWITTER_LOGIN_RESULT_CODE_SUCCESS = 1111;
    public static final int TWITTER_LOGIN_RESULT_CODE_FAILURE = 2222;
 
    private static final String TAG = "LoginActivity";
 
    private WebView twitterLoginWebView;
    private AlertDialog mAlertBuilder;
    private static String twitterConsumerKey;
    private static String twitterConsumerSecret;
 
    private static Twitter twitter;
    private static RequestToken requestToken;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_twitter_login);
        twitterConsumerKey = getResources().getString(R.string.twitter_consumer_key);
        twitterConsumerSecret = getResources().getString(R.string.twitter_consumer_secret);
 
        if(twitterConsumerKey == null || twitterConsumerSecret == null){
            Log.e(TAG, "ERROR: Consumer Key and Consumer Secret required!");
            LoginActivity.this.setResult(TWITTER_LOGIN_RESULT_CODE_FAILURE);
            LoginActivity.this.finish();
        }
 
 
        mAlertBuilder = new AlertDialog.Builder(this).create();
        mAlertBuilder.setCancelable(false);
        mAlertBuilder.setTitle(R.string.please_wait_title);
        View view = getLayoutInflater().inflate(R.layout.view_loading, null);
        ((TextView) view.findViewById(R.id.messageTextViewFromLoading)).setText(getString(R.string.authenticating_your_app_message));
        mAlertBuilder.setView(view);
        mAlertBuilder.show();
 
 
        twitterLoginWebView = (WebView)findViewById(R.id.twitterLoginWebView);
        twitterLoginWebView.setBackgroundColor(Color.TRANSPARENT);
        twitterLoginWebView.setWebViewClient( new WebViewClient(){
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url){
 
                if( url.contains(AppConstant.TWITTER_CALLBACK_URL)){
                    Uri uri = Uri.parse(url);
                    LoginActivity.this.saveAccessTokenAndFinish(uri);
                    return true;
                }
                return false;
            }
 
            @Override
            public void onPageFinished(WebView view, String url) {
                super.onPageFinished(view, url);
 
                if(mAlertBuilder != null){
                    mAlertBuilder.cancel();
                }
            }
 
            @Override
            public void onPageStarted(WebView view, String url, Bitmap favicon) {
                super.onPageStarted(view, url, favicon);
 
                if(mAlertBuilder != null){
                    mAlertBuilder.show();
                }
            }
        });
 
        Log.d(TAG, "Authorize....");
        askOAuth();
    }
 
    @Override
    protected void onDestroy() {
        super.onDestroy();
 
        if(mAlertBuilder != null) {
            mAlertBuilder.dismiss();
        }
    }
 
    @Override
    protected void onNewIntent(Intent intent) {
        super.onNewIntent(intent);
    }
 
    @Override
    protected void onResume() {
        super.onResume();
    }
 
    private void saveAccessTokenAndFinish(final Uri uri){
        new Thread(new Runnable() {
            @Override
            public void run() {
                String verifier = uri.getQueryParameter(AppConstant.IEXTRA_OAUTH_VERIFIER);
                try { 
                    SharedPreferences sharedPrefs = getSharedPreferences(AppConstant.SHARED_PREF_NAME, Context.MODE_PRIVATE);
                    AccessToken accessToken = twitter.getOAuthAccessToken(requestToken, verifier); 
                    Editor e = sharedPrefs.edit();
                    e.putString(AppConstant.SHARED_PREF_KEY_TOKEN, accessToken.getToken()); 
                    e.putString(AppConstant.SHARED_PREF_KEY_SECRET, accessToken.getTokenSecret()); 
                    e.commit();
 
                    Log.d(TAG, "TWITTER LOGIN SUCCESS ----TOKEN " + accessToken.getToken());
                    Log.d(TAG, "TWITTER LOGIN SUCCESS ----TOKEN SECRET " + accessToken.getTokenSecret());
                    LoginActivity.this.setResult(TWITTER_LOGIN_RESULT_CODE_SUCCESS);
                } catch (Exception e) { 
                    e.printStackTrace();
                    if(e.getMessage() != null){
                        Log.e(TAG, e.getMessage());
 
                    }else{
                        Log.e(TAG, "ERROR: Twitter callback failed");
                    }
                    LoginActivity.this.setResult(TWITTER_LOGIN_RESULT_CODE_FAILURE);
                }
                LoginActivity.this.finish();
            }
        }).start();
    }
 
 
    public static boolean isActive(Context ctx) {
        SharedPreferences sharedPrefs = ctx.getSharedPreferences(AppConstant.SHARED_PREF_NAME, Context.MODE_PRIVATE);
        return sharedPrefs.getString(AppConstant.SHARED_PREF_KEY_TOKEN, null) != null;
    }
 
    public static void logOutOfTwitter(Context ctx){
        SharedPreferences sharedPrefs = ctx.getSharedPreferences(AppConstant.SHARED_PREF_NAME, Context.MODE_PRIVATE);
        Editor e = sharedPrefs.edit();
        e.putString(AppConstant.SHARED_PREF_KEY_TOKEN, null); 
        e.putString(AppConstant.SHARED_PREF_KEY_SECRET, null); 
        e.commit();
    }
 
    public static String getAccessToken(Context ctx){
        SharedPreferences sharedPrefs = ctx.getSharedPreferences(AppConstant.SHARED_PREF_NAME, Context.MODE_PRIVATE);
        return sharedPrefs.getString(AppConstant.SHARED_PREF_KEY_TOKEN, null);
    }
 
    public static String getAccessTokenSecret(Context ctx){
        SharedPreferences sharedPrefs = ctx.getSharedPreferences(AppConstant.SHARED_PREF_NAME, Context.MODE_PRIVATE);
        return sharedPrefs.getString(AppConstant.SHARED_PREF_KEY_SECRET, null);
    }
 
    private void askOAuth() {
        ConfigurationBuilder configurationBuilder = new ConfigurationBuilder();
        configurationBuilder.setOAuthConsumerKey(twitterConsumerKey);
        configurationBuilder.setOAuthConsumerSecret(twitterConsumerSecret);
        Configuration configuration = configurationBuilder.build();
        twitter = new TwitterFactory(configuration).getInstance();
 
        new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    requestToken = twitter.getOAuthRequestToken(AppConstant.TWITTER_CALLBACK_URL);
                } catch (Exception e) {
                    final String errorString = e.toString();
                    LoginActivity.this.runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            mAlertBuilder.cancel();
                            Toast.makeText(LoginActivity.this, errorString.toString(), Toast.LENGTH_SHORT).show();
                            finish();
                        }
                    });
                    return;
                }
 
                LoginActivity.this.runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        twitterLoginWebView.loadUrl(requestToken.getAuthenticationURL());
                    }
                });
            }
        }).start();
    }
 
}
Добавлено через 50 секунд
вот само LoginActivity

Добавлено через 57 секунд
XML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<?xml version="1.0" encoding="utf-8"?>
<resources>
 
    <string name="app_name">DemoTwitterImagePost</string>
    <string name="action_settings">Settings</string>
    <string name="twitter_consumer_key">MtZV0R7nZMmTS0N5Uiiz52AV2</string>
    <string name="twitter_consumer_secret"> KZex7LHCC2wHuhLhiOwWFs5CgJfiUeSuqWgZx3b7C4GxFQSIRd</string>
    <string name="post_image">Post Image</string>
    <string name="post_tweet">Post Tweet</string>
    <string name="authentication_done_now_post_tweet_or_image_text"> Your app is authenticated. Now  you can post tweet/image on twitter. </string>
 
    <!-- loading messages -->
    <string name="please_wait_title"> Please wait </string>
    <string name="authenticating_your_app_message"> Authenticating your app... </string>
    <string name="posting_image_message"> Uploading image on twitter... </string>
    <string name="posting_tweet_message"> Posting tweet on twitter... </string>
 
    <!-- toast -->
 
    <string name="image_posted_on_twitter"> Image posted on twitter successfully. </string>
    <string name="tweet_posted_on_twitter"> Tweet posted on twitter successfully. </string>
    <string name="tweet_with_image_text"> dummy tweet with image. </string>
    <string name="tweet_text"> dummy tweet. </string>
 
</resources>
Добавлено через 52 секунды
а это ресурсы в которых также хранятся и API key

Добавлено через 1 минуту
А токен для работы с апи я беру в контексте приложения можно так??? в чем ошибка и как ее исправить??

Добавлено через 4 часа 1 минуту
можно ли брать token в контексте приложения через Context как тут реализовано?? в чем тогда ошибка??
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
30.08.2014, 01:34     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере?
Еще ссылки по теме:

Новые правила публикации приложений на Google Play Android
Android С чего начать разработку приложений и игр на Андроид?
Android Для чего производится индексация Андроид-приложений?
Создание app-release.apk для публикации в маркете Android
Для чего делать Resize при использовании Picasso Android

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
yura91
28 / 26 / 2
Регистрация: 23.10.2013
Сообщений: 2,195
30.08.2014, 01:34  [ТС]     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере? #8
неподскажите где сохраняются данные после регистрации пользователя в твиттере ??какой класс за это отвечает??
Yandex
Объявления
30.08.2014, 01:34     Для чего применяется класс OAuthConsumer при публикации приложений в твиттере?
Ответ Создать тему
Опции темы

Текущее время: 08:40. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru