С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

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

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

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

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

Для чего производится индексация Андроид-приложений? - Программирование Android
Для чего производится индексация андроид приложений? С какой целью?

Новые правила публикации приложений на Google Play - Программирование Android
Месяц не публиковал свое приложение, тут зашел в консоль, загрузил apk и вижу такую вот хрень. Что это за ебола?????????? Что за...

Разработка приложений для Андроид. С чего начать? Что нужно изучить? - Программирование Android
Ребят, подскажите! Хочу стать разрабом для популярной ОС Андроид, с чего начать? Что нужно изучить, где 100% безопасно можно взять...

Где и для чего применяется контрол Usercontrol - C#
Где и для чего применяется контрол Usercontrol ? Как и когда правильно его применять?

Для чего применяется Каррирование в языках высокого уровня? - Haskell
Добрый день, гуру функционального программирования! Ввиду большого интереса к теории компиляции и в своё время(на 2ом курсе) утраченной...

Объяснить для чего используется ref и out, точнее их значение и когда применяется - C#
Кто может объяснить для чего используется ref и out, точнее их значение и когда применяется. Я много прочитала но ещё больше запуталась. :)

7
YuraAAA
1577 / 1318 / 271
Регистрация: 25.10.2009
Сообщений: 3,438
Записей в блоге: 2
04.08.2014, 16:32 #2
Это видимо класс какой-то либы, это не нативный android framework.
0
yura91
1 / 25 / 2
Регистрация: 23.10.2013
Сообщений: 2,310
04.08.2014, 19:22  [ТС] #3
да это класс либы

Добавлено через 1 минуту
но если речь идет о регистрации через приложение твиттере то он служит для сохранения пользовательского логина и пароля по ходу да?
0
Netscape
374 / 361 / 48
Регистрация: 02.10.2009
Сообщений: 712
Записей в блоге: 4
05.08.2014, 15:43 #4
В нем сохраняется ключ доступа. Пароль и логин не сохраняются.
0
yura91
1 / 25 / 2
Регистрация: 23.10.2013
Сообщений: 2,310
20.08.2014, 14:20  [ТС] #5
просто дело в том что почему когда я запускаю приложение для публикации картинок в твиттер меня выводит не на страницу авторизации в твиттер а на страницу авторизации приложения это получается я как то не правильно задал ключи в проекте???я ж регистрировал приложение не подскажите почему это происходит???
0
KillAndEat
63 / 63 / 8
Регистрация: 17.05.2013
Сообщений: 286
21.08.2014, 03:50 #6
yura91, может вы токен для работы с методами апи нигде не сохранили?
0
yura91
1 / 25 / 2
Регистрация: 23.10.2013
Сообщений: 2,310
21.08.2014, 17:50  [ТС] #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 как тут реализовано?? в чем тогда ошибка??
0
yura91
1 / 25 / 2
Регистрация: 23.10.2013
Сообщений: 2,310
30.08.2014, 01:34  [ТС] #8
неподскажите где сохраняются данные после регистрации пользователя в твиттере ??какой класс за это отвечает??
0
30.08.2014, 01:34
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
30.08.2014, 01:34
Привет! Вот еще темы с ответами:

Для чего в коде применяется символ "~" - C#
Вопрос возможно не самый умный(но все же этот раздел для начинающих) Сталкнулся с примером в книге в котором в класе создаются два...

С чего начать создание приложений для wp 8.1? - Windows Phone
Объясните пожалуйста с чего начать создание приложений на вп8,1? На каком языке лучше писать на с++ или ява (что быстрее будет работать)?...

Программирование приложений для Компас-3D - с чего начать - Visual Basic .NET
Не могу запустить Компас: пишу Imports Kompas6API5 Imports Kompas6Constants Public Class Form1 Private Sub...

С чего начать писать свои API для приложений - C++
можно ссылки Заранее спаисибо)


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.